基于产生式规则的动物识别系统(Python)

基于产生式规则的动物识别系统(Python)产生式:一组产生式,互相配合/协调,其中一个产生式产生的结论可以作为另一个产生式的事实使用,以求解问题如下图为产生式系统的基本结构:产生式系统的基本结构规则库:用于描述相应领域内过程性知识的产生式集合。对知识进行合…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

产生式:一组产生式,互相配合/协调,其中一个产生式产生的结论可以作为另一个产生式的事实使用,以求解问题

如下图为产生式系统的基本结构:

基于产生式规则的动物识别系统(Python)

                                                                                    产生式系统的基本结构 

规则库:用于描述相应领域内过程性知识的产生式集合。对知识进行合理的组织与管理,提高问题求解效率。

综合数据库: 综合数据库(事实库、上下文、黑板等):存放问题求解过程中的各种信息的数据结构,包括初始状态、原始证据、中间结论、最终结论,其内容在推理过程中在动态、不断变化的。

控制系统(推理机构):由一组程序组成,负责整个产生式系统的运行,实现对问题的求解。

控制系统要做以下几项工作:

              (1)从规则库中选择与综合数据库中的已知事实进行匹配。

              (2)匹配成功的规则可能不止一条,进行冲突消解。

              (3)执行某一规则时,如果其右部是一个或多个结论,则把这些结论加入到综合数                          据库中:如果其右部是一个或多个操作,则执行这些操作。

             (4)对于不确定性知识,在执行每一条规则时还要按一定的算法计算结论的不确定                         性。    

             (5)检查综合数据库中是否包含了最终结论,决定是否停止系统的运行。

问题描述:基于产生式规则的动物识别系统——识别虎、金钱豹、斑马、长颈鹿、鸵鸟、企鹅、信天翁等七种动物的产生式系统。

              1.以动物识别系统的产生规则为例,建造规则库和综合数据库,并能对他们进行添加、删除和修改操作

              2.基于建立的规则库和综合数据库,进行推理

              3.可以使用任何语言,需要有日志说明推理结果的解释

              产生式规则如下:

                                        

基于产生式规则的动物识别系统(Python)

              解决思路如下:

                                     前提条件:将每一个前提条件转换为一个对应的唯一的一个数学数字

基于产生式规则的动物识别系统(Python)

                                    中间结论:

基于产生式规则的动物识别系统(Python)

                                    结论: 

基于产生式规则的动物识别系统(Python)

                                   产生式规则转换如下:

基于产生式规则的动物识别系统(Python)

                                   Python代码如下:

#动物识别系统
#自定义函数,判断有无重复元素
def judge_repeat(value,list=[]):
    for i in range(0,len(list)):
        if(list[i]==value):
            return 1
        else:
            if(i!=len(list)-1):
                continue
            else:
                return 0
#自定义函数,对已经整理好的综合数据库real_list进行最终的结果判断           
def judge_last(list):
    for i in list:
        if(i=='23'):
            for i in list:
                if(i=='12'):
                    for i in list:
                        if(i=='21'):
                            for i in list:
                                if(i=='13'):
                                     print("黄褐色,有斑点,哺乳类,食肉类->金钱豹\n")
                                     print("所识别的动物为金钱豹")
                                     return 0
                                elif(i=='14'):
                                    print("黄褐色,有黑色条纹,哺乳类,食肉类->虎\n")
                                    print("所识别的动物为虎")
                                    return 0

        
        elif(i=='14'):
            for i in list:
                if(i=='24'):
                    print("有黑色条纹,蹄类->斑马\n")
                    print("所识别的动物为斑马")
                    return 0   
        elif(i=='24'):
            for i in list:
                if(i=='13'):
                    for i in list:
                        if(i=='15'):
                            for i in list:
                                if(i=='16'):
                                    print("有斑点,有黑色条纹,长脖,蹄类->长颈鹿\n")
                                    print("所识别的动物为长颈鹿")
                                    return 0
        elif(i=='20'):
            for i in list:
                if(i=='22'):
                    print("善飞,鸟类->信天翁\n")
                    print("所识别的动物为信天翁")
                    return 0

        elif(i=='22'):
            for i in list:
                if(i=='4'):
                    for i in list:
                        if(i=='15'):
                            for i in list:
                                if(i=='16'):
                                    print("不会飞,长脖,长腿,鸟类->鸵鸟\n")
                                    print("所识别的动物为鸵鸟")
                                    return 0
        elif(i=='4'):
            for i in list:
                if(i=='22'):
                    for i in list:
                        if(i=='18'):
                            for i in list:
                                if(i=='19'):
                                    print("不会飞,会游泳,黑白二色,鸟类->企鹅\n")
                                    print("所识别的动物企鹅")
                                    return 0
                                
        else:
            if(list.index(i) != len(list)-1):
                continue
            else:
                print("\n根据所给条件无法判断为何种动物")
    
dict_before={'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':'信天翁'}
print('''输入对应条件前面的数字:
                                *******************************************************
                                *1:有毛发  2:产奶  3:有羽毛  4:不会飞  5:会下蛋          *
                                *6:吃肉  7:有犬齿  8:有爪  9:眼盯前方  10:有蹄         *
                                *11:反刍  12:黄褐色  13:有斑点  14:有黑色条纹  15:长脖 *
                                *16:长腿  17:不会飞  18:会游泳  19:黑白二色  20:善飞   *
                                *21:哺乳类  22:鸟类  23:食肉类  24:蹄类              *
                                *******************************************************
                                *******************当输入数字0时!程序结束***************
     ''' )
