人工智能动物识别专家系统

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

题目:动物识别专家系统

.实验目的

1. 理解并掌握基于规则系统的表示与推理

2. 学会编写小型的生产式系统,理解正向推理和反向推理的过程以及两者的区别

3. 学会设计简单的人机交互界面

实验内容

动物识别专家系统是流行的专家系统实验模型,它用产生式规则来表示知识,共15 条规则、可以识别七种动物,这些规则既少又简单,可以改造他们,也可以加进新的规则,还可以用来识别其他东西的新规则来取代这些规则。

四.实验要求

1、确定推理方法(正向还是反向),并根据问题设计实现一个简单的不通用推理机(匹配、冲突消解)

2、规则库要求至少包含15 条规则

3、初始事实可以任意给定,输入初始事实后能够得到推理结果

4、设计人机界面,解释模块提供查询规则的功能

5、可以不考虑知识库管理模块

6、提交实验报告,

7、报告中要有推理树

五.实验原理

动物识别专家系统是流行的专家系统实验模型,它用产生式规则来表示知识,共

15 条规则、可以识别七种动物,这些规则既少又简单,可以改造他们,也可以加进新的规则,还可以用来识别其他东西的新规则来取代这些规则。动物识别15条规则:

规则1:如果:动物有毛发则:该动物是哺乳动物

规则2:

如果:动物能产奶

则:该单位是哺乳动物

规则3:

如果:该动物有羽毛

则:该动物是鸟

规则4:

如果:动物会飞,且会下蛋

则:该动物是鸟

规则5:

如果:动物吃肉

则:该动物是肉食动物

规则6:

如果:动物有犬齿,且有爪,且眼盯前方

则:该动物是食肉动物

规则7:

如果:动物是哺乳动物,且有蹄

则:该动物是有蹄动物

规则8:

如果:动物是哺乳动物,且是反刍动物

则:该动物是有蹄动物

规则9:

如果:动物是哺乳动物,且是食肉动物,且是黄褐色的,且有暗斑点则:该动

物是豹

规则10:

如果:如果:动物是黄褐色的,且是哺乳动物,且是食肉,且有黑条纹则:该

动物是虎

规则11:

如果:动物有暗斑点,且有长腿,且有长脖子,且是有蹄类则:该动物是长颈

鹿

规则12:

如果:动物有黑条纹,且是有蹄类动物则:该动物是斑马

规则13:

如果:动物有长腿,且有长脖子,且是黑色的,且是鸟,且不会飞

则:该动物是鸵鸟

规则14:

如果:动物是鸟,且不会飞,且会游泳,且是黑色的则:该动物是企鹅规则15:

如果:动物是鸟,且善飞

则:该动物是信天翁

六.推理树

七.代码

#i nclude

#in elude

#include

#i nclude

#defi ne True 1

#defi ne False 0

#defi ne Don tK now -1

char *str[]={"chew_cud 反刍动物","hooves 蹄类动物","mammal 哺乳动物","forward_eyes 眼盯前方",

"claws 有爪","pointed_teeth 有犬齿","eat_meat 吃肉","lay_eggs 会下蛋","fly 会飞", "feathers有羽毛","ungulate 有蹄"「carnivore 食肉动物","bird 鸟",”give_milk 能产奶II

J

"has_hair有毛发","fly_well 善飞","black&white_color 黑白色","can_swim 会游泳", "long_legs 长腿","long_neck 长脖子","black_stripes 黑条纹","dark_spots 黑斑点", "tawny_color 黄褐色","albatross 信天翁","penguin 企鹅","ostrich 驼鸟","zebra 斑马II J

"giraffe 长颈鹿","tiger 老虎","cheetah猎豹",0};

in t rulep[][6]={{22,23,12,3,0,0},{21,23,12,3,0,0},{22,19,20,11,0,0},

{21,11,0,0,0,0},{17,19,20,13,-9,0},{17,18,13,-9,0,0},{16,13,0,0,0,0},

{15,0,0,0,0,0},{14,0,0,0,0,0},{10,0,0,0,0,0},{8,7,0,0,0,0},

{7,0,0,0,0,0},{4,5,6,0,0,0},{2,3,0,0,0,0},{1,3,0,0,0,0}};

in t rulec[]={30,29,28,27,26,25,24,3,3,13,13,12,12,11,11,0};

class fact {private: int Number; char Name[21]; int Active;

int Succ; public: fact *Next;

fact(i nt Num,char *L) {

strcpy(Name,L); Number=Num; Active=False; Succ=D ontKnow; Next=NULL;

}

char *GetName()

{

char *L;

L=new char[21]; strcpy(L,Name);

return L;

}

int GetNumber()

{

return Number;

}

int GetAct()

{

return Active;

}

int GetSucc()

{

return Succ;

}

void PutAct(co nst int ActO,i nt Suc0)

{

Active=Act0;

相关文档
最新文档