prolog --寻找neni (2)
混合查询
我们可以把简单的查询连接起来,组成复杂的查询。
?- location(X,kitchen),edible(X).
简单查询只有一个目标,而混合查询可以把这些目标连接起来。从而进行较为复杂的查询。
, 合取 且 的意思。
该查询意思为:寻找满足条件的X,条件是:X位于kitchen中,且可以吃(具有edible属性)
如果某个变量在查询中多次出现,那么此变量在所有出现的位置都必须绑定相同的值,所以该查询,只有找到一个X 得值,使得两个目标都成立,才算查询成功。
每次查询所使用的都是局部变量。
除了使用逻辑的方式理解混合查询外,还可以通过分析程序运行步骤的方式来理解
如该查询可以这么理解:首先找到一样位于厨房的东西,然后判断它是否能吃。
如果不能,那就找到下一样东西,在判断能否使用,直至找到答案,或者是把厨房的东西都查找完毕。
[debug] ?- location(X,kitchen),edible(X).
T Call: () location(_G533, kitchen)
T Exit: () location(broccoli, kitchen) %匹配第一个子句成功
T Call: () edible(broccoli) %匹配第二个子句
T Fail: () edible(broccoli) %匹配第二个子句失败,解除第一个子句的绑定,回溯上一个匹配成功的子句,发现并没有,回溯到最开始状态。
T Redo: () location(_G533, kitchen) %重新匹配第一个子句
T Exit: () location(crackers, kitchen)
T Call: () edible(crackers) % 匹配第二个子句
T Exit: () edible(crackers) %匹配成功,绑定X,同时显示
X = crackers ;
T Redo: () location(_G533, kitchen)
T Exit: () location(apple, kitchen)
T Call: () edible(apple)
T Exit: () edible(apple)
X = apple. [debug] ?-
上面为一个变量的。下面是两个变量的。
?- door(kitchen,R),location(T,R).
意思:找到和kitchen有们相邻的R,找到位于R中的T
[debug] ?- door(kitchen,R),location(T,R).
T Call: () door(kitchen, _G534)
T Exit: () door(kitchen, office) %匹配第一个子句成功
T Call: () location(_G536, office) %开始匹配第二个子句
T Exit: () location(desk, office) %匹配第二个子句,
R = office,
T = desk ;
T Redo: () location(_G536, office) %释放 T,重新在上一次匹配成功的子句后面寻找其他符合目标的条目
T Exit: () location(computer, office) % 再次找到符合条目,绑定,显示
R = office,
T = computer ;
T Redo: () door(kitchen, _G534) %SWI-prolog的原因,没有显示上面那次location匹配失败,重新开始匹配door子句,
T Exit: () door(kitchen, cellar) %找到 door 子句 绑定 R cellar
T Call: () location(_G536, cellar) % 查找 location子句
T Exit: () location('washing mechine', cellar)
R = cellar,
T = 'washing mechine'. [debug] ?-
如图所示,由于SWI-prolog的不显示 fail 的原因,所以,我同样copy一份教程上的 debug 调试信息
?-door(kitchen,R),location(T,R). call door(kitchen,R) %匹配第一个子句
exit() door(kitchen,office)
call location(T,office) %第一个子句匹配成功之后,匹配第二个子句
exit() location(desk,office)
R = office
T = desk redo location(T,office) %释放掉T,重新开始查询剩余的与location相匹配的条目
exit() location(computer,office) %匹配成功
R = office
T = computer redo location(T,office) %释放掉 T ,再次查询剩余的与location相匹配的条目
fail location(T,office) % 查询失败,释放掉 R,返回上一次匹配成功的子语句,发现并没有,所以会到最初状态 redo door(kitchen,R) % 在最开始匹配成功的条目后面,查找剩余的和door相匹配的条目
exit() door(kitchen,cellar) %匹配door成功,帮定R
call location(T,cellar) %开始查找第二个子句
exit() location('washing room',cellar) %查找成功,绑定R,显示R,T
R = cellar
T = 'washing room' redo location(T,cellar) %释放 T,重新开始查找剩下的和location相匹配的条目
fail location(T,cellar) % 查找失败 释放已经绑定的R,返回上一次匹配成功的子句,发现没有,会到最初状态 redo door(kitchen,R) % 重新查找剩余的和door相匹配的条目
fail door(kitchen,R) %查找失败结束所有查找
no
prolog --寻找neni (2)的更多相关文章
- prolog 规则
规则 规则由几个互相依赖的简单句(谓词)组成.用来描述事实之间的依赖关系,如:因果关系,蕴含关系,对应关系 规则的实质就是存储起来得查询 其语法结构如下: head:-body head 为谓词的定义 ...
- Prolog学习:基本概念 and Asp.net与Dojo交互:仪器仪表实现
Asp.net与Dojo交互:仪器仪表实现 项目中需要用到仪器仪表的界面来显示实时的采集信息值,于是便遍地寻找,参考了fusionchart和anychart之后,发现都是收费的,破解的又没有这些功能 ...
- 对Prolog的感想和我写的一些教程
我第一次见到Prolog这门独特的编程语言是在<七周七语言(Seven Languages in Seven Weeks)>中看到的.<七周七语言>名字看起来与市面上什么< ...
- Atitit.5gl 第五代语言编程语言 PROLOG教程 人工智能语言的标准 与实现
Atitit.5gl 第五代语言编程语言 PROLOG教程 人工智能语言的标准 与实现 1. 第五代语言就是自然语言又被称为知识库语言或人工智能语言,1 2. 人工智能语言特点2 2.1. 试探法2 ...
- 人工智能技术导论——逻辑程序设计语言PROLOG
最近在复习人工智能导论,里面介绍了一种逻辑关系语言PROLOG,但这本书里面用到的编译器是Turbo PROLOG,这个编译器早就被淘汰了,我后来找的了它的升级版Visual PROLOG,但一些语法 ...
- 【ProLog - 4.0 List】
[简介] 列表是Prolog编程中常用的一种重要的递归数据结构 列表是一个有限的元素序列 实例: 所有Prolog术语都可以是列表的元素,一个非空的List应该含有两个元素:头元素(Head)和尾元素 ...
- [LeetCode] Find the Celebrity 寻找名人
Suppose you are at a party with n people (labeled from 0 to n - 1) and among them, there may exist o ...
- [LeetCode] Find Minimum in Rotated Sorted Array II 寻找旋转有序数组的最小值之二
Follow up for "Find Minimum in Rotated Sorted Array":What if duplicates are allowed? Would ...
- [LeetCode] Find Minimum in Rotated Sorted Array 寻找旋转有序数组的最小值
Suppose a sorted array is rotated at some pivot unknown to you beforehand. (i.e., 0 1 2 4 5 6 7 migh ...
随机推荐
- AngularJS---表达式
AngularJS的表达式是放在{{}}里面,用{{ }}符号将一个变量绑定到$scope上. angularJS中的表达式有如下特点: 1.只能在其所属作用域内部 所有的表达式都在其所属的作用域内部 ...
- 理解Condition的用法
这个示例中BoundedBuffer是一个固定长度的集合,这个在其put操作时,如果发现长度已经达到最大长度,那么会等待notFull信号,如果得到notFull信号会像集合中添加元素,并发出notE ...
- 【巩固】bootstrap笔记二
这段主要记录如何给排版完的页面加一些动画效果,用到了的插件有: wow.min.js jquery.singlePageNav.min.js animate.css 将导航条上对应的菜单和页面上对应的 ...
- 在Eclipse中使用JUnit4进行单元测试(中级篇)
我们继续对初级篇中的例子进行分析.初级篇中我们使用Eclipse自动生成了一个测试框架,在这篇文章中,我们来仔细分析一下这个测试框架中的每一个细节,知其然更要知其所以然,才能更加熟练地应用JUnit4 ...
- 关于Failed to install helloworld.apk on device 'emulator-5554!的一个解决办法
好不容易架好了android环境,把该安得都安好了,结果发现在安装过程中创建一个虚拟设备映象就占用了c盘34g的空间,我的系统盘差点瘫了,看来以后就只能先用这一个虚拟设备调试了, 接着说上边这个问题, ...
- 如何用Jupyter Notebook打开Spark
电脑已经装了anaconda python,然后下载了spark2.1.0.因为版本太新,所以网上和书上的一些内容已经不再适用.比如关于如何使用IPython和Jupyter,教程给出的方法是用如下语 ...
- 多个Jdk版本(转)
window下在同一台机器上安装多个版本jdk,修改环境变量不生效问题处理办法 本机已经安装了jdk1.7,而比较早期的项目需要依赖jdk1.6,于是同时在本机安装了jdk1.6和jdk1.7. 安装 ...
- 检测文件是否有BOM 头,并删除BOM头(php)
将下面文件放在网站根目录访问即可,它会遍历当前目录下所有子目录,检测文件是否含有BOM头,并删除BOM头 <?php //remove the utf-8 boms //by magicbug ...
- ubuntu14.04 JDK安装
JDK7 安装 1 sudo apt-get install openjdk-7-jdk 2 设置安装环境 在/etc/profile中追加: # Java support # export JAVA ...
- gpio高阻态
配置gpio为高阻态:将gpio设为GPIO_INPUT,GPIO_NO_PULL即可