博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
动物产生式识别系统
阅读量:6279 次
发布时间:2019-06-22

本文共 5407 字,大约阅读时间需要 18 分钟。

  摘要:构造知识型系统和建立认知模型时常用的知识表示的形式系统。1943年E.波斯特首先将他提出的一种计算形式体系命名为产生式系统。50年代末期,A.纽厄尔和H.A.西蒙在研究人类问题求解的认知模型时也使用了产生式系统这一术语。产生式系统现代已成为研制人工智能系统时采用的最典型的体系结构之一。本文主要论述计算机科学与技术专业大三下专业课《人工智能》第三个实验算法。

关键字:人工智能,专家系统,产生式系统
Production system

Abstract: Constructs the knowledge system and cognitive model often used in the form of knowledge representation system. E. 1943 post first will he come up with a form of computing system named production system. The late 50 s, a. Newell and H.A. Simon in the study of human cognitive model of problem solving when the term is also used by the production system. Production system has become an artificial intelligence system in modern times, with one of the most typical architecture. This paper mainly discusses the computer science and technology under the junior in professional class "artificial intelligence" third experiment algorithm.

 

Keywords: Artificial intelligence, expert system, production system

1,问题重述 

  通过理解并体会知识库与控制系统相互独立的智能产生式系统与一般程序的区别,为以后设计并实现复杂的专家系统奠定基础。

知识表示为产生式知识表示方法,设计并实现具有15条规则能自动识别7种动物的产生式系统。知识库与控制系统相互独立,系统完成后除了能识别已有的7种动物外,按产生式知识表示方法向知识库中添加、修改新的知识后,系统能在不修改控制系统程序的情况下仍然能正确识别。

 图片

2,问题分析

2.1.事实的表示:

事实可看成是断言一个语言变量的值或是多个语言变量间的关系的陈述句,语言变量的值或语言变量间的关系可以是一个词。不一定是数字。一般使用三元组(对象,属性,值)或(关系,对象1,对象2)来表示事实,其中对象就是语言变量,若考虑不确定性就成了四元组表示(增加可信度)。这种表示的机器内部实现就是一个表

2.2.规则的表示:

规则用于表示事物间的因果关系,以if conditionthen action 的单一形式来描述,将规则作为知识的单位。其中的condition 部分称为条件式前件或模式,而action部分称作动作、后件或结论。

产生式一般形式为:前件     后件。前件和后件也可以是有“与”、“或”、“非”等逻辑运算符的组合的表达式。条件部分常是一些事实的合取或析取,而结论常是某一事实B。如果不考虑不确定性,需另附可信度度量值。

产生式过则的含义是:如果前件满足,则可得到后件的结论或者执行后件的相应动作,即后件由前件来触发。一个产生式生成的结论可以作为另一个产生式的前提或语言变量使用,进一步可构成产生式系统。

蕴涵式表示的知识只能是精确的,产生式表示的知识可以是不确定的,原因是蕴涵式是一个逻辑表达式,其逻辑值只有真和假。蕴含式的匹配一定要求是精确的,而产生式的匹配可以是不确定的,原因是产生式的前提条件和结论都可以是不确定的,因此其匹配也可以是不确定的。 

3,设计文档 

 

<知识库>

<事实>

<条件>

1:有毛发     2:产奶         3:有羽毛      4:会飞 

5:会下蛋     6:吃肉         7:有犬齿      8:有爪

9:眼盯前方   10:有蹄        11:反刍       12:黄褐色

13:有斑点    14:有黑色条纹  15:长脖       16:长腿

17:不会飞    18:会游泳      19:黑白二色   20:善飞

</条件>

<中间结论>

21:哺乳类     22:鸟类     23:食肉类      24:蹄类  

</中间结论>

<结论>

25:金钱豹   26:虎     27:长颈鹿      28:斑马      29:鸵鸟

30:企鹅     31:信天翁

</结论>

</事实>

<规则>

有毛->哺乳类

产奶->哺乳类

有羽毛->鸟类

会飞,会下蛋->鸟类

哺乳类,吃肉->食肉类

有犬齿,有爪,眼盯前方->食肉类

哺乳类,有蹄->蹄类

哺乳类,反刍->蹄类

食肉类,黄褐色,有斑点->金钱豹

食肉类,黄褐色,有黑色条纹->虎

蹄类,长脖,长腿,有斑点->长颈鹿

蹄类,有黑色条纹->斑马

鸟类,长脖,长腿,会飞->鸵鸟

鸟类,会游泳,黑白二色,会飞->企鹅

鸟类,善飞->信天翁

</规则>

</知识库>

 

**规则符号化

1->21                  //有毛->哺乳类

2->21                  //产奶->哺乳类

3->22                  //有羽毛->鸟类

4,5->22                //会飞,会下蛋->鸟类

21,6->23               //哺乳类,吃肉->食肉类

7,8,9->23              //有犬齿,有爪,眼盯前方->食肉类

21,10->24              //哺乳类,有蹄->蹄类

21,11->24              //哺乳类,反刍->蹄类

23,12,13->25           //食肉类,黄褐色,有斑点->金钱豹

23,12,14->26           //食肉类,黄褐色,有黑色条纹->虎

24,15,16,13->27        //蹄类,长脖,长腿,有斑点->长颈鹿

