導出原理(どうしゅつげんり、英: resolution principle)とは、ジョン・アラン・ロビンソン(英語版)により1965年に提案された[1]原理または手法を言う。
導出原理を元とする導出の手法は、その後の定理自動証明に大きな影響を与え、またPrologなどの論理プログラミング言語の基礎となった。
述語論理式 P が恒真であるかを証明する一般的な手続きは存在しないが、1930年に発表されたエルブランの定理はエルブラン領域の要素を論理式に代入して命題論理のレベルに落としその充足不能性を調べることで、¬P が充足不能(恒偽)であれば有限のステップで証明できることを保証している。また、エルブランの論文には単一化アルゴリズムなど他の様々なものが含まれていた[2]。
1950年代以降、計算機上での定理証明の研究が活発になり、ギルモアのアルゴリズム(1960)やデービス・パトナムのアルゴリズム(1958,1960) が考案された。デービス・パトナムのアルゴリズムには連言標準形の使用や導出規則の考え方が含まれていた。しかし、これらはエルブランの定理の証明を直接計算機上で実現したような方法で、エルブラン領域の要素を順次生成して変数を含まない論理式(基礎例)を作成し命題論理のレベルで充足不能性を調べるものだったため、不要な論理式が多数生成され、非常に効率が悪かった[3]。
プラウィツ(Dag Prawitz)は、論理式を生成してからチェックするのではなく、選言標準形に変換した論理式への適当な代入(単一化)によって充足不能性を調べる方法を1960年に提案した[4]。
この方法は必要な基礎例のみを生成するため、不要な論理式の生成が抑えられ効率的だったが、選言標準形は全ての連言項を調べなければならないため全体の効率はいいとは言えなかった。
ロビンソンはデービス・パトナムの枠組みにプラウィツのアイデアを組み合わせ、ただ1つの導出規則と単一化による代入操作とで充足不能性を調べる導出原理を1965年に発表した。単純な規則で関係する論理式のみを段階的に具体化していく方法は、従来の方法よりはるかに効率がよく、また理論的なエレガントさを持っていたため、その後の定理自動証明に大きな影響を与えた[3]。
導出とは二つの節より新しい節を導き出す操作で、一方の節に含まれるリテラル
と、他方の節に含まれる否定リテラル
をのぞき、その他のリテラルの論理和をとることで、新しい節を得ることをいう。
命題論理での導出規則を式で表せば、
と書ける。ここで上式は前提となる親節、下式はそれらから導かれる導出節(resolvent)を表す。
あるいは、別の表記法を用いて次のようにも表現できる。前提となる節を
と
とし, もしリテラル
と否定リテラル
が存在するならば、導出節
は以下のようになる。
![{\displaystyle C_{R}=(C_{1}\setminus \{L\})\cup (C_{2}\setminus \{{\overline {L}}\})}](https://wikimedia.org/api/rest_v1/media/math/render/svg/6962089a62673ee5348bd8998a3642ae43593b50)
導出規則は三段論法や前件肯定を一般化した規則となっている。
導出は完全な証明系であることが知られている。
を節形式にすると
となる。
を
の導出節とすると、前件肯定は以下の導出と同じである。
![{\displaystyle {\begin{array}{ll}C_{1}=\lnot p\lor q&\left(p\to q\right)\\C_{2}=p\\C_{R}=q&\left(\mathrm {resolvent} \right)\end{array}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/efc9c9e288ad65711c690f7bd567ecf0c357f50e)
同様に、
、
の節形式
、
による三段論法は以下のようになる。
![{\displaystyle {\begin{array}{ll}C_{1}=\lnot p\lor q&\left(p\to q\right)\\C_{2}=\lnot q\lor r&\left(q\to r\right)\\C_{R}=\lnot p\lor r&\left(\mathrm {resolvent,\ } p\to r\right)\end{array}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/31649b91d10de4b4b5f2d285c1e2c2c0aaa7627d)
述語論理のリテラルには個体変数が含まれるため、リテラルと否定リテラルとを単純に比較するだけでは削除できるかどうか分からない。一階述語論理ではリテラルと否定リテラルそれぞれの原子論理式が単一化できる場合に導出を行う。
また、導出の対象となる節は、冠頭標準形にして存在記号を削除したスコーレム連言標準形の論理式である。
例えば、一方の節がリテラル
、もう一方の節がリテラル
を含む場合、適切な代入
により各リテラルは
、
と書き換えられ、同じにすることができる。ここで代入
は
、
に書き換えることを表す。
一般に論理式
を等しくする代入を
の単一化子(unifier)といい、そのうち最も一般的な単一化子(最汎単一化子)を
のmgu(most general unifier)という。上記の例の場合、両方の論理式を等しくする代入は
、
など無数に存在する。これらは本来の代入
に
などの代入を合成したものなので、最汎単一化子 mgu は
である。
一階述語論理での導出は mgu を用いて次のように表現できる。
もしリテラル
と否定リテラル
が存在し、
と
が mgu
を持つ場合、以下の
が2項導出節(binary resolvent)である。ここで、
などは、それぞれの節やリテラルに代入
を行ったものを表す。
![{\displaystyle C_{R}=(C_{1}\sigma \setminus \{L_{1}\sigma \})\cup (C_{2}\sigma \setminus \{{\overline {L_{2}\sigma }}\})}](https://wikimedia.org/api/rest_v1/media/math/render/svg/71ee521eedcc0bd0aa24b65deb934faa30ca3855)
同様のやり方での2以上の複数の節から同時に導出することも可能であり、超導出(hyper-resolution)と呼ばれる。
以下の節からの導出を考える。
![{\displaystyle C_{1}=\lnot P(x)\lor \lnot Q(y)\lor R(x,y)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/6501d33501174f804e07cd9c71da512e75d33366)
![{\displaystyle C_{2}=Q\left(a\right)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/3abd9480c08a6f0238b796b3b8cb567d0b8615fc)
![{\displaystyle C_{3}=P\left(b\right)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/6cbe1696fa00f3eb1a4d3db6a88b7a2934801242)
Q を単一化する代入
により
と
の導出を行うと、
![{\displaystyle C_{R}=\lnot P(x)\lor R(x,a)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/edb0c8c3e2f5a9fb3e008d1a0a4b4c6f8b35e4d1)
続いて、P を単一化する代入
により
と
の導出を行うと、
![{\displaystyle C_{S}=R\left(b,a\right)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/47ed7ee58a0deeef42abee4f7929ef2df8934cb3)
を得ることができる。
反駁(はんばく、英: refutation)とは、節の集合からの導出により空節 □ を導くことである。
反駁については以下の定理が成り立つ。
節の集合 S が充足不能である必要十分条件は、節の集合 S からの導出により空節 □ が導けることである。
これはエルブランの定理を導出に応用したものになっている。
論理式 P が恒真であれば
は充足不能(恒偽)であるため、節の集合に
を追加し導出を繰り返すことで空節 □ になれば、論理式 P が恒真であることが証明できる。
反駁により
が
の論理的帰結か調べるアルゴリズムは以下のように表現できる。
をスコーレム連言標準形
に変換する。
をスコーレム連言標準形
に変換する。
- もし
の反駁が存在すれば、
は
の論理的帰結である。
- あるいは、別の表現をすれば、
が充足不能
が充足不能
の解釈が
ならば
の解釈は ![{\displaystyle {\mathit {F}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/d9a3fee67b66a9202b9d1ea2037d5e69fc6b8074)
の解釈が
ならば
の解釈は ![{\displaystyle {\mathit {T}}}](https://wikimedia.org/api/rest_v1/media/math/render/svg/a137981d17306dd1514f144fd838043daf8fdf9f)
以下の公式が成り立つ時、
が成り立つかどうかを証明する場合を考える。反駁の対象となる論理式は以下の論理式に
を追加したものである。
,
,
![{\displaystyle \lnot R(a)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/61952ff8687abdb84663066501c850f2fbe59b0c)
最初の論理式は
と等価なため、次の2つの節で表現できる。
![{\displaystyle C_{1}=\lnot S(x)\lor P(x)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/aa5e8d89ea8f62b61b48292f430eef176f75dfda)
![{\displaystyle C_{2}=\lnot T(x)\lor P(x)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/608b7c9e76ea745201a87a7c814700b13c397693)
2番目の論理式は以下の節になる。
![{\displaystyle C_{3}=S(x)\lor R(x)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/bd44e7137b7dd1d369ca2c9ed5a869047131e398)
さらに3番目は以下の節になる。
![{\displaystyle C_{4}=\lnot R(a)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/467aa65f4f422101f0de6f9d09161780e6698c37)
証明したい論理式の否定は以下の節である。
![{\displaystyle C_{5}=\lnot P(a)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/16c136a36b4766e2bb8b607e5234870241a59753)
これらの節
が反駁の対象となる節集合である。
と
の
についての導出を考えると、
の代入により以下が導かれる。
![{\displaystyle C_{6}=S\left(a\right)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/6b5c7560f276883b87d8acdc41c41f375b341c30)
と
の
についての導出を考えると、
![{\displaystyle C_{7}=P\left(a\right)}](https://wikimedia.org/api/rest_v1/media/math/render/svg/2e9ded5b0d2bb4fe36f8e26ecc230c59133accc7)
最後に
と
の導出により空節 □ が導かれ、
が成り立つことを証明できる。
導出は2つの節を前提として導出節を導くものであるので、どの節に導出規則を適用するかについては様々な選択肢があり、そのやり方により効率が大幅に異なる。代表的な証明戦略として以下のものがある。
- 前提となる節の一方を、頂上節(top clause)として指定した節と、頂上節から導出された節に限定する方法。導出木を書くと導出の流れが線状に一列に並ぶため、線形導出と呼ばれる。論理プログラミング言語の代表であるPrologで用いられるSLD導出(Selective Linear resolution for Definite clause)は線形導出の一種である。
- 前提となる節の一方を最初に与えられた節集合の要素(導出された節以外の節)に限定する方法。
- 支持集合戦略(set-of-support strategy)
- あらかじめ支持集合という節の集合を指定しておき、前提となる節の一方を支持集合の節とそこから導出された節に限定する方法。節集合S、T がありS-T が充足可能であるときT はS の支持集合と言う。目標に関係ないところを探索しないよう導出の対象を制限することで、より効率的な導出を行うための手法で、1965年に Lawrence Wos らが提案した[5]。
- 意味導出(semantic resolution)
- 論理式のモデルあるいは解釈を利用して導出の対象を制限し、探索の空間を狭めることで効率的な導出を行う手法。特定のモデルにおいて真となる可能性がある節と偽となる可能性のある節とを親節に選ぶ Slagle の Semantic Clash resolution[6] など様々な方法がある。
- ^ J. Alan Robinson, A Machine-Oriented Logic Based on the Resolution Principle. JACM, Volume 12, Issue 1, pp. 23–41. 1965.
- ^ Buss, Samuel R., "On Herbrand's Theorem", in Maurice, Daniel; Leivant, Raphaël, Logic and Computational Complexity, Lecture Notes in Computer Science, Springer-Verlag, pp. 195–209. 1995.
- ^ a b Martin Davis. The Early History of Automated Deduction. in Handbook of Automated Reasoning, Volume I, Alan J.A. Robinson and Andrei Voronkov(ed), 2001. ISBN 9780444829498
- ^ Wolfgang Bibel. Early History and Perspectives of Automated Deduction. in Advances in Artificial Intelligence, Lecture Notes in Computer Science, Springer-Verlag Berlin, 2007. ISBN 9783540745648
- ^
Lawrence Wos, G.A. Robinson, D.F. Carson. Efficiency and Completeness of the Set of Support Strategy in Theorem Proving. Journal of the ACM, Volume12, Issue 4, pp.536-541. 1965.
- ^
James Slagle. Automatic Theorem Proving With Renamable and Semantic Resolution. Journal of the ACM, Volume14, Issue 4, pp.687-697. 1967.
- 長尾 真、淵 一博『論理と意味』 7巻、岩波書店〈岩波講座 情報科学〉、1983年。
- 山崎 進『計算論理に基づく推論ソフトウェア論』コロナ社、2000年。
- D.ヒルベルト、W.アッケルマン 著、伊藤誠(訳) 編『記号論理学の基礎』大阪教育図書社、1954年。
- Robert Kowalski (1974), Predicate Logic as Programming Language, http://www.doc.ic.ac.uk/~rak/papers/IFIP%2074.pdf
- Wolfgang Bibel (2007), “Early History and Perspectives of Automated Deduction”, Advances in Artificial Intelligence, Lecture Notes in Computer Science, Springer-Verlag Berlin, ISBN 9783540745648, http://www.intellektik.de/resources/OsnabrueckBuchfassung.pdf
- J. Alan Robinson. "A Machine-Oriented Logic Based on the Resolution Principle." J. Assoc. Comput. Mach. 12, pp.23-41, 1965.
- Davis Martin. The Early History of Automated Deduction. in Handbook of Automated Reasoning, Volume I, Alan Robinson and Andrei Voronkov(ed), 2001. ISBN 9780444829498.
- Robert Kowalski. Logic for Problem Solving. North Holland, Elsevier, 1979. ISBN 978-0444003683
- Gallier, Jean H. (1986). Logic for Computer Science: Foundations of Automatic Theorem Proving. Harper & Row Publishers. http://www.cis.upenn.edu/~jean/gbooks/logic.html
- 佐藤 泰介. 導出原理による定理証明. 情報処理 22(11), pp.1024-1036, 1981.