人工智能导论——谓词公式化为子句集详细步骤

简介: 在谓词逻辑中,有下述定义:原子(atom)谓词公式是一个不能再分解的命题。原子谓词公式及其否定,统称为文字(literal)。$P$称为正文字,$\neg P$称为负文字。$P$与$\neg P$为互补文字。<font color="ddd0000">任何文字的析取式称为子句(clause)。任何文字本身也是子句。</font>由子句构成的集合称为子句集。不包含任何文字的子句称为空子句,表示为NIL。<font color="ddd0000">由于空子句不含有文字,它不能被任何解释满足,所以,空子句是永假的、不可满足的。</font>在谓词逻辑中,任何一个谓词公式都可以通过应用等

在谓词逻辑中,有下述定义:
原子(atom)谓词公式是一个不能再分解的命题。
原子谓词公式及其否定,统称为文字(literal)。$P$称为正文字,$\neg P$称为负文字。$P$与$\neg P$为互补文字。
任何文字的析取式称为子句(clause)。任何文字本身也是子句。
由子句构成的集合称为子句集。
不包含任何文字的子句称为空子句,表示为NIL。
由于空子句不含有文字,它不能被任何解释满足,所以,空子句是永假的、不可满足的。
在谓词逻辑中,任何一个谓词公式都可以通过应用等价关系及推理规则化成相应的子句集,从而能够比较容易地判定谓词公式的不可满足性。下面结合一个具体的例子,说明把谓词公式化为子句集的步骤。
[例] 将下列谓词公式化为子句集:

$$ \mathbf{(\forall x)\{(\forall y)P(x,y) \rightarrow \neg(\forall y)[Q(x,y) \rightarrow R(x,y)]\}} $$

(1) 消去谓词公式中的$“\rightarrow”$和$“\leftrightarrow”$
利用谓词公式的等价关系:

$$ \mathbf{P \rightarrow Q \Longleftrightarrow \neg P \lor Q} \\ \mathbf{P\longleftrightarrow Q \Longleftrightarrow(P \lor Q) \lor (\neg P \lor \neg Q)} $$

上列等式等价变化为:

$$ \mathbf{(\forall x)\{\neg (\forall y)P(x,y)\lor \neg(\forall y)[\neg Q(x,y)\lor R(x,y)]\}} $$

(2)把否定符号移到紧靠谓词的位置上
利用谓词公式的等价关系:
双重否定律: $\mathbf{\neg(\neg P)\Longleftrightarrow P}$
德摩根律: $\mathbf{\neg(P \land Q)\Longleftrightarrow \neg P \lor \neg Q}$
        $\mathbf{\neg(P \lor Q)\Longleftrightarrow \neg P \land \neg Q}$
量词转换律:$\mathbf{\neg(\forall x)P \Longleftrightarrow(\exists x)\neg P}$
          $\mathbf{\neg(\exists x)P \Longleftrightarrow(\forall x)\neg P}$
把否定符号移到紧靠谓词的位置上,减少了否定符号的辖域。
上列等式变换为:
$$\mathbf{(\forall x)\{(\exists y)\neg P(x,y)\lor(\exists y)[Q(x,y)\land \neg R(x,y)]\}}$$
(3)变量标准化
所谓变量标准化就是重新命名变元,使每个量词采用不同的变元,从而使不同量词的约束变元有不同的名字。这是因为在任一量词辖域内,受到该量词约束的变元为一哑元(虚构变量),它可以在该辖域内被另一个没有出现过的任意变元统一代替,而不改变谓词公式的值。

$$ \mathbf{(\forall x)P(x)\equiv (\forall y)P(y)}\\ \mathbf{(\exists x)P(x)\equiv (\exists y)P(y)} $$

上面等价变换为:

$$ \mathbf{(\forall x)\{(\exists y)\neg P(x,y)\lor(\exists z)[Q(x,z)\land \neg R(x,z)]\}} $$

(4)消去存在量词
分两种情况:
一种情况是存在量词不出现在全称量词的辖域内。此时只要用一个新的个体常量替换受该存在量词约束的变元,就可以消去存在量词。因为如原谓词公式为真,则总能找到一个个体常量,替换后仍然使谓词公式为真。这里的个体常量就是不含变量的$Skolem$函数。
例如:$\mathbf{(\exists x)(\forall y)[(\exists x) \neg p(x,z) \lor R(x,y,f(a))]}$
消去存在量词后变为:
$\mathbf{(\forall y)[\neg p(b,g(y))\lor R(b,y,f(a))]}$
另一种情况是存在量词出现在一个或者多个全称量词的辖域内。此时要用$Skolem$函数替换受该存在量词约束的变元,从而消去存在量词。这里认为所存在的y依赖于x值,它们的依赖关系由Skolem函数所定义。
对于一般情况:

$$ \mathbf{(\forall x_1)(\forall x_2)...(\forall x_n)(\exists y)P(x_1,x_2,...,x_n, y)} $$

存在量词$y$的$Skolem$函数记为:

$$ \mathbf{y=f(x_1,x_2,...,x_n)} $$

可见,$Skolem$函数把每个$x_1,x_2,...,x_n$值,映射到存在的那个$y$。
用$Skolem$函数代替每个存在量词量化的变量的过程称为$Skolem$化。$Skolem$函数所使用的函数符号必须是新的。
对于上面的例子,存在量词$(\exists y)$及$(\exists z)$都位于全称量词$(\forall x)$的辖域内,所以都需要用$Skolem$函数代替。设$y$和$z$的$Skolem$函数分别记为$f(x)$和$g(x)$,则替换后得到

$$ \mathbf{(\forall x)\{\neg P(x, f(x))\lor[Q(x, g(x))\land \neg R(x, g(x))]\}} $$