24,14->28              //蹄类,有黑色条纹->斑马

22,15,16,4->29         //鸟类,长脖,长腿,会飞->鸵鸟

22,18,19,4->30         //鸟类,会游泳,黑白二色,会飞->企鹅

22,20->31              //鸟类,善飞->信天翁

 

**

**测试用例

 

2,10,13,15,16 -> 27

产奶,有蹄,有斑点,长脖,长腿 -> 长颈鹿

 

*/

 

4,程序设计

图片

图片
 
1 #include
2 #include
3 #include
4 #include
5 #include
6 7 using namespace std; 8 9 const int fact_num = 31; //知识库中的知识:31种知识 10 const int rule_num = 15; //知识库中的规则:15条规则 11 const int rule_volume = 4; //规则中每个结果最多有4个前提条件 12 const int object_range_begin = 25; //从第25个知识开始 13 const int object_range_end = 31; //到第31个知识为目标结论 14 const int object_middle_begin = 21; //中间结果起始位置 15 16 string fact[fact_num] = 17 { 18 "有毛发","产奶","有羽毛","会飞","会下蛋", 19 "吃肉","有犬齿","有爪","眼盯前方","有蹄", 20 "反刍","黄褐色","有斑点","有黑色条纹","长脖", 21 "长腿","不会飞","会游泳","黑白二色","善飞", 22 "哺乳类","鸟类","食肉类","蹄类","金钱豹", 23 "虎","长颈鹿","斑马","鸵鸟","企鹅","信天翁" 24 }; 25 26 int rule_prerequisite[rule_num][rule_volume] = 27 { 28 {
1,0,0,0}, 29 {
2,0,0,0}, 30 {
3,0,0,0}, 31 {
4,5,0,0}, 32 {
21,6,0,0}, 33 {
7,8,9,0}, 34 {
21,10,0,0}, 35 {
21,11,0,0}, 36 {
23,12,13,0}, 37 {
23,12,14,0}, 38 {
24,15,16,13}, 39 {
24,14,0,0}, 40 {
22,15,16,4}, 41 {
22,18,19,4}, 42 {
22,20,0,0} 43 }; 44 45 int rule_result[rule_num] = 46 { 47 21, 48 21, 49 22, 50 22, 51 23, 52 23, 53 24, 54 24, 55 25, 56 26, 57 27, 58 28, 59 29, 60 30, 61 31 62 }; 63 64 bool backward_reasoning(int num,int message[]) ; 65 bool inference(int num,int message[]) //迭代推理机 66 { 67 int ii, ij, ik,im,in; 68 int hit_num = 0; //输入前提也规则前提重合数 69 int prerequisite_num; //规则前提数 70 int *message_c; //迭代前提 71 int num_c; //迭代前提数量 72 for (ik = 0; ik < num; ik++) //剪枝函数 73 { 74 if (message[ik] >= object_range_begin&&message[ik] <= object_range_end) 75 { 76 cout << "归并信息:" << fact[message[ik] - 1] << endl; 77 cout << "推理成功!" << endl<
"<
<
<<"命中率:"<
<
=object_middle_begin)226 {227 best_hit_rule_rate=hit_rule_rate[ii];228 best_hit_rule_number=ii;229 }230 }231 if(best_hit_rule_number==-1)232 {233 cout<<"您输入的信息对本系统无效!按任意键退出..."<
<
>input;265 if(input=='n')266 {267 new_message=new int[num];268 for(ik=0;ik
=object_middle_begin-1)301 {302 continue;303 }304 for(ij=0;ij
>input;324 if(input=='n')325 {326 break;327 }328 else if(input=='y')329 {330 new_message=new int[num+1];331 for(int iq=0;iq
> num;371 message = new int[num];372 cout << "请输入已有信息:(不重复的数字,以空格隔开)" << endl;373 for (ii = 0; ii < num; ii++)374 {375 cin >> message[ii];376 }377 cout << endl << "初始信息:";378 for (ij = 0; ij < num; ij++)379 {380 cout << fact[message[ij]-1] << " ";381 }382 cout << endl<

 

转载地址:http://grnva.baihongyu.com/

你可能感兴趣的文章
@RequestMapping 用法详解之地址映射
查看>>
254页PPT!这是一份写给NLP研究者的编程指南
查看>>
《Data Warehouse in Action》
查看>>
String 源码浅析(一)
查看>>
Spring Boot 最佳实践(三)模板引擎FreeMarker集成
查看>>
Fescar 发布 0.2.3 版本,支持 Redis 和 Apollo
查看>>
Google MapReduce到底解决什么问题?
查看>>
CCNP-6 OSPF试验2(BSCI)
查看>>
Excel 2013 全新的图表体验
查看>>
openstack 制作大于2TB根分区自动扩容的CENTOS镜像
查看>>
Unbuntu安装遭遇 vmware上的Easy install模式
查看>>
几个常用的ASP木马
查看>>
python分析postfix邮件日志的状态
查看>>
Mysql-5.6.x多实例配置
查看>>
psutil
查看>>
在git@osc上托管自己的代码
查看>>
机器学习算法:朴素贝叶斯
查看>>
小五思科技术学习笔记之扩展访问列表
查看>>
使用Python脚本检验文件系统数据完整性
查看>>
使用MDT部署Windows Server 2003 R2
查看>>