【人工智能 | 知识表示】问题规约法 谓词/符号逻辑,良好的知识表示是解题的关键!(笔记总结系列)

在这里插入图片描述

🤵‍♂️ 个人主页: @AI_magician
📡主页地址: 作者简介:CSDN内容合伙人,全栈领域优质创作者。
👨‍💻景愿:旨在于能和更多的热爱计算机的伙伴一起成长!!🐱‍🏍

在这里插入图片描述

【深度学习 | 核心概念】那些深度学习路上必经的核心概念,确定不来看看? (一)
作者: 计算机魔术师
版本: 1.0 ( 2023.8.27 )

摘要: 本系列旨在普及那些深度学习路上必经的核心概念,文章内容都是博主用心学习收集所写,欢迎大家三联支持!本系列会一直更新,核心概念系列会一直更新!欢迎大家订阅

该文章收录专栏
[✨— 《深入解析机器学习:从原理到应用的全面指南》 —✨]

问题归约法(Problem Reduction)

问题归约(problem reduction)是另一种基于状态空间的问题描述与求解方法。已知问题的描述,通过一系列变换把此问题最终变为一个本原问题集合;这些本原问题的解可以直接得到,从而解决了初始问题

问题归约表示的组成部分:

  • 一个初始问题描述;
  • 一套把问题变换为子问题的操作符;
  • 一套本原问题描述。

问题归约的实质:
从目标(要解决的问题)出发逆向推理,建立子问题以及子问题的子问题,直至最后把初始问题归约为一个平凡的本原问题集合

下面是问题归约法的一般步骤:

  1. 确定目标问题:明确要解决的原始问题是什么,以及需要得到的解决方案是什么。
  2. 识别子问题:分析原始问题,并确定可以将其分解为哪些较简单的子问题。子问题应该与原始问题相关,并且解决子问题可以为解决原始问题提供有用的信息。
  3. 定义转换规则:确定如何将原始问题转化为子问题。这包括定义问题之间的关系和转换过程,以确保转换后的子问题仍然保持原始问题的特性。
  4. 解决子问题:使用合适的方法或技术解决子问题。这可能涉及使用特定的算法、数学模型、启发式搜索等。
  5. 合并子问题的解:将子问题的解整合在一起,以得到原始问题的解。这可能需要将子问题的解进行组合、合并或进一步处理。
  6. 验证和优化解决方案:对得到的解决方案进行验证,确保它满足原始问题的要求。如果需要,可以对解决方案进行优化或调整。

我们以圆盘梵塔难题为例,

有3个柱子(1,2和3)和3个不同尺寸的圆盘(A,B和C)。在每个圆盘的中心有个孔,圆盘可以堆叠在柱子上。最初,全部3个圆盘都堆在柱子1上:最大的圆盘 C在底部,最小的圆盘A在顶部。要求把所有圆盘都移到柱子3上,每次只许移动一个,而且只能先搬动柱子顶部的圆盘,还不许把尺寸较大的圆盘堆放在尺寸较小的圆盘上。这个问题的初始配置和目标配置如图 2.3所示。
如果采用状态空间法来求解这个问题,其状态空间图含有 27个节点,每个节点代表柱子上圆盘的一种正当配置。

image-20231211163319205

也可以用问题归约法来求解此问题。对图所示的原始问题从目标出发逆向推理,其过程如下;
(1)要把所有圆盘都移至柱子3,必须首先把圆盘C移至柱子3;而且在移动圆盘C至柱子3之前,要求柱子3必须是空的。
(2)只有在移开圆盘A和B之后,才能移动圆盘 C;而且圆盘A和B最好不要移至柱子3,否则就不能把圆盘 C移至柱子3。因此,首先应该把圆盘 A和B移到柱子2上。
(3)然后才能够进行关键的一步,把圆盘C从柱子1移至柱子3,并继续解决难题的其余部分。

image-20231211164648389在这里插入图片描述

梵塔问题归约图(与或图)如下(用三元空间来描述问题)

