計算可能数

有限回で計算可能な実数

数学において、計算可能数実数であって、有限かつ停止するアルゴリズムによって望んだいかなる精度でも計算可能なもののことである。再帰的な数実効的な数[1]計算可能実数再帰的実数などとしても知られる。[要出典]

π は任意の精度で計算可能である。一方、 ほとんど全ての実数は計算可能でない。

同値な定義はμ再帰関数チューリングマシンラムダ計算などを用いたアルゴリズムの形式的表現によっても得られる。計算可能数は実閉体をなし、全てではないが多くの数学的な目的において実数の代わりに用いることができる。

チューリングマシンを用いた非形式的定義の例 編集

マービン・ミンスキーは数の計算可能性をアラン・チューリングが1936年に行ったのと同様の方法で以下のように定義した[2]; すなわち、0から1の間にある "十進小数と見なせる数列"として:[3]。  

計算可能数とは以下のようなチューリングマシンが存在する数である: n が初期状態のテープに与えられたら、その数の[エンコード結果]のn桁目を出力して停止する。

この定義における重要な点は (1) 最初にある n を決めておくこと、(2) いかなる n に対しても有限ステップ後、マシンが望まれた出力をして停止することである.

(2) の代わりに次のようなものがある – マシンが n 桁全てを連続でテープに出力した後、n桁目を出力した後停止する – これは次のミンスキーの観察を強調する: (3) チューリングマシンを用いることによって、状態遷移図の形をした "有限的" な定義が 無限 の長さになるかもしれない十進小数を定義するのに用いられる。

これはしかしながら、与えられた任意精度内に計算結果を収めることのみを要求する現代的な定義とは異なる。上で記した非形式的な定義はtable-maker's dilemmaと呼ばれる丸め誤差の問題の影響を受けるが、現代的な定義はそうではない。

形式的な定義 編集

実数 a計算可能である' とは、それがある計算可能関数 によって以下のような意味で近似できることである:与えられた任意の正整数 n に対して、その関数は整数 f(n) を、

 

となるように与えること。 この定義には、これと同値な二つの別の定義も存在する。:

  • 与えられたいかなる有理誤差限界   に対しても有理数 r であるように生成するような計算可能関数が存在すること。 
  • 有理数の計算可能列   であって、  に収束してさらに各 i に対して が成り立つものが存在すること。

計算可能なデデキント切断を通した同値な定義も存在する。 計算可能なデデキント切断 とは、計算可能関数   であって、有理数   が入力として与えられると出力として    を返すものであって次の条件を満たすものである。: 

 
 
 

3 の 立方根を定めるプログラムはその一例である。  として、次のように定義する。:

 
 

実数が計算可能であるとは、その実数に対応する計算可能なデデキント切断 D が存在することである。そのような関数 D は各計算可能数に対して一意的である。(しかしながらもちろん、二つの異なるプログラムがあってそれが同じ関数を与えることもある。) 複素数 が計算可能であるとは、実部と虚部が共に計算可能であることである。

性質 編集

計算可枚挙でないこと 編集

各チューリングマシンの定義にゲーデル数を割り当てることで計算可能数に対応する 自然数 部分集合   を生成し、  から計算可能数全体への全射を与える。チューリングマシンは可算個しかないので、計算可能数全体はsubcountableである。しかしながら,ゲーデル数の集合   それ自身は、計算可枚挙ではない (それゆえ、  の部分集合でSを基に定義されるものも計算可枚挙ではない)。これは計算可能実数を生成するチューリングマシンに対応するゲーデル数を決定するアルゴリズムは存在しないためである。計算可能実数を生成するためには、チューリングマシンは全域関数を計算しなければならない、しかし、対応する決定問題チューリング次数0′′ である。結論として、自然数の集合から計算可能実数の集合への全射計算可能関数は存在しない。 実数全体の集合は不可算であって、計算可能数の集合は可算であり、ほとんど全ての 実数は計算可能ではない。ここで、任意の与えられた計算可能数  について、整列原理によって の極小要素で に対応するものが存在する。そして、それゆえそのような極小なゲーデル数からなる部分集合から計算可能数全体への全単射が存在する. この全単射の逆写像は計算可能数に対応する自然数の集合への単射である。しかし、前述の通りこの部分集合は計算可能実数が整列されていても計算可能ではない。

体としての性質 編集

