人工智能之A*算法求解

这篇具有很好参考价值的文章主要介绍了人工智能之A*算法求解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

实验目的

熟悉和掌握启发式搜索的定义、估价函数和算法过程

实验平台

Python 3.7 +

实验要求

熟练掌握A*算法的基本原理。分析不同启发式函数对问题求解的提升效果。

  1. 实现A*算法的求解,要求设计两种不同的估价函数:设置相同的初始状态和目标状态,针对不同估价函数,求得问题的届,比较它们对搜索算法性能的影响,包括扩展节点数、生成节点数、运行时间等。
  2. 画出流程图。
  3. 源程序代码

实验结果(可以包含数据集分析、实验过程、结果截图、结果分析等)

  • 八数码问题
  1. 不同的估价函数对搜索算法性能的影响

(1)、曼哈顿距离:曼哈顿距离是八数码问题中常用的估价函数之一。在这个算法中,每个状态都会计算曼哈顿距离,并将距离加入优先队列中。曼哈顿距离具有良好的准确性和高效性,因此在这个算法中表现良好。

(2)、欧几里得距离:欧几里得距离是另一个常用的估价函数。在这个算法中,每个状态都会计算欧几里得距离,并将距离加入优先队列中。与曼哈顿距离相比,欧几里得距离可以更好地反映状态之间的真实距离,但是由于它需要进行平方根计算,因此计算成本更高。

(3)、切比雪夫距离:切比雪夫距离是一种更为简单的估价函数,它只需要取两个状态之间横向和纵向距离的最大值。在这个算法中,每个状态都会计算切比雪夫距离,并将距离加入优先队列中。与曼哈顿距离相比,切比雪夫距离更为简单,计算成本更低,但它可能不如曼哈顿距离那么准确。

  1. 流程图

说明曼哈顿距离和不在位数是否满足a*条件,分析这两个不同启 发函数的a*算法性能;,python,算法,开发语言

源程序代码

from queue import PriorityQueue

# 定义状态类
class State:
    def __init__(self, board, moves, previous):
        self.board = board
        self.moves = moves
        self.previous = previous

    # 定义状态比较函数,用于在优先队列中比较状态
    def __lt__(self, other):
        return self.moves + self.manhattan_distance() < other.moves + other.manhattan_distance()

    # 计算曼哈顿距离
    def manhattan_distance(self):
        distance = 0
        for i in range(3):
            for j in range(3):
                if self.board[i][j] == 0:
                    continue
                x, y = divmod(self.board[i][j] - 1, 3)
                distance += abs(x - i) + abs(y - j)
        return distance

    # 判断状态是否为目标状态
    def is_goal(self):
        return self.board == [[1, 2, 3], [4, 5, 6], [7, 8, 0]]

    # 获取当前状态的下一步状态
    def get_next_states(self):
        next_states = []
        i, j = next((i, j) for i in range(3) for j in range(3) if self.board[i][j] == 0)
        for x, y in ((i+1, j), (i-1, j), (i, j+1), (i, j-1)):
            if 0 <= x < 3 and 0 <= y < 3:
                board = [row[:] for row in self.board]
                board[i][j], board[x][y] = board[x][y], board[i][j]
                next_states.append(State(board, self.moves+1, self))
        return next_states

    # 获取从初始状态到达当前状态的路径
    def get_path(self):
        path = []
        state = self
        while state is not None:
            path.append(state)
            state = state.previous
        return reversed(path)

# A*搜索算法
def solve(start_board):
    start_state = State(start_board, 0, None)
    queue = PriorityQueue()
    queue.put(start_state)
    visited = set()
    while not queue.empty():
        state = queue.get()
        if state.is_goal():
            return state.get_path()
        if tuple(map(tuple, state.board)) in visited:
            continue
        visited.add(tuple(map(tuple, state.board)))
        for next_state in state.get_next_states():
            queue.put(next_state)

    return None

# 测试代码
if __name__ == '__main__':
    start_board = [[1, 2, 3], [4, 5, 6], [0, 7, 8]]
    path = solve(start_board)
    if path is None:
        print("无解")
    else:
        for i, state in enumerate(path):
            print(f"步骤 {i}:")
            for row in state.board:
                print(row)


说明曼哈顿距离和不在位数是否满足a*条件,分析这两个不同启 发函数的a*算法性能;,python,算法,开发语言

  • 5*5迷宫寻路问题
  1. 不同的估价函数对搜索算法性能的影响