image-20231211165725144在这里插入图片描述

归约图(与或图)解释

一些关于与或图的术语

image-20231211165624511在这里插入图片描述

可解节点的一般定义

终叶节点是可解节点(因为它们与本原问题相关联),

如果某个非终叶节点含有后继节点,那么只要有一个后继节点是可解的时,此非终叶节点就是可解的。
如果某个非终叶节点含有后继节点,那么只有其全部后继节点为可解时,此非终叶节点才是可解的。

不可解节点的一般定义
没有后裔的非终叶节点为不可解节点

如果某个非终叶节点含有后继节点,那么只有当其全部后裔为不可解时,此非终叶节点才是不可解的。
如果某个非终叶节点含有后继节点,那么只要好当其后裔有一个为不可解时,此非终叶节点就是不可解的。

谓词/符号逻辑(Symbolic Logic)

逻辑语句:一种形式语言,它能够把逻辑论证符号化,并用于证明定理,求解问题。
形式语言:严格地按照相关领域的特定规则,以数学符号(符号串)形式描述该领域有关客体的表达式。

语法和语义
基本符号:谓词符号、变量符号、函数符号、 常量符号、括号和逗号

image-20231211165454263在这里插入图片描述

在求解问题时,可把问题表示为一个有待证明的问题或定理,然后用消解原理和消解反演过程来证明。

在证明时,采用推理规则进行正向搜索, 使问题(定理)最终获得证明。另一种策略是采用反演证明来证明某个定理的否定是不成立的。首先假定该定理的否定是正确的,接着证明由公理和假定的定理之否定所组成的集合是不成立的,即导致矛盾的结论

通过逻辑推理和运用消解原理来求解证明。我们首先需要用谓词进行知识表示,以下是一个谓词的例子

设有如下语句,请用相应的谓词公式分别把他们表示出来 (要注意属性、行为、个体的区别

1)有人每天下午都去打篮球。

2)有的人喜欢梅花,有的人喜欢菊花,有的人既喜欢梅花又喜欢菊花

1.) 有人每天下午都去打篮球。

​ 解:定义谓词 P(x):

x是人 B(x):x打篮球 A(y):y是下午

将知识用谓词表示为:(A(y)→B(x)∧P(x))

2.) 老李每天下午都去打篮球。

解:定义谓词 d

P(x): x是人
L(x,y): x喜欢 y
其中,y 的个体域是(梅花,菊花)(注意个体域)

将知识用谓词表示为 :

$(Ex)(P(x)->L(x,梅花) ∨ L(x,菊花)∨ L(x,梅花)∧ L(x,菊花)) $

在更复杂的问题,我们需要掌握用消解/归结原理得到目标公式,消解是一种可用于一定的子句公式的重要推理规则,(对谓词演算公式进行分解和化简,消去一些符号,以求得导出子句,又称归结。)

以下是一些基本定义

子句:由文字的析取组成的合式公式。

文字:一个原子公式及其否定。

任一谓词演算公式可以化成一个子句集。变换过程如下:

  1. 消去蕴涵符号
    只应用∨和∼,以∼ A ∨ B替换 A→B
  2. 减少否定符号的辖域
    每个否定符号最多只用到一个谓词符号上,并反复应用狄⋅ 摩根定律
  3. 对变量标准化
    在任一量词辖域内,受该量词约束的变量称为一哑元(虚构变量),它可以在该辖域内处处统一的被另一个没有出现过的任意变量所代替,而不改变公的真值。
    合式公式中变量的标准化意味着对哑元改名以保证每个量词都有其唯一的哑元
  4. 消去存在量词
    从一个公式消去一个存在量词的一般规则是以一个Skolem函数1代替每个出现的存在量词的量化变量,而这个Skolem函数的变量就是由那些全称量词所约束的全称量词量化变量,这些全称量词的辖域包括要被消去的存在量词的辖域在内
    如果要消去的存在量词不在任何一个全称量词的辖域内,那么就用不含变量的Skolem函数即常量
    Skolem函数所使用的函数符号必须是新的
  5. 化为前束型
    把所有全称量词移到公式的左边,并使每个量词的辖域包括这个量词后面公式的整个部分,所得公式称为前束型。前束型公式由前缀和母式组成,前缀由全称量词串组成,母式由没有量词的公式组成
  6. 把母式化为合取范式
    任何母式都可写成由一些谓词公式和谓词公式的否定的析取的有限集组成的合取,这种母式叫做合取范式
  7. 消去全称量词
  8. 消去连词符号∧
    用{ A , B } 代替( A , B ) (A,B)(A,B),以消去∧
  9. 更换变量名称
    可以更换变量符号的名称,使一个变量符号不出现在一个以上的子句中