#综合数据库
list_real=[]
while(1):
#循环输入前提条件所对应的字典中的键
    num_real=input("请输入:")
    list_real.append(num_real)
    if(num_real=='0'):
        break
print("\n")
print("前提条件为:")
#输出前提条件
for i in range(0,len(list_real)-1):
    print(dict_before[list_real[i]],end=" ")
print("\n")
print("推理过程如下:")
#遍历综合数据库list_real中的前提条件
for i in list_real:
    if(i=='1'):
        if(judge_repeat('21',list_real)==0):
            list_real.append('21')
            print("有毛发->哺乳类")
    elif(i=='2'):
        if(judge_repeat('21',list_real)==0):
            list_real.append('21')
            print("产奶->哺乳类")
    elif(i=='3'):
        if(judge_repeat('22',list_real)==0):
            list_real.append('22')
            print("有羽毛->鸟类")
    else:
        if(list_real.index(i) !=len(list_real)-1):
            continue
        else:
            break
for i in list_real:
    if(i=='4'):
        for i in list_real:
            if(i=='5'):
                if(judge_repeat('22',list_real)==0):
                    list_real.append('22')
                    print("不会飞,会下蛋->鸟类")
    elif(i=='6'):
        for i in list_real:
            if(i=='21'):
                if(judge_repeat('21',list_real)==0):
                    list_real.append('21')
                    print("食肉->哺乳类")
    elif(i=='7'):
        for i in list_real:
            if(i=='8'):
                for i in list_real:
                    if(i=='9'):
                        if(judge_repeat('23',list_real)==0):
                            list_real.append('23')
                            print("有犬齿,有爪,眼盯前方->食肉类")
    elif(i=='10'):
        for i in list_real:
            if(i=='21'):
                if(judge_repeat('24',list_real)==0):
                    list_real.append('24')
                    print("有蹄,哺乳类->蹄类")
                    
    elif(i=='11'):
        for i in list_real:
            if(i=='21'):
                if(judge_repeat('24',list_real)==0):
                    list_real.append('24')
                    print("反刍,哺乳类->哺乳类")
                    
    else:
        if(i !=len(list_real)-1):
            continue
        else:
            break

judge_last(list_real)

    

Jetbrains全家桶1年46,售后保障稳定

 编者赠语:

这是我大学的一次课堂小作业,就用Python(3.5)实现了一下,其实除此动物识别系统还有一个相似的植物水果识别系统(我也用Python实现了),我就不再次赘余了,如果还有不懂的那就看一下我的实验报告吧!

 

 

 

                                                   

 

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/206764.html原文链接:https://javaforall.net

(0)
上一篇 2025年8月4日 下午11:01
下一篇 2025年8月4日 下午11:43


相关推荐

  • vs2013下载地址_vs2013使用

    vs2013下载地址_vs2013使用微软已经向MSDN订阅用户提供了VisualStudio2013正式版镜像下载,不过非MSDN用户可以在微软的VisualStudio2013官方网站上下载到正式版镜像(通过下载专业版本,已验证与MSDN版本一致)。下面为大家整理一下个版本下载地址。MicrosoftVisualStudioUltimate2013(简体中文旗舰版)文件名: cn_visual_studio…

    2025年10月25日
    7
  • 怎么使用JavaScript代码?

    怎么使用JavaScript代码?一 简介 HTML 文件使用 JavaScript 代码 有三种方式 1 直接写入 DOCTYPE tml htmllang zh CN head metacharset utf 8 title 加载 JavaScript 的方法 title script 法一 加载 JavaScript 代码 document script metacharset utf 8 head htmllang zh CN

    2026年3月17日
    2
  • 总结Redis Cluster原理+基本使用+运维注意事项「建议收藏」

    目录一、RedisCluster数据分布理论选择(一)数据分布关注点(二)三种数据分布方案的对比1.节点取余分区方案2.一致性哈希分区方案3.虚拟槽分区方案(RedisCluster采用此方案)二、RedisCluster节点通信概述(一)Gossip消息(二)消息格式分析(三)消息处理流程(四)节点选择(五)通信流程总述三、搭建集群与简单…

    2022年4月14日
    41
  • 浅谈C++中的多线程(一)

    浅谈C++中的多线程(一)本篇文章围绕以下几个问题展开 何为进程 何为线程 两者有何区别 何为并发 C 中如何解决并发问题 C 中多线程的语言实现 同步互斥原理以及多进程和多线程中实现同步互斥的两种方法 Qt 中的多线程应用引入传统的 C C 98 中并没有引入线程这个概念 linux 和 unix 操作系统的设计采用的是多进程 进程间的通信十分方便 同时进程之间互相有着独立的空间 不会污染其他进程的数

    2026年3月17日
    2
  • 端口号22是哪个协议_https端口号是多少

    端口号22是哪个协议_https端口号是多少https端口:443  服务项目:Https  网页浏览端口,能提供加密和通过安全端口传输的另一种HTTP,简单来说,就是HTTP安全版,打开的网页中,如果网址前缀为https,则说明该网站开启了  https安全访问。  说明:443端口用于网页浏览,关闭电脑443端口,将会导致https网页无法正常打开。  HTTP:80端口  服务:HTTP  说明:用于网页

    2026年1月15日
    5
  • 高手解决DISK BOOT FAILURE,INSERT SYSTEM DISK AND PRESS ENTER

    高手解决DISK BOOT FAILURE,INSERT SYSTEM DISK AND PRESS ENTER1、首先要先确定你加电启动的时候有没有认出你的硬盘。这点在bios里可查。如果开机「滴」的一声短声,证明开机自检没问题(排除硬件问题,但不包括硬盘没有识别)。此时按del键进入bios,看你的硬盘有没

    2022年7月4日
    26

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号