当前位置: 首页 > article >正文

人工智能——猴子摘香蕉问题

一、实验目的

求解猴子摘香蕉问题,根据猴子不同的位置,求解猴子的移动范围,求解对应的过程,针对不同的目标状态进行求解。

二、实验内容

根据场景有猴子、箱子、香蕉,香蕉挂天花板上。定义多种谓词描述位置、状态等。

有从一处走到另一处、推箱子、爬到箱子、拿到香蕉 4 种操作。需输出猴子摘香蕉的四步步骤及对应谓词,从初始状态(猴子位置、箱子位置、香蕉位置,香蕉挂天花板、猴手空、猴不在箱上)达到目标状态(猴拿香蕉且在箱上)。

# -*- coding: utf-8 -*-
'''
人工智能:知识表示:谓词公式表示
实验1:猴子摘香蕉问题  Python代码
'''

'''定义类保存猴子位置、箱子位置、香蕉位置等信息'''
'''
拔高1:输出猴子进行某step之前的状态
拔高2:加入猴子伸手的高度、箱子的高度、香蕉被挂在墙上的高度
拔高3:加入前端代码,增加动画演示
'''
class predicate():
    
    monky = 0
    box = 0
    banana = 0
    monbox = 0
    # 全局变量, 表示步骤Step数量
    iStep = 0  
    
    def __init__(self, monky=0, box=0, banana=0, monbox=0):
        ''' Initialize '''
        self.monky = monky      # 猴子的位置
        self.box = box          # 箱子的位置
        self.banana = banana    # 香蕉的位置
        self.monbox = monbox    # -1(或<0), 猴子不在箱子上
                                # 1(或>=0), 猴子在箱子上
        self.monkyName = 'monky'
        self.boxName = 'box'
        self.bananaName = 'banana'
        self.iStep = 0
        
    def displayInit(self):
        ''' 输出初始位置信息 '''
        self.AT(self.monkyName, self.monky)
        self.BOX(self.box)
        self.BAN(self.banana)
        self.OVER(self.bananaName)
        self.EMPTY(self.monkyName)
        if self.monbox < 0:
            self.NOT_ON(self.monkyName, self.boxName)
        elif self.monbox >= 0:
            self.ON(self.monkyName, self.boxName)
    
    def displayFinal(self):
        ''' 输出最终位置信息 '''
        self.AT(self.monkyName, self.banana)
        self.BOX(self.banana)
        self.BAN(self.banana)
        self.HOLD(self.monkyName, self.bananaName)
        if self.monbox < 0:
            self.NOT_ON(self.monkyName, self.boxName)
        elif self.monbox >= 0:
            self.ON(self.monkyName, self.boxName)

    def AT(self, x, y):
        '''猴子在y位置上'''
        print('--------' + str(x) + '在' + str(y) + '位置上--------')
    
    def BOX(self, y):
        '''箱子在y的位置'''
        print('--------箱子在' + str(y) + '位置上--------')
        
    def BAN(self, y):
        '''香蕉在y的位置'''
        print('--------香蕉在' + str(y) + '位置上--------')
    
    def OVER(self, x):
        '''x被挂在天花版上'''
        print('--------' + str(x) + '被挂在天花版上--------')
    
    def EMPTY(self, x):
        '''x手中是空的'''
        print('--------' + str(x) + '手中是空的--------')
    
    def HOLD(self, x, z):
        '''x拿着z'''
        print('--------' + str(x) + '拿着' + str(z) + '--------')
    
    def ON(self, x, w):
        '''x在w上面'''
        print('--------' + str(x) + '在' + str(w) + '的上面--------')
    
    def NOT_ON(self, x, w):
        '''x不在w的上面'''
        print('--------' + str(x) + '不在' + str(w) + '的上面--------')
    
    
    def monkeyGoBox(self):
        ''' GOTO(x,y):从x处走到y处 '''
        self.iStep = self.iStep + 1
        if self.monky != self.box:
            ''' 猴子与箱子不在同一位置 '''
            print('step' + str(self.iStep) + ': monkey从位置' + str(self.monky) + '走到位置' + str(self.box))
            if self.monbox < 0:
                self.AT(self.monkyName, self.box)
        else:
            ''' 猴子与箱子在同一位置 '''
            print('step' + str(self.iStep) + ': monkey在位置' + str(self.monky) + ', box在位置' + str(self.box) + \
                  ',猴子已经在箱子处')
    
    def monkeyMoveBox(self):
        ''' PUSH(x,y):把箱子从x处推到y处 '''
        self.iStep = self.iStep + 1
        if self.box != self.banana:
            ''' 箱子与香蕉不在同一位置 '''
            print('step' + str(self.iStep) + ': monkey把箱子从位置' + str(self.box) + '运到位置' + str(self.banana))
            self.AT(self.monkyName, self.banana)
            self.AT(self.boxName, self.banana)
        else:
            ''' 箱子与香蕉在同一位置 '''
            print('step' + str(self.iStep) + ': box在位置' + str(self.box) + ', banana在位置' + str(self.banana), \
                  ', 箱子已在香蕉处')

    def monkeyOnBox(self):
        ''' CLIMB(x):从x处爬上箱子 '''
        self.iStep = self.iStep + 1
        print('step' + str(self.iStep) + ': monkey从位置' + str(self.banana) + '处爬上箱子')
        self.ON(self.monkyName, self.boxName)
        self.monbox = 1

    def monkeyGetBanana(self):
        ''' GET(x):从x处得到香蕉 '''
        self.iStep = self.iStep + 1
        print('step' + str(self.iStep) + ': monkey从位置' + str(self.banana) + '处摘到香蕉')
        self.HOLD(self.monkyName, self.bananaName)
        
    def doWork(self):
        ''' main '''
        self.monkeyGoBox()
        self.monkeyMoveBox()
        self.monkeyOnBox()
        self.monkeyGetBanana()

