Visual Prolog 的 Web 专家系统 (8)
GENI核心 -- 推理引擎(2)流量控制
1、阐述fail、“!”而回溯
与其他语言相比,,Prolog最大的特点。这是回溯机制。
回溯机制,还有的主要手段2个月,首先,通过使用谓词fail触发回溯,特别谓词“!”(读作cut)取消回溯。
Prolog运用fail引发回溯。实现程序的循环,并运用“!”对回溯进行控制。
看一个典型演示样例:
FACTS
f(integer)
PREDICATES
a()
b()
c()
CLAUSES
a():-
write("------ a -------\n"),
f(X),
writef("%\n",X),
fail.
a():-
write("a is sucsess.").
%---------------------------------------------------------
b():-
write("\n\n------- b -------\n"),
f(X),
writef("%\n",X),
!,
fail.
b():-
write("b is sucsess.").
%---------------------------------------------------------
c():-
write("\n\n------- c -------\n"),
a(),
b(),
!,
write("\nc sucsess.").
c():-
write("\nc backtracking.\n\n").
%---------------------------------------------------------
GOAL
assert(f(1)),
assert(f(2)),
assert(f(3)),
c().
在VDE中,菜单选:File|New,新建一文件noname.pro,把上边的代码贴进去
菜单选:Project|Test Goal,
执行结果。输出显演示样例如以下:
------- c -------
------ a -------
1
2
3
a is sucsess. ------- b -------
1 c backtracking. yes
程序非常easy,GOAL先把事实f(1)、f(2)、f(3)入库,接着求证c()。
Prolog把“函数调用”称作“求证(query)子目标”。
并不是Prolog矫情。别的“小语种”基本如此。
比方。函数语言Lisp、Erlang等,把“函数调用”称作“求值(evaluate)“。
还得说说”子目标“。
从理论上说,Prolog程序,由一个总目标和多个子目标构成,形成”树“逻辑关系。
GOAL是总目标,即树的根结点,子目标则是树的各层枝叶。
在本演示样例中,总目标的子目标是c(),而a(),b()则是c()的子目标。
在a()和b()中,子目标是f(X)。
这段演示样例代码的看点,主要是fail和!。
write(),writef()等管理输入输出的谓词,不是子目标。由于,它们不參与求证、推理。
要正确理解谓词子句体内子目标的关系。逗号”,“是关键。
逗号”,“的含意,是逻辑”与“,and。因此。子句体实际上是个复合逻辑推断:
比如,子句
a():- b(),c(),d().
相当于:
if a() then { if (b() and c() and d()) then a() }
这里并没写错,子句头与子句体就是这种逻辑关系。
不仅如此,分号”;“表示逻辑”或“。
比如。本例的谓词a(),2个子句能够合并写成这样:
a():-
write("------ a -------\n"),
f(X),
writef("%\n",X),
fail
;
write("a is sucsess.").
仅仅是,用分号”,“而非并列子句表示逻辑或,会造成代码难读、难懂等误会,非常不有用。
所以,在实际编程中,差点儿见不到使用分号”;“的。
如今再回到GENI的推理机流程控制这个话题上来。
上面提到的“典型演示样例”,是GENI的推理机流程控制的方法之中的一个。
当中,谓词a()中的fail,遍历了所有f(X)。
谓词b()中的 !,fail。仅仅取得第一个f(X),而且不再回溯。
谓词c()中的 ! 也非常重要。
没有它。程序编译时就会出错。
2、Prolog以先深搜索的方式求证子目标
Prolog本身就是以先深搜索的方式求证目标的推理机。
仍以上面的“典型演示样例”说事。
a(),b()。c()等三个谓词,分别都是由2个子句构成的逻辑或,or 的关系。
它他们体内条款。构成逻辑和。and 关系。
按照逻辑操作的优先级的规则。第一and后or。
然后,证明的方式来形成目标深度优先搜索。
GENI知识库rule,按道理“树”关系,与Prolog完全一致的推理机制。
和GENI推理引擎本身,这是他们的知识基础结构,量身定制,以验证机深层搜索目标。
Visual Prolog 的 Web 专家系统 (8)的更多相关文章
- Visual Prolog 的 Web 专家系统 (1)
用Prolog敲代码,感觉舒坦. Prolog的编程范式,抽象程度远高于中.低级别的C语言等.敲代码的源码长度,至少比C语言的节省50%. 并且,Prolog的语法简单,符号选择自然合理,养眼度远高于 ...
- Visual Prolog 的 Web 专家系统 (7)
GENI核心 -- 推理引擎(1)知识表示 GOAL最后一句是谓语infer(),它的含义是"论证". 因此,,进GENI核心,执行视图推理引擎. infer() infer(): ...
- Visual Prolog 的 Web 专家系统 (9)
GENI的核心 -- 推理机(3)一些谓词 为了集中注意力.较好地分析GENI推理机核心程序,应该做些准备工作,弄明确一些起辅助作用的谓词功能. is_htmlfile(Rulexpl) is_htm ...
- Visual Prolog 的 Web 专家系统 (6)
保存用户响应询价.作为进一步推理的条件 或GOAL段开始.最初的一句是write_startform() write_startform():- write("<form action ...
- Visual Prolog 的 Web 专家系统 (10)
GENI的核心 -- 推理机(4)求证过程分析 1.GENI知识库结构 专家系统推理机的设计执行,与其知识库结构紧密相关. GENI知识库结构是一棵逻辑推理树. 根节点是animal,即求证的目标. ...
- Visual Studio 2013 Web开发
cnbeta新闻:微软正式发布Visual Studio 2013 RTM版,微软还发布了Visual Studio 2013的最终版本..NET 4.5.1以及Team Foundation Ser ...
- VSS提示"Could not find the Visual SourceSafe Internet Web Service connection information for the specified database
转自:http://www.cnblogs.com/qqflying/archive/2007/12/18/1004051.html VSS连接错误提示: ====================== ...
- Visual Studio的Web Performance Test提取规则详解(3)
总结 Visual Studio的Web Performance Test是基于HTTP协议层的,它不依赖于浏览器,通过直接接收,发送HTTP包来和Web服务器交互.Web Performance T ...
- Visual Studio的Web Performance Test提取规则详解(2)
总结 Visual Studio的Web Performance Test是基于HTTP协议层的,它不依赖于浏览器,通过直接接收,发送HTTP包来和Web服务器交互.Web Performance T ...
随机推荐
- android 按字母搜索
在看Oplayer的时候看见滑动字母来实现listView的内容搜索,所以就把里面的核心的函数扣除来做了一个demo,分为两部分一个是布局,另一个就是代码了,具体的如下: 布局: <?xml v ...
- HTML语言简单回顾
简单复习一下html语言. html的基本结构如下: <html> <head> <title></title> </head> <b ...
- 基于unity3d和leap motion的拼图游戏
近期用unity3d引擎做了一个拼图游戏,会分几次写完,以此作为总结. 本文基本查找了网上能查到的全部资料作为參考.也算是大家节省了时间. 眼下仅仅完毕了拼图部分,leap motion手势控制部分会 ...
- 486E - LIS of Sequence(LIS)
题意:给一个长度为n的序列.问每一个数关于序列的LIS(longest increasing subsequence)是什么角色. 这里分了三种: 1.此数没有出如今随意一条LIS中 2.此数出如今至 ...
- 某公司ASP.NET应聘上机试题
ASP.NET笔试题是ASP.NET程序员面试必须经历的,一般会叫你填两个表 1个是你的详细信息表 1个是面试题答卷 两个都要注意反正面是否都有内容不要遗漏,如果考你机试一般也有两种,就是程序连接数据 ...
- JSP的学习(6)——九大隐式对象及其out对象
本篇将介绍JSP中的九大隐式对象,并重点介绍其中的out对象. 我们在之前的博客<JSP的学习(1)——基础知识与底层原理>一文中已经知道,JSP最终要被翻译和转换成Servlet,在转换 ...
- Selenium HtmlUnitDriver 多浏览器的支持
1.HtmlUnitDriver WebDriver包括一个基于HtmlUnit的无界面实现,称为HtmlUnitDriver,即使用HtmlUnit时并不会打开真实的浏览器,而是在内存中执行代码,因 ...
- 14.9.4 COMPACT and REDUNDANT Row Formats
14.9.4 COMPACT and REDUNDANT Row Formats InnoDB 早期的版本 使用一种未命名的文件格式(现在称为Antelope(羚羊)) 对于数据库文件 在这种文件格式 ...
- eval 捕获错误
eval 捕获错误: [root@dr-mysql01 ~]# cat t1.pl use DBI; my $dbUser='zabbix'; my $user="root"; m ...
- 工信部表态支持Linux,可是Linux又是什么呢?
近日,工信部高层官员出面表态:工信部大力支持发展国产Linux操作系统,可是,Linux又是什么呢?假设依照工信部的说法,发展所谓"国产Linux".恐怕要给国家带来麻烦. 大家知 ...