(5)化为前束形
所谓前束形,就是把所有的全称量词都移到公式的前面,使每个量词的辖域都包括公式后的整个部分,即:

$$ \pmb{前束形=(前缀)\{母式\}} $$

其中,(前缀)是全称量词串,{母式}是不含量词的谓词公式。
对上面的例子,因为只有一个全称量词,而且已经位于公式的最左边,所以,这一步不需要做任何工作。
(6)化为$Skolem$标准形
$Skolem$标准形的一般形式是:

$$ \mathbf{(\forall x_1)(\forall x_2)...(\forall x_n)M} $$

其中,$M$是子句的合取式,称为$Skolem$标准形的母式。
一般利用:

$$ \mathbf{P \lor(Q\land R) \Leftrightarrow(P\lor Q)\land (P\lor R)}\\ \mathbf{P \land(Q\lor R) \Leftrightarrow(P\land Q)\lor (P\land R)} $$

把谓词公式化为$Skolem$标准形。
对于上面的例子,有

$$ \mathbf{(\forall x)\{[\neg P(x, f(x))\lor Q(x, g(x))]\land[\neg P(x,f(x))\lor \neg R(x,g(x))]\}} $$

(7)略去全称量词
由于公式中所有变量都是全称量词量化的变量,因此,可以省略全称量词。母式中的变量仍然认为是全称量词量化的变量。
对于上面的例子,有:

$$ \mathbf{[\neg P(x, f(x))\lor Q(x, g(x))]\land [\neg P(x, f(x))\lor \neg R(x, g(x))]} $$

(8)消去合取词,把母式用子句集表示
对于上面的例子,有:

$$ \mathbf{\{\neg P(x, f(x))\lor Q(x, g(x)), \neg P(x, f(x))\lor \neg R(x, g(x)) \}} $$

(9)子句变量标准化,即使每个子句中的变量符号不同
谓词公式的性质有:

$$ \mathbf{(\forall x)[P(x)\land Q(x)]\equiv (\forall x)P(x)\land(\forall y)Q(y)} $$

对于上面的例子,有:

$$ \mathbf{\{\neg P(x, f(x))\lor Q(x, g(x)), \neg P(y, f(y))\lor \neg R(y, g(y)) \}} $$

显然,在子句集中各子句之间是合取关系。
下面举个课本上的例子熟练下:
在这里插入图片描述

相关文章
|
8月前
|
机器学习/深度学习 人工智能 运维
【人工智能技术专题】「入门到精通系列教程」打好AI基础带你进军人工智能领域的全流程技术体系(机器学习知识导论)(二)
【人工智能技术专题】「入门到精通系列教程」打好AI基础带你进军人工智能领域的全流程技术体系(机器学习知识导论)
317 1
|
8月前
|
机器学习/深度学习 人工智能 自然语言处理
【人工智能技术专题】「入门到精通系列教程」打好AI基础带你进军人工智能领域的全流程技术体系(机器学习知识导论)(一)
【人工智能技术专题】「入门到精通系列教程」打好AI基础带你进军人工智能领域的全流程技术体系(机器学习知识导论)
391 1
|
5月前
|
机器学习/深度学习 人工智能 算法
【人工智能】机器学习、分类问题和逻辑回归的基本概念、步骤、特点以及多分类问题的处理方法
机器学习是人工智能的一个核心分支,它专注于开发算法,使计算机系统能够自动地从数据中学习并改进其性能,而无需进行明确的编程。这些算法能够识别数据中的模式,并利用这些模式来做出预测或决策。机器学习的主要应用领域包括自然语言处理、计算机视觉、推荐系统、金融预测、医疗诊断等。
90 1
|
6月前
|
机器学习/深度学习 消息中间件 人工智能
人工智能平台PAI使用问题之EasyRec训练的步骤是怎样的
阿里云人工智能平台PAI是一个功能强大、易于使用的AI开发平台,旨在降低AI开发门槛,加速创新,助力企业和开发者高效构建、部署和管理人工智能应用。其中包含了一系列相互协同的产品与服务,共同构成一个完整的人工智能开发与应用生态系统。以下是对PAI产品使用合集的概述,涵盖数据处理、模型开发、训练加速、模型部署及管理等多个环节。
|
7月前
|
机器学习/深度学习 数据采集 人工智能
人工智能:构建自定义机器学习模型的步骤与技巧
【6月更文挑战第25天】构建自定义机器学习模型涉及明确问题、数据收集预处理、特征工程、模型选择训练、评估优化及部署监控。关键技巧包括选择适配的算法、重视数据预处理、精巧的特征工程、有效评估优化和适时的模型更新。通过这些步骤和技巧,可提升模型性能与泛化能力。
|
8月前
|
人工智能 弹性计算 监控
在阿里云服务器上搭建自己的人工智能,可以按照以下步骤进行:
【2月更文挑战第22天】在阿里云服务器上搭建自己的人工智能,可以按照以下步骤进行:
658 6
|
机器学习/深度学习 人工智能 算法
《人工智能导论》期末项目
《人工智能导论》期末项目
228 3
|
存储 人工智能 安全
成为一家支持人工智能的企业的七个步骤
成为一家支持人工智能的企业的七个步骤
237 0
成为一家支持人工智能的企业的七个步骤
|
人工智能
人工智能导论 (五) - 搜索求解策略(下)
人工智能导论 (五) - 搜索求解策略
142 0
人工智能导论 (五) - 搜索求解策略(下)
|
人工智能
人工智能导论 (五) - 搜索求解策略(中)
人工智能导论 (五) - 搜索求解策略
138 0
人工智能导论 (五) - 搜索求解策略(中)