本文主要是介绍(《机器学习》完整版系列)第15章 规则学习——15.3 归结与逆归结(你可知“反证法”原理?),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
归结原理(即消解):可以“消除”该互补项
归结与逆归结
上篇我们用“十一条规则”形成一套命题逻辑的形式推理体系,归结原理强大到只需一个规则就可形成一套命题逻辑的形式推理体系。
若互补项(即正文字 L L L与负文字 ¬ L \lnot L ¬L)分别在两子句 C 1 C_1 C1与 C 2 C_2 C2中,则可以“消除”该互补项,称为归结原理(即消解),如图15.1 所示。
C = C 1 ⋅ C 2 \begin{align} C=C_1\cdot C_2 \tag{15.9} \end{align} C=C1⋅C2(15.9)
称 C C C为 C 1 C_1 C1与 C 2 C_2 C2的消解式,简记为
不可满足指恒假,参见后续的(15.6 一阶逻辑公式及“分拆”),常用结论:空子句是不可满足的、含有空子句的子句集是不可满足的。
归结原理有一个重要的推论:设 C 1 C_1 C1与 C 2 C_2 C2是子句集 S S S中的子句,如果把它俩的消解式 C C C加入到子句集 S S S中,得到子句集 S ′ S' S′,则子句集 S S S与 S ′ S' S′的可满足性相同,即
“ S 是不可满足的”等价于“ S ′ 是不可满足的” \begin{align} \text{“$S$是不可满足的”等价于“$S'$是不可满足的”} \tag{15.10} \end{align} “S是不可满足的”等价于“S′是不可满足的”(15.10)
由此,通常将要证“ S S S是不可满足的”转化为证“ S ′ S' S′是不可满足的”。
归结原理式(15.9)的逆运算(逆归结)简记为
{ C 1 = C / C 2 C 2 = C / C 1 \begin{align} \begin{cases} C_1=C / C_2 \\ C_2=C / C_1 \\ \end{cases} \tag{15.11} \end{align} {C1=C/C2C2=C/C1(15.11)
式(15.9)、式(15.11)为图15.1 的简记, C , C 1 , C 2 C,C_1,C_2 C,C1,C2三者中,已知二者可求另一个。
若已知 C , C 1 C,C_1 C,C1,如何“逆归结”出 C 2 C_2 C2?
我们先将式(15.9)用集合论变形
C = A ∨ B = ( C 1 − { L } ) ∨ ( C 2 − { ¬ L } ) \begin{align} C & =A\lor B \notag \\ & =(C_1-\{L \})\lor (C_2-\{\lnot L \}) \tag{15.12} \end{align} C=A∨B=(C1−{L})∨(C2−{¬L})(15.12)
通过“移项”得
C − ( C 1 − { L } ) = C 2 − { ¬ L } C 2 = ( C − ( C 1 − { L } ) ) ∨ { ¬ L } \begin{align} & C-(C_1-\{L \})= C_2-\{\lnot L \}\notag \\ & C_2=(C-(C_1-\{L \}))\lor \{\lnot L \} \tag{15.13} \end{align} C−(C1−{L})=C2−{¬L}C2=(C−(C1−{L}))∨{¬L}(15.13)
式(15.13)这即【西瓜书式(15.9)】,从中可知,选取不同的 L L L,则得到不同的 C 2 C_2 C2,即 C 2 C_2 C2不唯一(未给定 L L L时)。
设 Σ \Sigma Σ为子句集(多条件), p p p为子句(结论),定理(蕴涵符“ ⊨ \vDash ⊨”参见后续15.8 三种蕴涵) :
Σ ⊨ p 当且仅当: ( p ∨ ¬ Σ ) = T r u e 当且仅当: Σ ∧ ( ¬ p ) 不可满足(即总不成立) \begin{align} \Sigma \vDash p \qquad & \text{当且仅当:} (p\lor \lnot \Sigma)=\mathrm{True}\tag{15.14} \\ & \text{当且仅当:} \Sigma \land (\lnot p)\text{不可满足(即总不成立)} \tag{15.15} \end{align} Σ⊨p当且仅当:(p∨¬Σ)=True当且仅当:Σ∧(¬p)不可满足(即总不成立)(15.14)(15.15)
其中,式(15.15)即是“反证法”原理,结合式(15.10)得到利用归结进行“反证法”的步骤(参见后续15.11 基于逆归结的机器证明给出了示例):
(1)设条件集(子句集)为 Σ \Sigma Σ,将结论的反面 ¬ p \lnot p ¬p加入到 Σ \Sigma Σ中;
(2)在 Σ \Sigma Σ集中反复归结,结果仍然放到 Σ \Sigma Σ中;
(3)直到归结出一个空子句,即推导出了矛盾(空子句不可满足)。
(i) 证 Σ ⊨ p ⇒ p ∨ ¬ Σ \Sigma \vDash p \Rightarrow p\lor \lnot \Sigma Σ⊨p⇒p∨¬Σ:
若 Σ ⊨ p \Sigma \vDash p Σ⊨p,则表明(逻辑代数(布尔代数)中,1表示True;0表示False,通常通过对变量进行赋值来检验式子是否可满足):若 Σ = 1 \Sigma =1 Σ=1,则 p = 1 p=1 p=1
即: 若 ¬ Σ = 0 \lnot \Sigma =0 ¬Σ=0,则 p = 1 p=1 p=1
即有: p ∨ ¬ Σ = 1 p\lor \lnot \Sigma =1 p∨¬Σ=1
(ii) 证 Σ ⊨ p ⇐ p ∨ ¬ Σ \Sigma \vDash p \Leftarrow p\lor \lnot \Sigma Σ⊨p⇐p∨¬Σ:
若 Σ = 1 \Sigma=1 Σ=1,则 ¬ Σ = 0 \lnot \Sigma =0 ¬Σ=0
设 p ∨ ¬ Σ = 1 p\lor \lnot \Sigma =1 p∨¬Σ=1,则 p ∨ 0 = 1 p\lor 0=1 p∨0=1,即 p = 1 p=1 p=1
上述由 Σ = 1 \Sigma =1 Σ=1推出 p = 1 p=1 p=1,即说明在此条件下 Σ ⊨ p \Sigma \vDash p Σ⊨p。
受式(15.11)分数表达的启发,我们将图15.1 表达成“分数”,形成逆归结如图15.2 所示。
在上述归结的理论下,我们可以考虑命题逻辑的两个特殊子集:(1)限定子句:子句中只有一个正文字(其余为负文字);(2)霍尔子句:子句中至多只有一个正文字(其余为负文字),这两种特性在归结下保持不变,如,一对限定子句(各有一个正文字),若能利用归结原理抵消一对正、负文字后,得到一个新的子句还是只有一个正文字。 在这两种特殊的范围内,可以得到较简单的、机器易于实现的推理系统,这里不作讨论。
本文为原创,您可以:
- 点赞(支持博主)
- 收藏(待以后看)
- 转发(他考研或学习,正需要)
- 评论(或讨论)
- 引用(支持原创)
- 不侵权
上一篇:15.2 形式推理(哥德尔怎么说?)
下一篇:15.4 序贯覆盖(规则集与数据集)
这篇关于(《机器学习》完整版系列)第15章 规则学习——15.3 归结与逆归结(你可知“反证法”原理?)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!