以下是基本定律(联接词的优先顺序:非~、合取∧、析取∨、蕴含

(1) 否定之否定: ~(~P)等价于P
(2) P∨Q等价于~P=>Q
(3) 狄·摩根定律: ~(P∨Q)等价于~P∧~Q
~(P∧Q)等价于~P∨~Q
(4) 分配律: P∧(Q∨R)等价于(P∧Q)∨(P∧R)
P∨(Q∧R)等价于(P∨Q)∧(P∨R)
(5) 交换律: P∧Q等价于Q∧P
P∨Q等价于Q∨P
(6) 结合律: (P∧Q)∧R等价于P∧(Q∧R)
(P∨Q)∨R等价于P∨(Q∨R)
(7) 逆否律: P=>Q等价于~Q=>~P

(8) ~(∃x)P(x) 等价于 (∀ x)[~P(x)]
~(∀ x)P(x) 等价于 (∃ x)[~P(x)]

(9) (∀ x)[P(x)∧Q(x)] 等价于 (∀ x)P(x)∧(∀ x)Q(x)
(∀ x)[P(x)∨Q(x)] 等价于 (∀ x)P(x)∨(∀ x)Q(x)

(10) (∀ x)P(x) 等价于 (∀ y)P(y)
(∃ x)P(x) 等价于 (∃ y)P(y)

得到子句集后后续有三个重要的问题求解方法需要重点掌握

  1. 消解推理规则(根据已有的式子析取推理)
  2. 含有变量的消解式(根据基子句推理的推广、原理一样,需要额外使变量相等)
  3. 消解反演求解过程(将要证明的命题,将其否定添加到命题公式集,如产生矛盾为真、否则为假)

消解反演求解例子一(证明一个子句):

设事实的公式集合
{ P,(P∧Q) → \rightarrow R,
(S∨T) → \rightarrow Q,T },
证明:R

否定结论 ,将公式化为子句,得子句集:
{ P,~P∨~ Q∨R,
~S∨Q,~ T∨Q ,T ,
~R }

这里除了用列出结论之外还可以用消解反演树

image-20231211194330594在这里插入图片描述

消解反演:

给出一个公式集合S 和目标公式L,通过反证或反演来求证目标公式 L ,其证明步骤如下:

否定L,得∼ L
把∼ L添加到S 中
把新产生的集合{ ∼ L , S } 化成子句集
应用消解原理,推导出一个表示矛盾的空子句

反演求解过程:
用反演树求取对某个问题的答案

  1. 把由目标公式的否定产生的每个子句添加到目标公式否定之否定的子句中,形成重言式
  2. 按照反演树,执行和以前相同的消解,直至在根部得到某个子句为止
  3. 用根部的子句作为一个回答语句

答案求取涉及把一棵根部有NIL的反演树变换为在根部带有可用答案的某个语句的一棵证明树

再来一个例子(反演求解 证明一个公式),建议动手做做

已知

1)能够阅读的都是有文化的。

2)海豚是没有文化的。

3)某些海豚是有智能的。

用归结原理证明:某些有智能的并不能阅读。

证明:
 
已知谓词:R(x)表示x能阅读, L(x)表示有文化,D(x)表示x是海豚,I(x)表示智慧的。
 
 
 
则将条件与目标用谓词公式表示:
 
