対関数(ついかんすう、英: Pairing function)とは、2つの自然数を一意に符号化して1つの自然数を返す関数である。
集合論では、任意の対関数を用いて、有理数全体の集合 Q が可算濃度であることを証明できる。理論計算機科学では、自然数の多変数関数 f : Nk → N を一変数関数 g : N → N に変換するために使われる。
対関数は非可算無限個存在する。したがってその中には計算可能関数でないものが非可算無限個存在する。計算可能性理論や計算複雑性理論の文脈では、ある複雑性クラスの中で対をコード化して扱いたいことがあることから、対関数とその逆関数がともに目的の関数クラスに属するような符号化を見つけることが重要となる。
対関数は次のような全単射関数である。
![{\displaystyle \pi :\mathbb {N} \times \mathbb {N} \to \mathbb {N} .}](https://wikimedia.org/api/rest_v1/media/math/render/svg/e745ac69fa8aafd780d447d0adf45410ab192802)
カントールの対関数は、2つの自然数の対に1つの自然数を割り当てる。
カントールの対関数は次のように定義される対関数である。
![{\displaystyle \pi (k_{1},k_{2}):={\frac {1}{2}}(k_{1}+k_{2})(k_{1}+k_{2}+1)+k_{2}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/87f9c97454540088230d7b4aa179056900f836ae)
と
への対関数の適用をするとき、それによって得られる数を
と表記することが多い。
この定義を帰納的に一般化すると、カントールのタプル関数となる。すなわち、
![{\displaystyle \pi ^{(n)}:\mathbb {N} ^{n}\to \mathbb {N} }](https://wikimedia.org/api/rest_v1/media/math/render/svg/0bddf329579ee95d3e984d0bf03923866f49dd0c)
であり、ここで
![{\displaystyle \pi ^{(n)}(k_{1},\ldots ,k_{n-1},k_{n}):=\pi (\pi ^{(n-1)}(k_{1},\ldots ,k_{n-1}),k_{n})}](https://wikimedia.org/api/rest_v1/media/math/render/svg/fb804d468f2837aac0cb65c982c8997f58b69bed)
ここで z を次のように定義する。
![{\displaystyle z=\langle x,y\rangle ={\frac {(x+y)(x+y+1)}{2}}+y}](https://wikimedia.org/api/rest_v1/media/math/render/svg/51692d145ef2228604ab7184ff175f73974cf50b)
このときの x と y を求めたい。そのために中間的な値を定義する。
![{\displaystyle w=x+y\!}](https://wikimedia.org/api/rest_v1/media/math/render/svg/7718f9335f66f3b058f049bf8a87f8e0773994da)
![{\displaystyle t={\frac {w(w+1)}{2}}={\frac {w^{2}+w}{2}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/214515cc9274f923118e94127d99cfdc835866dd)
![{\displaystyle z=t+y\!}](https://wikimedia.org/api/rest_v1/media/math/render/svg/5129ed3a09cbcdbaa0774e08eb8561803f272cf6)
ここで t は w の三角数である。そこで次の二次方程式を解く。
![{\displaystyle w^{2}+w-2t=0\!}](https://wikimedia.org/api/rest_v1/media/math/render/svg/55c49c327568a6aab76f8411e3619fef4ff21570)
w を t の関数で表すと、次のようになる。
![{\displaystyle w={\frac {{\sqrt {8t+1}}-1}{2}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/381c4199137121930b88e642d6332be9beec3cd4)
t が非負実数であれば、これは単調増加する連続関数である。ここで
![{\displaystyle t\leq z=t+y<t+(w+1)={\frac {(w+1)^{2}+(w+1)}{2}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/064355d6f2c53ca4209804895783e94eb750c5dd)
が成り立つので、次が得られる。
![{\displaystyle w\leq {\frac {{\sqrt {8z+1}}-1}{2}}<w+1}](https://wikimedia.org/api/rest_v1/media/math/render/svg/7664423e5c38ac89c7218fceab42d390e5ad2c98)
従って
.
以上から z から x と y を計算すると次のようになる。
![{\displaystyle w=\left\lfloor {\frac {{\sqrt {8z+1}}-1}{2}}\right\rfloor }](https://wikimedia.org/api/rest_v1/media/math/render/svg/daa8d22b2942b099d4be50c2991eebdaaf700487)
![{\displaystyle t={\frac {w^{2}+w}{2}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/a5ea840fb429ed04261f8ab3a3b095a6ae1b66a9)
![{\displaystyle y=z-t\!}](https://wikimedia.org/api/rest_v1/media/math/render/svg/e3827ff2a4b59fa136c4076bd81eca3b9e7f3313)
![{\displaystyle x=w-y\!}](https://wikimedia.org/api/rest_v1/media/math/render/svg/1dd88600a7429423892be530a2ba4a7ffa66badb)
以上のようにカントールの対関数には逆関数が存在し、一対一対応している。
順序の言葉で述べるならば、
を和
が小さい順に並べ、和が等しいものについては
が小さい順に並べたとき、
から
への一意的な順序同型がカントールの対関数である。
対
を最大値
が小さい順に並べ、最大値が等しいものについては辞書式順序で並べれば、
から
への一意的な順序同型
が存在する。この関数は次のように表せる。
![{\displaystyle P(x,y)={\begin{cases}x+y^{2}&x<y\\x^{2}+x+y&x\geq y\end{cases}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/c7587ba5047e9534fba1788cf036d7e16df1cd0b)
逆関数
は次のように表せる。
![{\displaystyle Q(z)=\min(\lfloor {\sqrt {z}}\rfloor ,E(z))}](https://wikimedia.org/api/rest_v1/media/math/render/svg/c377ddb9f959d0317ebd508c2207cb5b1396aa27)
![{\displaystyle R(z)={\begin{cases}\lfloor {\sqrt {z}}\rfloor &E(z)<\lfloor {\sqrt {z}}\rfloor \\E(z)-\lfloor {\sqrt {z}}\rfloor &E(z)\geq \lfloor {\sqrt {z}}\rfloor \end{cases}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/5eecad74118e73628b8d7197055225700bcb075c)
ただし
である。
- Pigeon, Steven. "Pairing function". mathworld.wolfram.com (英語).
- Nagashima, Takashi (1965), “On a certain class of recursive functions”, Hitotsubashi Journal of Arts and Sciences 16: 72–81