(《机器学习》完整版系列)第15章 规则学习——15.3 归结与逆归结(你可知“反证法”原理?)

本文主要是介绍(《机器学习》完整版系列)第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=C1C2(15.9)
C C C C 1 C_1 C1 C 2 C_2 C2的消解式,简记为
图15.1 归结原理

图15.1 归结原理

不可满足指恒假,参见后续的(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=AB=(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 Σpp¬Σ

Σ ⊨ 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 Σpp¬Σ

Σ = 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 p0=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 所示。
图15.2 逆归结

图15.2 逆归结

在上述归结的理论下,我们可以考虑命题逻辑的两个特殊子集:(1)限定子句:子句中只有一个正文字(其余为负文字);(2)霍尔子句:子句中至多只有一个正文字(其余为负文字),这两种特性在归结下保持不变,如,一对限定子句(各有一个正文字),若能利用归结原理抵消一对正、负文字后,得到一个新的子句还是只有一个正文字。 在这两种特殊的范围内,可以得到较简单的、机器易于实现的推理系统,这里不作讨论。

本文为原创,您可以:

  • 点赞(支持博主)
  • 收藏(待以后看)
  • 转发(他考研或学习,正需要)
  • 评论(或讨论)
  • 引用(支持原创)
  • 不侵权

上一篇:15.2 形式推理(哥德尔怎么说?)
下一篇:15.4 序贯覆盖(规则集与数据集)

这篇关于(《机器学习》完整版系列)第15章 规则学习——15.3 归结与逆归结(你可知“反证法”原理?)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/680748

相关文章

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

Java Stream的distinct去重原理分析

《JavaStream的distinct去重原理分析》Javastream中的distinct方法用于去除流中的重复元素,它返回一个包含过滤后唯一元素的新流,该方法会根据元素的hashcode和eq... 目录一、distinct 的基础用法与核心特性二、distinct 的底层实现原理1. 顺序流中的去重

Spring @Scheduled注解及工作原理

《Spring@Scheduled注解及工作原理》Spring的@Scheduled注解用于标记定时任务,无需额外库,需配置@EnableScheduling,设置fixedRate、fixedDe... 目录1.@Scheduled注解定义2.配置 @Scheduled2.1 开启定时任务支持2.2 创建

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别