(1) ∀x(R(x)→L(x))
 
(2) ∀x(D(x)→¬L(x))
 
(3) ∃x(D(x)∧I(x))
 
把要求证的结论用谓词公式表示出来并否定,得:
 
(4) ∃x(I(x)∧¬R(x))
 
 
把上述公式化成子句集:
 
(1) ¬R(x)∨L(x)
 
(2) ¬D(y)∨¬L(y)
 
(3) D(a)
 
(4) I(a)
 
(5) ¬I(z)∨R(z)
 
应用归结原理进行归结:
 
(6) ¬L(a)      (2),(3)归结
 
(7) ¬R(a)      (1),(6)归结
 
(8) R(a)       (4),(5)归结
 
(9) NIL        (7),(8)归结

在这里插入图片描述

						  🤞到这里,如果还有什么疑问🤞
					🎩欢迎私信博主问题哦,博主会尽自己能力为你解答疑惑的!🎩
					 	 🥳如果对你有帮助,你的赞是对博主最大的支持!!🥳

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/237729.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

QEMU源码全解析 —— virtio(2)

接前一篇文章: 本文内容参考: 《趣谈Linux操作系统》 —— 刘超,极客时间 《QEMU/KVM》源码解析与应用 —— 李强,机械工业出版社 特此致谢! 上一回对于virtio进行了简介,并说明了其基本原理以及框架。对…

在工作中灵活运用CHATGPT

问CHAT:基于微课技术的小学创新课堂教学模式开题,重要变更,侧重说明对照课题申请书、根据评议专家意见所作的研究计划调整 CHAT回复:在本研究项目的开题阶段,我们设想通过利用微课技术来提高小学创新课堂的教学质量。 …

外包干了3个月,技术退步明显

先说一下自己的情况。大专生,19年通过校招进入湖南某软件公司,干了接近3年的测试,今年年上旬,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了三年&#xff0c…

使用Mockjs模拟(假数据)接口(axios)

一、什么是MockJs Mock.js官网 Mock.wiki.git mock测试就是在测试过程中,对于某些不容易构造或者不容易获取的对象,用一个虚拟的对象来创建以便测试的测试方法。 二、安装mockjs npm install mockjs 三、 MockJs使用 简单使用: // 使用…

企业使用APP自动化测试工具的重要因素

随着移动应用市场的蓬勃发展,企业对高质量、高效率的软件交付提出了更高的要求。在这个背景下,APP自动化测试工具成为了企业不可或缺的一部分。以下是企业采用APP自动化测试工具的关键因素: 1. 快速且可重复的测试执行 自动化测试工具能够快速…

KUKA机器人如何隐藏程序或程序段?

KUKA机器人如何隐藏程序或程序段? 如下图所示,新建一个示例程序进行说明, 如下图所示,如果红框中的动作指令不想让别人看到,想隐藏起来,如何做到? 如下图所示,在想要隐藏的程序或程序段的前后,分别添加 ;fold 和 endfold指令(这里要注意是英文状态下的输入法), 如…

基于查表法的水流量算法设计与实现

写在前面 本文分享的是一种基于查表法的水流量的算法方案设计与实现,算法简单易懂,主要面向初学者,有两个目的:一是给初学者一些算法设计的思路引导;二是引导初学者学习怎样用C语言编程实现。 一、设计需求 基于“19…

c/c++ 柔性数组