計算可能数上の算術的操作はそれら自身計算可能である。すなわち、計算可能実数 ab が存在するとき、次の数は全て計算可能である: a + b, a - b, ab, そして b が 0 でない場合の a/b。これらの操作は実際のところ 一様計算可能 である; 例えば、チューリングマシンで入力が (A,B, ) で出力が r であるものがある。ここで Aa を、Bb を近似するチューリングマシンの記述で、ra+b  近似である。 この計算可能実数がをなすということはHenry Gordon Riceによって1954年に初めて証明された[4]。 計算可能実数全体は計算可能体はなしていない。計算可能体の定義には実効的な等価性が必要である。

整列の計算不可能性 編集

計算可能数上の順序関係は計算可能でない。A を近似するチューリングマシンの記述とする。このとき、任意に A を与えられて なら "YES"、 なら "NO" を返せるようなチューリングマシンは存在しない。なぜかというと、 近似として0を出力し続けるマシン A を考えてみると、a が正であることを強制する近似を出力することはないと判断するまでの時間が不明なものになっている。それゆえ、このマシンは出力を得るためには最終的には a が 0 に等しいことを推測して出力しなければならないが、実際はそれを決めた後のタイミングで a が 0 でないことを強制する近似が判明してしまう可能性がある。このアイデアは全域関数を計算するいくつかの数列についてマシンが不正確であることを示すのに用いられる。似た問題がデデキント切断によって計算可能数を表現する際に発生する。等式関係は計算不可能である。 完全な順序関係は計算不可能である一方、異なる数のペアに限定すれば大小関係は計算可能である。すなわち、次のようなプログラムは存在する。チューリングマシン A, B が実数  ,  ただし であるものを計算するものとしてそれが入力として与えられる、これに対して出力は  を与えるものである。これには、 である -近似を用いれば十分でこの は0にいくらでも近づけられる。 である以上は、最終的に  は必ず判断できる。

その他の性質 編集

計算可能実数の集まりは解析で使われる実数の性質を満たすとは限らない。例えば、計算可能実数からなる有界な増加列があってもその上限は計算可能実数であるとは限らない。[5] この性質を満たす数列はSpecker sequenceとして知られている。これはErnst Speckerによって1949年に構成された。[6] このような反例がある一方、実解析の一部は計算可能数の分野で発展し計算可能解析学の研究に繋がっている。

全ての計算可能数は算術的定義可能であるが逆は成り立たない。算術的定義可能であるが計算可能でない実数はたくさん存在する。例えば:

これらの例は実際のところ、定義可能かつ計算不能な数の無限集合を定義し、各万能チューリングマシンごとに一つずつ与える。 実数が計算可能であるとき、かつその時に限り、自然数の集合を特性関数として見なしたとき計算可能である。

計算可能実数全体は (およびそのうち可算な稠密順序で端点の無い部分集合は) 有理数全体と順序同型である。

数字列とカントール空間やベール空間 編集

チューリングは原論文で次のように計算可能数を定義している:

実数が計算可能であるとはその桁の並びがなんらかのアルゴリズムやチューリングマシンで生成できることをいう。そのアルゴリズムは整数 を入力として受け取り、その実数の十進表現の 桁目を出力とするものである。

(ここで a の十進展開と言ったとき、それは小数点以下の部分のみを指している。)

