NL (計算複雑性理論)
NL(えぬえる、英: Nondeterministic Logarithmic-space)は、計算複雑性理論における決定問題の複雑性クラスの一つである。非決定性チューリングマシンで対数規模の記憶領域を使って解ける問題がこのクラスに属する。
NL は Lを一般化したものである。L は決定性チューリングマシンでの対数領域問題のクラスである。決定性チューリングマシンは非決定性チューリングマシンに含まれるため、L も NL に含まれる。
NLは非決定性領域(NSPACE)の計算資源記法で形式的に定義でき、NL = NSPACE(log n) となる。
計算複雑性理論の研究により、このクラスと他の複雑性クラスの関係が明らかとなり、必要な計算資源も明らかとなってきた。一方、アルゴリズムの研究によって、対数領域で解ける問題も明らかとなってきつつある。しかし、計算複雑性理論の他の分野と同様、NLについての重要な部分は未解決である。
NLの確率的定義(後述)を指して RL と呼ぶこともある。しかし、RLという名称はRLPという複雑性クラスの別名として使われることが多い(RLPとは、確率的チューリングマシンで対数領域と多項式時間で解ける問題のクラス)。
NL完全問題
[編集]ある複雑性クラスに属する最も難しい問題を指して完全問題という。直観的には、完全問題を効率的に解く方法が判っていれば、それを使ってそのクラスのあらゆる問題を解くことが出来る。すなわち、完全問題はその複雑性クラスの能力の程度を示すものである。
NL完全であることが判っている問題はいくつかある。STCON問題(有向グラフの2点間の経路の有無を問う問題)と2元充足可能性問題はNL完全である。2元充足可能性問題とは、連言標準形の論理式の各節(論理和で表される部分)が2つの変数で構成されているとき、その論理式を真とする変数値の組み合わせが存在するかどうかを問う問題である。以下にそのような論理式の例を示す。なお、~(チルダ)は「否定」を意味する。
- (x1 or ~x3) and (~x2 or x3) and (~x1 or ~x2)
包含関係
[編集]NL は Pに含まれる。これは、2元充足可能性問題に多項式時間のアルゴリズムが存在していることから明らかである。しかし、NL = P かどうか、あるいは L = NL かどうかは未だわかっていない。非決定性領域は補集合演算について閉じているため、NL = co-NL であることが判っている。これは、Neil Immerman と Róbert Szelepcsényi が 1987年にそれぞれ独自に証明した。彼らはこの業績によって1995年のゲーデル賞を受賞している(PSPACEのようなより大きいクラスでは、サヴィッチの定理(1970年)によりPSPACE = NPSPACE、NPSPACE = co-NPSPACEであることが既に知られていた)。
回路計算量理論では、NL はNCの階層に置くことができる。Papadimitriou 1994, Theorem 16.1 によれば、次のようになる。
また、NL = RL であることも知られている。RLは確率的チューリングマシンで対数領域で解ける問題のクラスであり、3分の1未満の確率で間違ってNOと答える可能性のあるクラスである。また、ZPL とも同じであることが知られている。ZPL は乱択アルゴリズムで対数領域で解ける問題のクラスである(誤答はない)。しかし、RLPまたはZPLPとは異なると考えられている。これらは RL や ZPL を多項式時間に制限したもので、書籍によってはこれらを混同している場合もある。
サヴィッチの定理を使って NL を決定性領域に関連付けることもできる。つまり、非決定性アルゴリズムは、決定性機械で高々二乗の領域を使うことでシミュレートできる。サヴィッチの定理によれば、 となる( と同じことである)。この強力な原理は1994年に知られるようになった(Papadimtriou 1994 Problem 16.4.10, "Symmetric space")。
確率的定義
[編集]確率的チューリングマシン上で対数領域で解ける問題の複雑性クラスを C とする。C の回答がYESである場合は常に正しいが、回答がNOである場合は3分の1未満の確率で間違った回答だとする。3分の1という定数は、0 ≤ x < 1/2 となる任意の x であればよい。
このようなクラスは NL と同じである。C は時間が多項式時間に制限されていない。なぜなら、対数領域の状態の組み合わせがたかだか多項式で表せるほどしかないとしても、確率的な解法であるために無限ループに陥る可能性があるからである。これを多項式時間に制限すると RLP という別のクラスになる。
C = NL であることを示す。まず C が NL に含まれることを簡単に示すアルゴリズムが存在する。
- ある文字列がある言語に含まれない場合、C も NL も全計算経路でこれらを拒否(reject)する。
- 文字列が言語に含まれる場合、NLのアルゴリズムはそれを少なくとも1つの計算経路で受容(accept)し、C のアルゴリズムは少なくとも3分の2の計算経路で受容する。
NL が C に含まれることを示すため、一つの NLアルゴリズムで長さ n の計算経路を無作為に選び、これを 2n 回行う。計算経路は長さ n を超えず、全体として 2n 個の計算経路があるため、一定確率以上で受容状態となる可能性がある。
問題は、最大値が 2n となるカウンタを保持する領域が対数領域にないことである(O(n)になる)。これに対処するため、カウンタをランダムカウンタとし、単純に n 個のコインを投げて全部のコインが表なら停止または拒否するものとする。この事象の確率は 2-n なので、停止するまでの平均ステップ数の期待値は 2n となる。この場合に必要な領域は対数領域に収まる(表になるコインを数えるだけなら O(log n) に収まる)。
以上から、領域だけに着目すれば、確率的なアルゴリズムも非決定性のアルゴリズムも同じ能力を持つことがわかる。
記述計算量
[編集]NLの簡単な論理的定義として、推移閉包演算子を付与した一階述語論理で表される言語がNLに含まれる。
参考文献
[編集]- Papadimitriou, C. (1994年). “Chapter 16: Logarithmic Space”. Computational Complexity. Addison-Wesley. ISBN 0-201-53082-1
- Michael Sipser (1997年). “Sections 8.4–8.6: The Classes L and NL, NL-completeness, NL equals coNL”. Introduction to the Theory of Computation. PWS Publishing. pp. pp. 294–302. ISBN 0-534-94728-X
- Introduction to Complexity Theory: Lecture 7. Oded Goldreich. Proposition 6.1. 本文で C と称していたものは、この文書では badRSPACE(log n) となっている。