在C99新增特性中,结构体的 最后一个元素 允许是 未知大小的数组 ,这样就叫做柔性数组成员。 struct stu{ int i; char c; int arr[ ]; //未知大小数组,并且是整个结构体最后一个成员 } 这个时候结构体所占字节空间是多少&#xf…

FPGA高端项目:UltraScale GTH + SDI 视频解码,SDI转DP输出,提供2套工程源码和技术支持

目录 1、前言免责声明 2、相关方案推荐我这里已有的 GT 高速接口解决方案我目前已有的SDI编解码方案 3、详细设计方案设计框图3G-SDI摄像头LMH0384均衡EQUltraScale GTH 的SDI模式应用UltraScale GTH 基本结构参考时钟的选择和分配UltraScale GTH 发送和接收处理流程UltraScale…

人工智能的技术演进与未来趋势

人工智能的技术演进与未来趋势 一、引言 人工智能(AI)已经成为当今科技领域的热门话题,其在各个行业的应用越来越广泛。从智能语音助手到自动驾驶汽车,从智能家居系统到医疗诊断,AI技术已经深入到我们的日常生活。在…

Arrays.asList() 和 Collections.singletonList()

Arrays.asList() 和 Collections.singletonList() 概述 List 是我们使用Java时常用的集合类型。众所周知,我们可以轻松地在一行中初始化列表。例如,当我们想要初始化一个只有一个元素的List时,我们可以使用Arrays.asList(&#…

Spring 的缓存机制【记录】

一、背景 在最近的业务需求开发过程中遇到了“传说中”的循环依赖问题,在之前学习Spring的时候经常会看到Spring是如何解决循环依赖问题的,所谓循环依赖即形成了一个环状的依赖关系,这个环中的某一个点产生不稳定变化都会导致整个链路产生不…

6_CSS布局之浮动的应用

day06_CSS布局之浮动的应用 本课目标(Objective) 理解什么是浮动掌握浮动的三种机制掌握浮动的案例应用 1 CSS 布局的三种机制 CSS 提供了 3 种机制来设置盒子的摆放位置,分别是普通流(标准流)、浮动和定位。 普通流…

MySQL 教程 2.1.1

MySQL 插入数据 MySQL 表中使用 INSERT INTO 语句来插入数据。 你可以通过 mysql> 命令提示窗口中向数据表中插入数据,或者通过PHP脚本来插入数据。 语法 以下为向MySQL数据表插入数据通用的 INSERT INTO SQL语法: INSERT INTO table_name (colu…

110. 平衡二叉树(Java)

给定一个二叉树,判断它是否是高度平衡的二叉树。 本题中,一棵高度平衡二叉树定义为: 一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1 。 示例 1: 输入:root [3,9,20,null,null,15,7] 输出:t…

基于conda环境使用mamba/conda安装配置QIIME 2 2023.9 Amplicon扩增子分析环境,q2cli主要功能模块介绍及使用

QIIME 2 2023.9 Amplicon Distribution介绍: 概述 qiime团队专门针对高通量扩增子序列分析退出的conda集成环境,包括了主要和常见的扩增子分析模块,用户可以单独使用各个模块,也可以使用各模块组成不同的分析流程。从2023.09版本…

Linux——Web网站服务(二)

一、httpd服务的访问控制 1、客户机地址限制 通过Require配置项&#xff0c;可以根据主机的主机名或P地址来决定是否允许客户端访问。在 httpd服务器的主配置文件的<Location>&#xff0c;<Directory>、<Files>、<Limit>配置段中均可以使用Require配置…

MQ-Det: Multi-modal Queried Object Detection in the Wild

首个支持视觉和文本查询的开放集目标检测方法 NeurIPS2023 文章&#xff1a;https://arxiv.org/abs/2305.18980 代码&#xff1a;https://github.com/YifanXu74/MQ-Det 主框图 摘要 这篇文章提出了MQ-Det&#xff0c;一种高效的架构和预训练策略&#xff0c;它利用文本描述的…

【LeetCode刷题-树】-- 103.二叉树的锯齿形层序遍历

103.二叉树的锯齿形层序遍历 方法&#xff1a;广度优先搜索 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.val val; }* TreeNode(int …

单片机(STM32,GD32,NXP等)中BootLoader的严谨实现详解

Bootloader(引导加载程序)的主要任务是引导加载并运行应用程序&#xff0c;我们的软件升级逻辑也一般在BootLoader中实现。本文将详细介绍BootLoader在单片机中的实现&#xff0c;包括STM32、GD32、NXP Kinetis等等的所有单片机&#xff0c;因为无论是什么样的芯片&#xff0c;…