Prolog(Programming in Logic的缩写)是一种逻辑
编程语言。它建立在
逻辑学的理论基础之上,最初被运用于自然语言等研究领域。现已广泛的应用在
人工智能的研究中,可以用来建造专家系统、自然语言理解、智能知识库等。同时对一些通常的应用程序的编写也很有帮助,能够比其他的语言更快速地开发程序,因为它的编程方法更像是使用逻辑的语言来描述程序。
历史
Prolog语言最早由Aix-Marseille大学的Alain Colmerauer与Phillipe Roussel等人于60年代末研究开发。1972年被公认为是Prolog语言正式诞生的年份,自1972年以后,分支出多种Prolog的方言。最主要的两种方言为
爱丁堡和Aix-Marseille。最早的Prolog解释器由Roussel建造,而第一个Prolog编译器则是 David Warren编写的。
Prolog一直在北美和
欧洲被广泛使用。日本政府曾经为了建造智能
计算机而用Prolog来开发ICOT第五代计算机系统。在早期的机器智能研究领域,Prolog曾经是主要的开发工具。
80年代
Borland开发的Turbo Prolog,进一步普及了Prolog的使用。1995年确定了ISOProlog标准。
受Prolog影响的程序语言有很多,较为人所知的有:Mercury、Oz、
Erlang、Strand。
目前比较流行的实现工具包括 SWI-Prolog, Yap 等。
特点
1. prolog程序没有特定的运行顺序,其运行顺序是由电脑决定的,而不是编程序的人。
从这个意义上来说,prolog程序不是真正意义上的程序。所谓程序就是按照一定的步骤运行的
计算机指令,而prolog程序的运行步骤不由人来决定。它更像一种描述型的语言,用特定的方法描述一个问题,然后由电脑自动找到这个问题的答案。举个极端的例子,你只需要把某个数学题目告诉它,它就会自动的找到答案,而不像使用其他的语言一样,必须人工的编制出某种算法。
2. prolog程序中没有if、when、case、for这样的控制流程语句
前面已经说了,程序的运行方式有电脑自己决定,当然就用不到这些控制流程的语句了。通常情况下,程序员不需要了解程序的运行过程,只需要注重程序的描述是否全面,不过prolog也提供了一些控制流程的方法,这些方法和其他语言中的方法有很大的区别,希望你在以后的学习当中能够融会贯通。
3. prolog程序和数据高度统一
在prolog程序中,是很难分清楚哪些是程序,哪些是数据的。事实上,prolog中的所有东西都有相同的形式,也就是说数据就是程序,程序就是数据。举一个其他语言的例子:如果想用
c语言编写一个计算某个数学表达式的程序很简单(比如:a=2+5*4),因为这是一段程序。但是如果想编写一个计算用户输入的表达式的值的程序就很困难了。因为用户输入的是一段数据(字符串),如果想让c语言处理这个字符串,就需要很多方面的技术。则正是因为在c语言中,程序和数据是分开的。而在prolog就不存在这个问题,你甚至可以很轻松的编写处理其它prolog程序的程序。
4. prolog程序实际上是一个智能数据库
prolog的原理就是关系数据库,它是建立在关系数据库的基础上的。在以后的学习中你会发现它和
SQL数据库查询语言有很多相似之处。使用prolog可以很方便的处理数据。
5. 强大的递归功能
在其它的语言中,你也许已经接触过递归程序了。递归是一种非常简洁的方式,它能够有效的解决许多难题。而在prolog中,递归的功能得到了充分的体现,你甚至都会感到惊奇,递归居然有如此巨大的能力。
语法示例
表示事实:
human(bill).
likes(kate,bill).
——表示kate和bill是人(human),kate喜欢bill;
表示规则:
friend(X,Y):-likes(X,Y),likes(Y,X).
——表示对于两个对象XY,如果X喜欢Y,且Y喜欢X,那么他们是朋友。
范例
Quicksort
/*quicksort2.pl,原始来源:http://en.wikipedia.org/wiki/Prolog*/
/* quicksort()中的第二个引数带有排序好的结果 */
/* 仅为示范,若为gprolog使用者则用内建sort等较佳 */
/* 在gprolog下之编译,例:gplc --min-size quicksort.pl*/
/* 执行 quicksort2 后会出现排序结果 [2,9,18,18,25,33,66,77] */
q:- L=[33,18,2,77,66,18,9,25], last(P,_),(quicksort(L,P,_),write(P),nl). /* 加入last/2会在印P时没复合项 */
partition([], _,[],[]). /* 此行表空集亦视为分割(分割成空集与空集)*/
partition([X|Xs], Pivot, Smalls, Bigs):- /* 原list分成Smalls与Bigs; 此rule保证Smalls集\u003cPivot且Bigs集\u003e=Pivot */
( X @\u003c Pivot -\u003e
Smalls =[X|Rest],
partition(Xs, Pivot, Rest, Bigs)
; Bigs =[X|Rest],
partition(Xs, Pivot, Smalls, Rest)
).
quicksort([]) --\u003e[]. /* 表empty list视为排序好的list */
quicksort([X|Xs])--\u003e /* 此行相当于quicksort([X|Xs],Start,End) :- 此rule让Start为sorted list */
{ partition(Xs, X, Smaller, Bigger)}, /* 由上行最左端元素为 Pivot */
quicksort(Smaller),[X], quicksort(Bigger). /* 此行相当于 quicksort(Smaller,Start,A),
A=[X|B], 注意首字母大写者皆视为变数(list)
quicksort(Bigger,B,End). */
:-initialization(q). /* 启动q处goals */
Sort
/* sortcsj.pl 原始参考:Computer Science J. Glenn
Brookshear */
/* sortcsj()中的第二个引数带有排序好的结果 */
/* 仅为示范,若为gprolog使用者则用内建sort等较佳 */
/* 在gprolog下之编译,例:gplc --min-size sortcsj.pl */
/* 执行 sortcsj 后会出现排序结果 [2,9,18,18,25,33,66,77] */
q:- L=[33,18,2,77,18,66,9,25],(sortcsj(L,P),write(P),nl).
sortcsj(L,S):- permutation(L,S), ordered(S). /* L为原list, S为排序好的list, 此为permutation关系(built-in) */
ordered([]). /* 表empty list视为排序好的list */
ordered([_|[]]). /* 只有一元素之list视为排序好的list */
ordered([A|[B|T]]):- A =\u003c B, ordered([B|T]). /* 此rule约束所谓的排序好是指前项元素小于或等于后一项元素 */
:-initialization(q). /* 启动q处goals */
Russell's paradox
/* tstpx.pl */
/* 罗素佯谬(
罗素悖论)(皇帝新脑 罗杰。彭罗斯 p.120)会导致不停机(使得gprolog产生 stack overflow) */
/* 在gprolog下之编译,例:gplc --min-size tstpx.pl */
q:- px(_). /* 找寻任何可使 px() rule 成立的方式 */
px(1):-\+ px(1). /* 规定此rule不成立。 i.e. 此rule为假时此rule才为真 (佯谬)*/
:-initialization(q). /* 启动q处goal */
如何使用Prolog
一般而言,prolog作为数据或者逻辑处理程序而运行,配合其它程序如VC++、JAVA等的界面,由此实现带UI交互的“智能”软件,当然你所编辑出来的“智能”是软件,而不能说是真正意义的
人工智能。上文说Prolog就是一个智能数据库,其实不然,Prolog主要是对数据进行一种关系描述,比如张三和李四是A关系,李四和王二是B关系,A关系==B关系,那么Prolog则擅长处理这种逻辑上的数据关系,不能和
SQL混为一谈,所以说,Prolog的用途是来处理数据之间关系的,而不是存储数据本质的存在。
参考资料
Warning: Invalid argument supplied for foreach() in
/www/wwwroot/newbaike1.com/id.php on line
362