【Prolog - 2.0 基础应用】
【术语统一 terms unify】
两者统一,只需满足下面两条件之一
1.原本就是相同的
2.包含变量,这些变量可以用术语统一实例化,从而得到相等的术语
mia和mia是统一的,42和42是统一的,woman(mia)和woman(mia)是统一的
woman(mia)和woman(jody)不是统一的
【实例化 Instantiations】
当Prolog统一两个术语时,它会执行必要的实例化,以便在之后的操作中,二者相等
1.如果T1和T2是常数,如果它们是相同的原子,或者相同的数,那么T1和T2是统一的
2.如果T1是变量并且T2是任何类型的项,则T1和T2统一,并且T1实例化为T2(反之亦然)
3.如果T1和T2是复杂的术语,则它们在以下情况下统一:1.它们具有相同的函子和对数 2.所有其对应的自变量都统一 3.变量实例化是兼容的
例子1:
?- mia = X.
X=mia
yes
例子2:
?- X=mia, X=vincent.
no
no的原因在于,在实现第一个目标之前,Prolog用mia实例化了X,因此它无法与vincentany统一。因此,第二个目标失败了。
例子3:
?- k(s(g),Y) = k(X,t(k)).
X=s(g)
Y=t(k)
yes
例子4:
?- k(s(g),t(k)) = k(X,t(Y)).
X=s(g) Y=k
yes
另外,在查询?- father(X) = X.的时候,会出现一个X=father(father(father(...))))的死循环,但是最终会得到yes的结果
这就引出了一个概念,叫做“占用检查occurscheck” :
如果要求将一个变量与另一项统一起来,它会检查该变量是否出现在这一项中
【统一性实战】
Eg1 :

Eg2 :

Eg3 :

【证据搜索 Proof Search 以及 搜索树 search trees】
当我们提供了一个条件或者目标进行答案搜索的时候,Prolog会进行一个名为“搜索树”的方法进行搜索
例1:

例2:

【ProLog的搜索与回答】
Prolog有一种特定的方式来回答查询,具体如下所示
1.从上到下搜索知识库
2.从左到右处理子句
3.从错误的选择中返回
【Prolog - 2.0 基础应用】的更多相关文章
- 【Prolog - 1.0 基础语法与概念】
[概述] Prolog的语法与其它常用语言(如C,JAVA等)不同,它更接近于自然语言. [实例] 当我想表示"Mia是以女人"这个事实(之后会提到事实这个概念)的时候,我可以这么 ...
- <-0基础学python.第一课->
初衷:我电脑里面的歌曲很久没换了,我想听一下新的歌曲,把他们下载下来听,比如某个榜单的,但是一首一首的点击下载另存为真的很恶心 所以我想有没有办法通过程序的方式来实现,结果还真的有,而且网上已经有有人 ...
- Android 工程在4.0基础上混淆
Android现在对安全方面要求比较高了,我今天要做的对apk进行混淆,用所有的第三方工具都不能反编译,作者的知识产权得到保障了,是不是碉堡了. 一,首先说明我这是在4.0基础上进行的. 先看看pro ...
- Android程序开发0基础教程(一)
程序猿学英语就上视觉英语网 Android程序开发0基础教程(一) 平台简单介绍 令人激动的Google手机操作系统平台-Android在2007年11月13日正式公布了,这是一个开放源码的操 ...
- swift3.0基础语法
swift 3.0 基础语法 目录 01-变量和常量 02-运算符 03-可选项 04-条件语句 05-循环 06-字符串 07-元组 08-数组 09-字典 10-对象和类 11-枚举 12-属性 ...
- 【转】WF4.0 (基础篇)
转自:http://www.cnblogs.com/foundation/category/215023.html 作者:WXWinter —— 兰竹菊梅★春夏秋冬☆ —— wxwinter@16 ...
- JAVA思维导图系列:多线程0基础
感觉自己JAVA基础太差了,又一次看一遍,已思维导图的方式记录下来 多线程0基础 进程 独立性 拥有独立资源 独立的地址 无授权其它进程无法訪问 动态性 与程序的差别是:进程是动态的指令集合,而程序是 ...
- 【转】Android 工程在4.0基础上混淆
Android现在对安全方面要求比较高了,我今天要做的对apk进行混淆,用所有的第三方工具都不能反编译,作者的知识产权得到保障了,是不是碉堡了. 一,首先说明我这是在4.0基础上进行的. 先看 ...
- 0基础搭建Hadoop大数据处理-编程
Hadoop的编程可以是在Linux环境或Winows环境中,在此以Windows环境为示例,以Eclipse工具为主(也可以用IDEA).网上也有很多开发的文章,在此也参考他们的内容只作简单的介绍和 ...
随机推荐
- 11月16日NGK公链第13期官方快讯!
- winform导出csv
public void ExportToSvc1(string strFileName) { string strPath = strFileName + ".csv"; Stri ...
- ATP - UI 自动化测试用例管理平台搭建
用到的工具:python3 + django2 + mysql + RabbitMQ + celery + selenium python3和selenium这个网上很多教程,我不在这一一说明: ...
- JVM基础入门
内存模型 我理解的jvm: 个人理解的jvm流程: .java反编译为.class文件 经类加载器到上图的内存模型 方法区:存静态 常量区(String在里面) 本地栈区:调本地服务其它库的方法 计数 ...
- ElementUI使用总结
首先声明,我这总结的官网都有,只是将自己使用时遇到的问题,重新记录一下,官网地址:https://element.eleme.cn/ 1.表格内指定行数给定不同样式(类似于隔行变色,也能叫指定行数不同 ...
- 将VMware工作站最小化到托盘栏
目录 前言 将VMware最小化到托盘栏的方法 1.下载 Trayconizer 2.解压 trayconizerw.zip 3.创建 VMware 快捷方式 4.修改 VMware 快捷方式 5.运 ...
- python进阶(9)多线程
什么是线程? 线程也叫轻量级进程,是操作系统能够进行运算调度的最小单位,它被包涵在进程之中,是进程中的实际运作单位.线程自己不拥有系统资源,只拥有一点儿在运行中必不可少的资源,但它可与同属一个进程的其 ...
- mysql锁——innodb的行级锁
[前言]数据库锁定机制简单来说,就是数据库为了保证数据的一致性,而使各种共享资源在被并发访问变得有序所设计的一种规则.MySQL数据库由于其自身架构的特点,存在多种数据存储引擎,每种存储引擎所针对的应 ...
- kali 将家目录下的中文文件名修改成英文
修改vim ~/.config/user-dirs.dirs 打开`文件,删除那些中文目录 在目录下创建英文目录 重启 参考 https://elementaryos.stackexchange.co ...
- rsyslog日志总结
rsyslog日志总结 一 rsyslog介绍 syslogd被rsyslog取代 将日志写入数据库 可以利用模块和插件控制输入输出 rsyslog程序管理本地和远程日志 安装软件 根据需求修改配置文 ...