ImageVerifierCode 换一换
格式:DOCX , 页数:14 ,大小:61.12KB ,
资源ID:13227471      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/13227471.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(人工智能小型动物分类专家系统的设计与实现PPTWord下载.docx)为本站会员(b****1)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

人工智能小型动物分类专家系统的设计与实现PPTWord下载.docx

1、该动物是食肉动物规则7:动物是哺乳动物,且有蹄该动物是有蹄动物规则8:动物是哺乳动物,且是反刍动物规则9:动物是哺乳动物,且是食肉动物,且是黄褐色的,且有暗斑点该动物是豹规则10:动物是黄褐色的,且是哺乳动物,且是食肉,且有黑条纹该动物是虎规则11: 动物有暗斑点,且有长腿,且有长脖子,且是有蹄类该动物是长颈鹿规则12:动物有黑条纹,且是有蹄类动物该动物是斑马规则13:动物有长腿,且有长脖子,且是黑色的,且是鸟,且不会飞该动物是鸵鸟规则14:动物是鸟,且不会飞,且会游泳,且是黑色的该动物是企鹅规则15:动物是鸟,且善飞该动物是信天翁 动物分类专家系统由15条规则组成,可以识别七种动物,在15条

2、规则中,共出现 30个概念(也称作事实),共30个事实,每个事实给一个编号,从编号从1到30,在规则对象中我们不存储事实概念,只有该事实的编号,同样规则的结论也是事实概念的编号,事实与规则的数据以常量表示,其结构如下:Char *str=chew_cud,hoovesmammalforward_eyesclaws, pointed_teetheat_meatlay_eggsflyfeathersungulate, carnivorebirdgive_milkhas_hairfly_wellblack&white_colorcan_swimlong_legslong_neckblack_stri

3、pesdark_spotstawny_coloralbatrosspenguinostrichzebragiraffetigercheetah0程序有编号序列的方式表达了产生式规则,如资料中规则15,如果动物是鸟,且善飞,则该动物是信天翁。相应的规则数组第七条是16,13,0,0,0,0,第十三个是“bird”(鸟),如果事实成立,询问使用者下一个事实,第十六个“fly_well”(善飞),如果也成立,则查找结论断言编号数组30,29,28,27,26,25,24,3,3,13,12,12,11,11,0中第七个“24”,这里24对应事实数组中的“albatross”(信天翁)。上述就是程序的

4、推理过程,也是程序中的重点,该部分是由规则类(类rule)中的Query方法实现。三、 实验原理一个基于规则专家系统的完整结构示于图1。其中,知识库、推理机和工作存储器是构成专家系统的核心。系统的主要部分是知识库和推理引擎。知识库由谓词演算事实和有关讨论主题的规则构成。推理引擎由所有操纵知识库来演绎用户要求的信息的过程构成如消解、前向链或反向链。用户接口可能包括某种自然语言处理系统,它允许用户用一个有限的自然语言形式与系统交互;也可能用带有菜单的图形接口界面。解释子系统分析被系统执行的推理结构,并把它解释给用户。 图1 一个基于规则专家系统的完整结构四、 实验环境 开发工具采用Microsft

5、 Visual C+6.0 集成开发工具或C,其它C+工具任选,如采用数据库完成知识库,数据库管理系统采用Sql Server 2000.五、 实验步骤知识库中的知识源于领域专家,它是问题求解所需要的领域知识的集合,包括基本事实、规则和其它有关信息。步骤一:知识获取与知识表示选择/设计1. 知识的获取获取专业领域所涉及到的知识内容。上图是从规则集所形成的(部分)推理网络。2、知识的表达 由步骤1获取的知识集合中的内容,包括定性信息和定量信息,对于定性信息必须制定相应的规则来表达知识的含义。也是知识库建立的重点。3、建立知识库步骤二:简单推理机设计推理机是实施问题求解的核心执行机构,它是对知识进

6、行解释的程序,根据知识的语义,对按一定策略找到的知识进行解释执行,并把结果记录到动态库的适当空间中去。推理策略包括:1、正向(数据驱动)2、反向(目标驱动)3、双向 本实验用正向推理策略来完成,实现推理机的程序与知识库的具体内容无关,对知识库的修改不需要改动推理机。本步骤具体包括:1、充分理解知识库现有知识,提出待解决问题2、建立规则库3、从规则库中获取可用规则集4、确定搜索控制策略(例如:估价函数策略)5、通过搜索控制策略,从规则集中选出最优规则6、执行最优规则,更新知识库7、反复多次以上步骤8、获得解决方案或无解步骤三:系统调试与测试先熟悉语言环境;接着运行示例程序;然后编辑、调试、测试自

7、己的系统程序。程序的流程主要是:1、实例化各个类2、初始化事实集3、初始化规则集4、使用规则对事实进行推导规则类:规则名只是用来表示规则的一个名称,前提链由前提类生成的单链表,结论则是存放结论断言编号,表示由该规则的到的结论在事实数组中的编号。事件类:事实号和规则数据和结论断言数据的数字相对应。激活标志表示这个时候有没有被处理过。断言保存推理后的结论,在重复查询这个事实条件时不用反复询问用户。六、 实验思考题1、 专家系统的设计和开发方法与其它软件的设计和开发的方法有什么不同?2、如果使用数据库管理系统中建立知识库,程序如何实现?附程序参考源代码:#include math.hstdio.hi

8、ostream.h#define True 1#define False 0#define DontKnow -1char *str=,0;int rulep6=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;int rulec=30,

9、29,28,27,26,25,24,3,3,13,13,12,12,11,11,0;class factprivate: int Number; char Name21; int Active; int Succ;public: fact *Next; fact(int Num,char *L) strcpy(Name,L); Number=Num; Active=False; /-1是已经推理,不符合。1是已经推理,符合。 Succ=DontKnow; /0是无,-1是不知道,1是有。 Next=NULL; char *GetName() char *L; L=new char21; str

10、cpy(L,Name); return L; int GetNumber() return Number; int GetAct() return Active; int GetSucc() return Succ; void PutAct(const int Act0,int Suc0) Active=Act0; Succ=Suc0;fact *Fact;class list list *Next; list(int Num)class rulechar *Name;list *Pre;int Conc; rule *Next; rule(char *N,int P,int C); rule

11、(); int Query(); void GetName() coutNext; delete Pre; Pre=L;delete Name;rule(char *N,int P,int C)int i;Pre=NULL;Next=NULL;Name=new charstrlen(N)+1;strcpy(Name,N);i=0;while(Pi!=0) L=new list(Pi+); L-Next=Pre;Conc=C;int rule:Query()char c;int Tag=0;fact *F;F=Fact;L=Pre;if(L=NULL)nError;while(L!=NULL) F=Fac

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1