1、2.3解答:设有如下四个谓词: HUMAN(X) X是人 LAWED(X) X受法律管制 COMMIT(X) X犯法 PUNISHED(X) X受法律制裁前两个谓词可以变为:HUMAN(X) LAWED(X),表示:人人都要受法律的管制;后两个谓词可以变为:COMMIT(X) PUNISHED(X),表示只要X犯了罪,X就要受到惩罚;进一步,还可以把上述两个谓词联结成如下形式: HUMAN(X) LAWED(X) COMMIT(X) PUNISHED(X)本公式的含义是:如果由于某个X是人而受到法律管制,则这个人犯了罪就一定要受到惩罚。晁盖是人,受法律的管制(老百姓受法律的管制);所以晁盖劫了
2、生辰纲,违反了宋王朝的法律,一定要受到官府的追究。高衙内是人,却不受法律的管制(达官贵人和恶少不受法律的管制);所以高衙内强抢民女,同样是违反了宋王朝的法律,却可以横行无忌。2.4解答:题中提供的条件可记为,依次利用这些条件可得到如下结果:(1)条件:周和钱是同一性别; 条件:李、徐、周是同一性别; 条件:李的爱人是陈的爱人的表哥,则李的爱人性别是男,而李的性别是女推得:陈与钱是夫妻这样可以初步推出:李、徐、周、钱均是女的,对应的王、陈、孙、吴均是男的。(2)条件:陈与徐、周俊不构成夫妻,则陈选择的余地为钱或李;李与陈不构成夫妻; 条件:吴与徐、周均不构成夫妻,则吴选择的余地为李;吴与李是夫妻
3、 条件:王与周不构成夫妻,则王选择的余地为徐;王与徐是夫妻排除上述已经成立的条件,显然可推得:孙与周是夫妻。2.5解答:符号微积分基本公式为用产生式表示为:If f(x) and (a,b) Then F(b)-F(a)2.6解答:题中描述的情况用谓词形式可表达如下:DOG(X) X是狗SOUND(X) X会吠叫BIT(X,Y) X咬YANIMAL(X) X是动物题中各条推理则可以表示为:P1: x DOG(X) yBIT(X,Y)SOUND(X)P2: : x(ANIMAL(X) SOUND(X) yBIT(X,Y)P3: 猎犬是狗,即DOG(X)种X的谓词样品是猎犬,同时也可得ANIMAL
4、(猎犬)将P3带入P1可得SOUND(猎犬),再将SOUND(猎犬)和ANIMAL(猎犬)带入P2可得 yBIT(猎犬,Y),即可以得到结果:猎犬是咬人的。2.7解答:题中的三条规则侧重点不同:R1规则的重点在于我师的任务;R2规则的重点在于敌团的配置;R3规则的重点在于我师的任务和敌团的配置同时满足。它们之间的关系为R1 R2 R3。 所以根据冲突解决规则中的规模排序,可知首先应该选择规则R3,系统执行才最有效。2.8 解答:2.9 解答:2.10 解答:2.11解答:在产生式系统中,随着产生式规则的数量的增加,系统设计者难以理解规则间的相互作用,究其原因,在于每条规则的自含性使得知识表示的
5、力度过于细微。因此要提高产生式系统的可理解性,就应当按照软件工程的思想,通过对规则的适当划分,将规则组织诚易于管理的功能模块。由于框架系统具有组织成块知识的良好特性,因此将两者进行有机结合,可以为产生式系统的开发、调试和管理提供有益的帮助。基于框架的表示机制可以用作产生式语言和推理机制设计的一个重要构件。另外,框架可以直接用于表示规则,如果将每一个规则作为一个框架处理,一组用于解决特定问题的规则可组织成一类,且在这一类框架中表示这组规则的各种特性。2.12 解答:略2.13 解答:(1)题目描述可转换为如下问题(N阶汉诺塔问题)有编号为A、B、C 的三个柱子和标识为1、2、N的尺寸依次从小到大
6、的N个有中心孔的金片;初始状态下N个金片按1、2、N 顺序堆放在A号柱子上,目标状态下N个金片以同样次序顺序堆放在B 号柱子上,金片的搬移须遵守以下规则:每次只能搬一个金片,且较大金片不能压放在较小金片之上,可以借助于C针。(2)假设基本操作为move(x,A,C,B),表示将x个金片从A移到B上,中间可借助于C。当N=1时,则无需借助中间的C针,就可以直接实现将1个金片从A移到B上,这也是问题的最简操作,可表示为move-one(1,A,B);当N1时,需要用中间的C针作辅助。其操作又可分为以下三步: 将N-1个金片从A移到C上,中间可借助于B,转换为基本操作就是move(N-1,A, B,
7、 C); 将1个金片直接从A移到B上,转换为基本操作就是move-one(1,A,B); 将N-1个金片从C移到B上,中间可借助于A,转换为基本操作就是move(N-1, C, A, B);这样,就将问题的规模减小为N-1,依次递归求解就可以得到相应的结果。(3)设M(x)表示移动x个金片所需要的操作次数,则上述N阶汉诺塔问题可以表示成如下形式:M(1)=1M(N)=2M(N-1)+1最后可以解得M(N)=2N-1下面给出对梵塔问题给出产生式系统描述,并讨论N为任意时状态空间的规模。(1)综合数据库定义三元组:(A, B, C),其中A, B, C分别表示三根立柱,均为表,表的元素为1N之间的
8、整数,表示N个不同大小的盘子,数值小的数表示小盘子,数值大的数表示大盘子。表的第一个元素表示立柱最上面的柱子,其余类推。(2)规则集为了方便表示规则集,引入以下几个函数:first(L):取表的第一个元素,对于空表,first得到一个很大的大于N的数值。tail(L):取表除了第一个元素以外,其余元素组成的表。cons(x, L):将x加入到表L的最前面。规则集:r1: IF (A, B, C) and (first(A) first(B) THEN (tail(A), cons(first(A), B), C)r2: first(C) THEN (tail(A), B, cons(first
9、(A), C) r3: IF (A, B, C) and (first(B) first(C) THEN (A, tail(B), cons(first(B), C)r4: first(A) THEN (cons(first(B), A), tail(B), C)r5: IF (A, B, C) and (first(C) first(A) THEN (cons(first(C), A), B, tail(C)r6: first(B) THEN (A, cons(first(C), B), tail(C) (3)初始状态:(1,2,.,N),(),()(4)结束状态:(),(),(1,2,.,
10、N)问题的状态规模:每一个盘子都有三种选择:在A上、或者在B上、或者在C上,共N个盘子,所以共有种可能。即问题的状态规模为。 2.14 解答: (1)定义谓词G(x,y):x比y大,个体有张三(zhang)、李四(li),将这些个体带入谓词中,得到G(zhang,li)和G(zhang,li),根据语义用逻辑连接词将它们联结起来就得到表示上述知识的谓词公式:G(zhang,li) G(zhang,li)。(2) 定义谓词Marry(x,y):x和y结婚,Male(x):x是男的,Female(x):x是女的。个体有甲(A)、乙(B),将这些个体带入谓词中,得到Marry(A,B)、Male(A
11、)、Female(B)以及Male(A)、Female(B),根据语义用逻辑连接词将它们联结起来就得到表示上述知识的谓词公式:Marry(A,B) (Male(A)Female(B)(Male(B)Female(A)(3) 定义谓词Honest(x):x是诚实的,Lying(x):x会说谎。个体有张三(zhang),将这些个体带入谓词中,得到Honest(x)、Lying(x)、Lying(zhang)、Honest(zhang),根据语义用逻辑连接词将它们联结起来就得到表示上述知识的谓词公式: x (Honest(x) Lying(x) (Lying(zhang) Honest(zhang)
12、第三章 问题求解方法3.1答:深度优先搜索与广度优先搜索的区别在于:在对节点n进行扩展时,其后继节点在OPEN表中的存放位置不同。广度优先搜索是将后继节点放入OPEN表的末端,而深度优先搜索则是将后继节点放入OPEN表的前端。广度优先搜索是一种完备搜索,即只要问题有解就一定能够求出,而深度优先搜索是不完备搜索。 在不要求求解速度且目标节点的层次较深的情况下,广度优先搜索优于深度优先搜索;在要求求解速度且目标节点的层次较浅的情况下,深度优先搜索优于广度优先搜索。 广度优先的正例:积木问题;深度优先的正例:邮递员问题,反例:国际象棋。3.2答:衡量标准为:这组子状态中有没有目标状态,如果有,则选择
13、该节点并且搜索成功;若没有,则按照某种控制策略从已生成的状态中再选择一个状态作为当前状态重复搜索过程。3.3答:(1)广度优先搜索:该程序必须找到解,并且最好是最优解; (2)广度优先搜索:医生要根据病人的各种病状判断病人的病; (3)深度优先搜索:该程序要求一定要找到目标路径; (4)深度优先搜索:该程序要求找到最优解; (5)广度优先搜索:不能确定它们是否等同,既不能确定它们是否有等同解。3.4答:对于四皇后问题,如果放一个皇后的耗散值为1的话,则任何一个解的耗散值都是4。因此如果h是对该耗散值的估计,是没有意义的。对于像四皇后这样的问题,启发函数应该是对找到解的可能性的评价。利用一个位置
14、放皇后后,消去的对角线的长度来进行评价。3.5答:定义h1=M+C-2B,其中M,C分别是在河的左岸的传教士人数和野人人数。B1表示船在左岸,B0表示船在右岸。也可以定义h2=M+C。h1是满足A*条件的,而h2不满足。要说明h2M+C不满足A*条件是很容易的,只需要给出一个反例就可以了。比如状态(1, 1, 1),h2=M+C=1+1=2,而实际上只要一次摆渡就可以达到目标状态,其最优路径的耗散值为1。所以不满足A*的条件。下面我们来证明h1M+C-2B是满足A*条件的。我们分两种情况考虑。先考虑船在左岸的情况。如果不考虑限制条件,也就是说,船一次可以将三人从左岸运到右岸,然后再有一个人将船
15、送回来。这样,船一个来回可以运过河2人,而船仍然在左岸。而最后剩下的三个人,则可以一次将他们全部从左岸运到右岸。所以,在不考虑限制条件的情况下,也至少需要摆渡次。其中分子上的3表示剩下三个留待最后一次运过去。除以2是因为一个来回可以运过去2人,需要个来回,而来回数不能是小数,需要向上取整,这个用符号表示。而乘以是因为一个来回相当于两次摆渡,所以要乘以2。而最后的1,则表示将剩下的3个运过去,需要一次摆渡。化简有:再考虑船在右岸的情况。同样不考虑限制条件。船在右岸,需要一个人将船运到左岸。因此对于状态(M,C,0)来说,其所需要的最少摆渡数,相当于船在左岸时状态(M+1,C,1)或(M,C+1,
16、1)所需要的最少摆渡数,再加上第一次将船从右岸送到左岸的一次摆渡数。因此所需要的最少摆渡数为:(M+C+1)-2+1 。其中(M+C+1)的表示送船回到左岸的那个人,而最后边的,表示送船到左岸时的一次摆渡。(M+C+1)-2+1=M+C。综合船在左岸和船在右岸两种情况下,所需要的最少摆渡次数用一个式子表示为:M+C-2B。其中B1表示船在左岸,B0表示船在右岸。 由于该摆渡次数是在不考虑限制条件下,推出的最少所需要的摆渡次数。因此,当有限制条件时,最优的摆渡次数只能大于等于该摆渡次数。所以该启发函数h是满足A*条件的。3.6答:在搜索期间改善h函数,是一种动态改变h函数的方法。像改进的A*算法
17、中,对NEXT中的节点按g值的大小选择待扩展的节点,相当于令这些节点的h0,就是动态修改h函数的一种方法。由定理2:若h(n)满足单调限制,则由A*所扩展的节点序列,其f值是非递减的,即f(ni)f(nj),当h满足单调条件时,A*所扩展的节点序列,其f是非递减的。对于任何节点i,j,如果j是i的子节点,则有f(i)f(j)。利用该性质,我们可以提出另一种动态修改h函数的方法:f(j)=max(f(i), f(j)以f(j)作为节点j的f值。f值的改变,隐含了h值的改变。当h不满足单调条件时,经过这样修正后的h具有一定的单调性质,可以减少重复节点的可能性。3.7答:像这种类型的问题,由于涉及到
18、城市距离或旅行费用,所以利用代价树广度优先搜索求解。为此,首先必须将旅行交通图转换为代价树,转换方法为:从初始节点A开始,把与它直接相邻的节点作为他的后继节点,对其他节点也作同样的扩展,但若一个节点以作为某节点的前驱节点,则它就不能再作为该结点的后继结点。另外,图中节点除了初始节点A之外,其它的节点都有可能在代价树中多次出现,为了区分它们的多次出现,分别用下标1,2标出。但他们却是图中的同一个节点。设估价函数f(n)=d(n)+w(n),其中d(n)为状态的深度,w(n)为城市间的距离。代价树如下所示:ACEBDA定义h1=n*k,其中n是还未走过的城市数,k是还未走过的城市间距离的最小值。
19、h2,其中n是还未走过的城市数,ki是还未走过的城市间距离中n个最小的距离。 显然这两个h函数均满足A*条件。3.8答:可定义h为:hB右边的W的数目设j节点是i节点的子节点,则根据走法不同,h(i)-h(j)的值和C(i, j)分为如下几种情况:(1)B或W走到了相邻的一个空格位置,此时: h(i)-h(j)=0, C(i,j)=1;(2)W跳过了1或2个W,此时 h(i)-h(j)=0, C(i,j)=1或2;(3)W向右跳过了一个B(可能同时包含一个W),此时: h(i)-h(j)=-1, C(i,j)=1或2;(4)W向右跳过了两个B,此时: h(i)-h(j)=-2, C(i,j)=
20、2;(5)W向左跳过了一个B(可能同时包含一个W),此时: h(i)-h(j)=1, C(i,j)=1或2;(6)W向左跳过了两个B,此时: h(i)-h(j)=2, C(i,j)=2;(7)B跳过了1或2个B,此时 h(i)-h(j)=0, C(i,j)=1或2;(8)B向右跳过了一个W(可能同时包含一个B),此时:(9)B向右跳过了两个W,此时:(10)B向左跳过了一个W(可能同时包含一个B),此时:(11)B向左跳过了两个W,此时:纵上所述,无论是哪一种情况,具有:h(i)-h(j)C(i,j)。且容易验证h(t)=0,所以该h是单调的。由于h满足单调条件,所以也一定有h(n)h*(n)
21、,即满足A*条件。3.9答:3.10答:(1)余一棋的弈法如下:两棋手可以从5个钱币堆中轮流拿走一个、两个或三个钱币,拣起最后一个钱币者算输。试通过博弈证明,后走的选手必胜,并给出一个简单的特征标记来表示取胜策略。为了方便起见,用(AB)()()这样的表表示一个状态。这样得到搜索图如下:(2)八数码问题 空格:Up,Left,Down,Right3.11答:(1)与/或图的解图:那些可解结点的子图,包含一结点到目的结点集的、连通的可解结点的子图。在问题的完整的隐含图中扩展生成出包含初始结点和目的结点集合的连通的明显子图。(2)算法AO*:必须对当前已生成出的与或图中的所有结点实施其每解点是否为
22、可解结点的标注过程,如果起始结点被标注为可解的,则搜索过程可成功地结束;如果起始结点还不能被标注为可解的,则应当继续扩展生成结点(尽可能地记录,所有生成的结点中,哪些结点被标注了可解的,以便减少下一次标注过程的工作量);同样地,对不可解结点也同样如此。 利用结点的可解/不可解性质,能从搜索图中删去可解结点的任何不可解结点的子结点;同样地,能删去不可解结点的所有的子结点(搜索这些被删除的结点是没有意义的,而只会降低搜索的效率)。两个主要过程的反复:自上而下的图生长过程,并通过跟踪有标记的连接符寻找一个候选局部解图自下而上的估价函数值的修正、连接符的标记和SOLVED的标注过程3.12答:此题要求
23、按照课中例题的方式,给出算法,以下是每个循环结束时的搜索图。上面这种做法比较简单,也可以如下做:3.13答:3.14答:博弈搜索通常被限制在一定的范围,搜索的目标是确定一步好的走法(好棋),等对手回手后,再继续搜索。因此,博弈搜索过程总是由当前状态向目标状态搜索,而不是由目标状态向当前状态搜索。这类博弈的实例有西洋跳棋等。3.15答:8(3,0,8)(7,8,3)、(0,6)、(8,9)(7,6)、(8,6,5)、(2,3)、(0,-2)、(6,2)、(5,8)、(9,2)3.16答: 见上图3.17答:3.18答:剪裁算法. 剪裁若极小层的(先辈层)则中止这个MAX以下的搜索 算法如下: d
24、ouble alphabeta( int depth, double alpha, double beta, Position p);/* alpha是MAX的当前值 beta是MIN的当前值,depth 是在搜索树中的深度,p是所求结点的位置*/ double t; if( depth=0 ) return evaluate(p); /* 如果P是叶结点,算出P的值 */ for( i=1; i alpha&MAX) if(t beta) t; /*直接返回*/ else alpha = if( talpha&MIN) if(t alpha=t; alpha;3.19-3.22 答:第四章
25、基本的推理技术4.1答:(1)推理:按照某种策略从已有事实和知识推出结论的过程。 (2)正向推理 正向推理(事实驱动推理)是由已知事实出发向结论方向的推理。 基本思想是:系统根据用户提供的初始事实,在知识库中搜索能与之匹配的规则即当前可用的规则,构成可适用的规则集RS,然后按某种冲突解决策略从RS中选择一条知识进行推理,并将推出的结论作为中间结果加入到数据库DB中作为下一步推理的事实,在此之后,再在知识库中选择可适用的知识进行推理,如此重复进行这一过程,直到得出最终结论或者知识库中没有可适用的知识为止。正向推理简单、易实现,但目的性不强,效率低。需要用启发性知识解除冲突并控制中间结果的选取,其
26、中包括必要的回溯。由于不能反推,系统的解释功能受到影响。 (3)反向推理 反向推理是以某个假设目标作为出发点的一种推理,又称为目标驱动推理或逆向推理。 反向推理的基本思想是:首先提出一个假设目标,然后由此出发,进一步寻找支持该假设的证据,若所需的证据都能找到,则该假设成立,推理成功;若无法找到支持该假设的所有证据,则说明此假设不成立,需要另作新的假设。 与正向推理相比,反向推理的主要优点是不必使用与目标无关的知识,目的性强,同时它还有利于向用户提供解释。反向推理的缺点是在选择初始目标时具有很大的盲目性,若假设不正确,就有可能要多次提出假设,影响了系统的效率。 反向推理比较适合结论单一或直接提出结论要求证实的系统。(4)推理方式分类演绎推理、归纳推理、默认推理 确定性推理、不精确推理 单调推理、非单调推理 启发式推理、非启发式推理 4.2答:(1) 在推理过程中,系统要不断地用数据库中的事实与知识库中的规则进行匹配,当有一个
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1