# 只在当前文件作为脚本直接执行时运行,被其他脚本调用时不执行
if __name__ == '__main__':
    monkey = input("请输入猴子位置:")
    banana = input("请输入香蕉位置:")
    box = input("请输入箱子位置:")
    # 创建对象
    p = predicate(monkey, banana, box, -1)
    print('初始位置信息:')
    p.displayInit()
    
    print('操作步骤如下:')
    #请用最少步骤完成猴子摘香蕉任务
    ###########开始#############
    p.doWork()
    
    print('最终位置信息:')
    p.displayFinal()

结果:


http://www.kler.cn/a/311012.html

相关文章:

  • Android OpenGL ES详解——纹理:纹理过滤GL_NEAREST和GL_LINEAR的区别
  • 微服务电商平台课程三:搭建后台服务
  • TCP可靠连接的建立和释放,TCP报文段的格式,UDP简单介绍
  • 产品经理如何使用项目管理软件推进复杂项目按时上线
  • vs2019托管调试助手 “ContextSwitchDeadlock“错误
  • 闯关leetcode——3206. Alternating Groups I
  • centos中yum方式部署Jenkins
  • 【Linux取经之路】编译器gcc/g++的使用 调试器gdb的使用
  • OceanBase 运维管理工具 OCP 4.x 升级:聚焦高可用、易用性及可观测性
  • Vscode搭配latex简易教程
  • file的判断和获取,创建和删除
  • C++使用Socket编程实现一个简单的HTTP服务器
  • 掌握MySQL性能监控 · performance_schema 使用快速入门
  • Linux_bash的一些特殊符号
  • 聚观早报 | 极越07正式上市;宝骏云海正式上市
  • Laya2.x出包alipay小游戏
  • Java后端框架---Spring
  • 每日一问:C++ 如何实现继承、封装和多态
  • 随着访问范围的扩大 OpenAI o1-mini 现已向免费用户开放
  • 大模型训练数据库Common Crawl
  • MySQL常用的函数
  • 函数的定义与使用
  • 【Hot100】LeetCode—169. 多数元素
  • 常见汇编指令
  • C++系列-谓词predicate
  • AWTK fscript 中的 CRC函数