(1)、切比雪夫距离估价函数:对于55迷宫的起点和目标点,在网格上可视为同一正方形角落的两个点。因此,用切比雪夫距离可以轻松快速地计算出任意两点之间的代价。使用切比雪夫距离作为估价函数的A算法可以有效地搜索整个网格,直接到达目标点,并尽可能少地探索其他节点。因此,此估价函数能够有效地提高搜索算法性能。

(2)、曼哈顿距离估价函数:曼哈顿距离是指两点之间横向和纵向的距离之和。在5*5迷宫中,使用曼哈顿距离可以快速估算出两点之间的代价,但是这种估价方式会导致搜索算法探索更多的区域,因此相比于切比雪夫距离估价函数,曼哈顿距离估价函数在搜索算法性能方面稍逊一筹。

(3)、欧几里得距离估价函数:欧几里得距离是指两点之间的直线距离。在5*5迷宫中,使用欧几里得距离可以准确地估算出两点之间的代价,但是此估价方式需要更多的计算资源,因此可能会导致搜索算法性能下降。

综上所述,在5*5迷宫寻路问题中,估价函数的选择对搜索算法性能具有重要影响,切比雪夫距离估价函数可以在这个问题中提高搜索算法性能。

  1. 流程图

说明曼哈顿距离和不在位数是否满足a*条件,分析这两个不同启 发函数的a*算法性能;,python,算法,开发语言

源程序代码

import numpy as np
import heapq


class Node:
    def __init__(self, x: int, y: int, parent=None):
        self.x = x
        self.y = y
        self.parent = parent
        self.g = 0
        self.h = 0

    def __lt__(self, other):
        return self.g + self.h < other.g + other.h


def heuristic(a: tuple, b: tuple) -> int:
    return abs(b[0] - a[0]) + abs(b[1] - a[1])


def astar(maze: np.array, start: tuple, end: tuple) -> list:
    open_set = []
    closed_set = set()
    start_node = Node(start[0], start[1])
    end_node = Node(end[0], end[1])
    heapq.heappush(open_set, start_node)

    while len(open_set) > 0:
        current_node = heapq.heappop(open_set)
        if current_node.x == end_node.x and current_node.y == end_node.y:
            path = []
            while current_node is not None:
                path.append((current_node.x, current_node.y))
                current_node = current_node.parent
            return path[::-1]
        closed_set.add((current_node.x, current_node.y))

        for x, y in [(0, -1), (0, 1), (-1, 0), (1, 0)]:
            node = Node(current_node.x + x, current_node.y + y, current_node)
            if node.x < 0 or node.y < 0 or node.x >= maze.shape[0] or node.y >= maze.shape[1]:
                continue
            if maze[node.x][node.y] == 1:
                continue
            if (node.x, node.y) in closed_set:
                continue
            node.g = current_node.g + 1
            node.h = heuristic((node.x, node.y), (end_node.x, end_node.y))
            heapq.heappush(open_set, node)

    return None


if __name__ == '__main__':
    start = (0, 0)
    end = (4, 4)
    maze = np.array([
        [0, 0, 0, 0, 1],
        [1, 1, 1, 0, 1],
        [0, 0, 0, 0, 0],
        [1, 1, 1, 1, 0],
        [1, 1, 1, 1, 0]
    ])

    path = astar(maze, start, end)
    print(path)


说明曼哈顿距离和不在位数是否满足a*条件,分析这两个不同启 发函数的a*算法性能;,python,算法,开发语言

实验总结

通过这次实验,我掌握了如何使用A*搜索算法解决迷宫问题和八数码问题。这是一种常用的人工智能搜索算法,可以用于寻找路径和规划。

在实验中,首先学习了迷宫问题的定义和A算法的基本思路。我们使用Python编写代码,在55大小的迷宫中,通过A*算法计算出从起点到终点的最短路径。其中,需要考虑迷宫的障碍物、每个节点的代价值和启发式函数等因素,也需要用到优先队列来存储待扩展的节点。最后,通过绘制迷宫地图和标注路径,完成了实验任务。

接着,学习了八数码问题的定义和A算法的适用性。同样利用Python编写代码,通过A算法计算出从初始状态到目标状态的最短路径。在实验中,为了提高算法效率和减少搜索深度,设计了一种简单而可行的启发式函数,并使用优先队列存储待扩展的节点,最终完成了实验任务。

通过这次实验,除了掌握了A*搜索算法的应用,还进一步了解了Python的函数定义语法和相关知识,同时也加深了对算法原理和机制的理解。文章来源地址https://www.toymoban.com/news/detail-794498.html