チューリングはこの定義が上でこれまで定義してきた -近似と同値であることに気づいていた。その議論は次のように進められる: ある数がチューリングの意味で計算可能であるときにはそれは、 近似の意味でも計算可能である: であるとき、a の最初の n 桁は a 近似を与えている。逆を示すには、 近似可能な a に対しては小数点以下 n 桁目が確定するまで近似精度を上げていけばよい。これは常に a の十進展開に等しい列を生成するが、この考え方だと不適切に9の無限列で終わる可能性がある。しかしその場合は有限の (したがって計算可能な) 適切な十進展開を持つことになるのでいずれにしても計算可能性が導かれる。 実数の位相的性質が関係しない限り、区間 の実数の代わりに の元 (0,1 の値を取る全域関数) を扱う方が便利なことがしばしばある。 の元は実数の二進展開と同一視することができる。ただし、   は同じ実数を表しており、区間  の元のうち1の列で終わらないもの全体と全単射で対応する(相対位相を考えれば同相にもなる)。 この小数展開の性質は計算可能な実数が十進展開で定義されたものであるか 近似で定義されたものであるかを実効的に区別することは不可能であることを意味している。ハーストは計算可能数 a  近似を生成するチューリングマシンの記述を入力として受け取り、そしてチューリングの意味における a の桁の並びを列挙するようなチューリングマシンを出力として生成するアルゴリズムは存在しないことを示した。[7] 同様に、計算可能実数上の算術操作は、十進数の足し算をするときのように、実効的ではないことを意味している。ある一桁を確定するために、繰上りが無いかどうかを予め分からない桁数分の右側を確認しに行かねばならない場合がある。この一様性の無さが現代的な計算可能数の定義で十進展開よりも  近似を用いる理由の一つである。 しかしながら、計算可能性理論測度論的観点から  という二つの構造は本質的に同一のものであり、計算可能性理論の分野ではしばしば の元を実数と呼んでいる。また 完全不連結であって、  のクラスやランダムネスの問題に関しては で考える方が考えやすい。  と同相な像を含む の元も実数と呼ばれることがある。 は完全不連結であることに加えて局所コンパクトですらない。このため、計算的性質に関する明確な違いが発生してくる。例えば、  を満たすものとしよう。ここで は量化子の無いものとする。このとき、これは計算可能でなければならないが、一方、universal formula を満たす一意的な hyperarithmetic hierarchyにおける任意の高さに位置することができる。

実数の代わりとして 編集

計算可能数の範囲には全ての代数的数eπ などの具体的な超越数など実用的な具体的実数が全て含まれている。計算可能実数というのは、計算したり近似したりできる実数全てを網羅したものであるが、考慮すべき実数が全て計算可能であると仮定すると実数に関する結論は大きく異なってくる。全ての数学に、実数全体でなく計算可能数のみを用いることができるのかという問いが自然に出てくる。この考えは構成主義の観点からも魅力的でエレット・ビショップ やフレッド・リッチマンが構成的数学の ロシア学派 と呼んで追究してきたものである。[要出典] 計算可能数上の解析学を実際に展開するためには、いくつかの注意が必要である。例えば、列の古典的な定義を用いる際、計算可能数の集合は有界列上限を取るという基本的な操作について閉じていない  (例えば、前述のSpecker sequenceなど)。この困難さについては計算可能な収束係数を持つ列のみを考慮することによって対処することができ。このようにして得られた理論は計算可能解析学と呼ばれている。

正確な算術の実装 編集

実数を、それ自身を近似計算するプログラムによって表現するコンピュータパッケージは "正確な算術" という名前で1985年に提唱されている[8]。 近年の例としては、 include the CoRN ライブラリ (Coq)[9] や RealLib パッケージ (C++) などがある[10]。 関連する話題としては iRRAM パッケージのように real RAM プログラムとそれを十分な精度の有理数や浮動小数点数で実行することも挙げられる[11]

関連項目 編集

脚注 編集

  1. ^ van der Hoeven (2006).
  2. ^ Turing (1936).
  3. ^ Minsky (1967).
  4. ^ Rice (1954).
  5. ^ Bridges & Richman (1987), p. 58.
  6. ^ Specker (1949).
  7. ^ Hirst (2007).
  8. ^ Boehm, Hans-J.; Cartwright, Robert; Riggle, Mark; O'Donnell, Michael J. (8 August 1986). “Exact real arithmetic: a case study in higher order programming”. Proceedings of the 1986 ACM conference on LISP and functional programming: 162–173. doi:10.1145/319838.319860. http://fricas-wiki.math.uni.wroc.pl/public/refs/exact-real-p162-boehm.pdf. 
  9. ^ O’Connor, Russell (2008). “Certified Exact Transcendental Real Number Computation in Coq”. Theorem Proving in Higher Order Logics: 246–261. doi:10.1007/978-3-540-71067-7_21. https://arxiv.org/pdf/0805.2438.pdf. 
  10. ^ Lambov (2015).
  11. ^ Gowland, Paul; Lester, David (2001). “A Survey of Exact Arithmetic Implementations” (英語). Computability and Complexity in Analysis (Springer): 30–47. doi:10.1007/3-540-45335-0_3. https://link.springer.com/content/pdf/10.1007%2F3-540-45335-0_3.pdf. 

参考文献 編集

Further reading 編集