到了这里,关于人工智能之A*算法求解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【复习】人工智能 第六章 搜索求解策略(又多又难)

    在求解一个问题时,涉及到两个方面: (1)该问题的表示 (2)相对合适的求解方法:由于绝大多数需要人工智能方法求解的问题缺乏直接求解的方法,因此, 搜索 为一种求解问题的一般方法。 另外如果真的想拿下这一章,还是走一下ppt或书上的八数码的对应的每一种情况

    2024年01月16日
    浏览(54)
  • 人工智能原理实验4(2)——贝叶斯、决策求解汽车评估数据集

    汽车数据集 车子具有 buying,maint,doors,persons,lug_boot and safety六种属性,而车子的好坏分为uncc,ucc,good and vgood四种。 数据预处理 1.转为数字编码 将数据集中的中文分类编码转为数字编码,以便更好地训练。这里采用sklearn的LabelEncoder库进行快速转换。 2.拆分数据集 按7:3的比例拆

    2024年04月26日
    浏览(46)
  • 人工智能_机器学习065_SVM支持向量机KKT条件_深度理解KKT条件下的损失函数求解过程_公式详细推导_---人工智能工作笔记0105

    之前我们已经说了KKT条件,其实就是用来解决 如何实现对,不等式条件下的,目标函数的求解问题,之前我们说的拉格朗日乘数法,是用来对 等式条件下的目标函数进行求解. KKT条件是这样做的,添加了一个阿尔法平方对吧,这个阿尔法平方肯定是大于0的,那么 可以结合下面的文章去

    2024年02月04日
    浏览(43)
  • 【2022级研究生人工智能高级语言程序设计考试说明】

    考试题共包括4道大题: 第一大题:分类和回归----(7选1) 第二大题:降维和聚类----(6选1) 第三大题:API调用(课程中学习过的所有云平台)----(11选1) 第四大题:深度学习项目----(10选1) 题目采取随机分配方式,请查阅 人工智能高级语言程序设计考试-题目分配表 ,

    2024年02月11日
    浏览(60)
  • 【人工智能】神经元数学模型的基本方程式及其意义详细说明

    神经元数学模型的基本方程式及其意义 在神经科学中,数学模型被广泛应用于理解神经元及其网络的激活、沟通和计算作用。本文将详细讨论一些典型神经元数学模型的基本方程式及其意义,以表达对神经网络实现认知和行为功能的认识。 一、Hodgkin-Huxley 模型

    2024年02月07日
    浏览(56)
  • 从 人工智能学派 视角来看 人工智能算法

    当今人工智能的算法纷繁复杂:神经网络、卷积神经网络CNN、遗传算法、进化策略、知识图谱、贝叶斯网络、支持向量机SVM、强化学习、生成对抗网络GAN,自编码器… 如果你把每个算法独立看待简直是眼花缭乱,头都是大的。这次我就带你理理这些算法,有些算法其实是可以

    2024年03月15日
    浏览(62)
  • 【人工智能】深入了解人工智能的核心算法与应用实践

    人工智能知识对于当今的互联网技术人来说已经是刚需。但人工智能的概念、流派、技术纷繁复杂,选择哪本书入门最适合呢? 这部被誉为人工智能“百科全书”的《人工智能(第3版)》,可以作为每个技术人进入 AI 世界的第一本书。 这本书是美国人工智能领域的权威经典

    2024年02月03日
    浏览(70)
  • 高级人工智能之群体智能:粒子群算法

    粒子群优化算法(Particle Swarm Optimization, PSO)是一种基于群体协作和信息共享的优化技术。它由Kennedy和Eberhart于1995年提出,灵感来源于鸟群和鱼群的社会行为。PSO是解决连续空间优化问题的有效方法,特别适合于多峰和高维问题。以下是PSO的基本思想和工作原理: 1.1基本思想

    2024年01月18日
    浏览(39)
  • 【人工智能】遗传算法

    可以把遗传算法类比成一个游戏,我们需要通过这个游戏来找到最佳的解决方案。 首先,我们需要创建一些角色(也就是种群),每个角色有自己的装备和技能(染色体),但是我们并不知道哪个角色更加强大。 然后,我们让这些角色相互竞争,通过升级、打怪等方式来获

    2024年02月02日
    浏览(48)
  • 人工智能分类算法概述

    人工智能分类算法是用于将数据划分为不同类别的算法。这些算法通过学习数据的特征和模式,将输入数据映射到相应的类别。分类算法在人工智能中具有广泛的应用,如图像识别、语音识别、文本分类等。以下是几种常见的人工智能分类算法的详细讲解过程: 决策树 决策

    2024年04月11日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包