news 2026/2/15 7:45:19

扩展邻域A* Astar astar路径规划 A星路径规划算法 基于珊格地图的路径规划 因代码...

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
扩展邻域A* Astar astar路径规划 A星路径规划算法 基于珊格地图的路径规划 因代码...

扩展邻域A* Astar astar路径规划 A星路径规划算法 基于珊格地图的路径规划 因代码具有可复制性,

A*算法(A-Star)是一种经典的路径规划算法,在栅格地图中被广泛应用。它结合了Dijkstra算法和贪心算法的思想,通过使用启发式函数来估计到目标的代价,从而在路径规划中表现出较高的效率。

A*算法的基本原理

A*算法的核心在于使用一个优先队列(通常用最小堆实现)来选择下一步扩展的节点。每个节点的总代价F(n)由两部分组成:

  • G(n):从起点到当前节点n的实际代价。
  • H(n):从当前节点n到目标节点的启发式估计代价(通常使用曼哈顿距离或欧氏距离)。

算法每次从优先队列中取出F(n)最小的节点进行扩展,直到找到目标节点。

栅格地图的表示

栅格地图通常可以用一个二维数组表示,其中每个元素表示一个栅格的状态(如0表示可通过,1表示障碍物)。

grid = [ [0, 0, 0, 0, 0], [0, 1, 0, 1, 0], [0, 0, 0, 0, 0], [0, 1, 0, 1, 0], [0, 0, 0, 0, 0] ]

扩展邻域A*算法

传统的A算法通常使用4个方向(上下左右)或8个方向进行扩展。扩展邻域A算法通过增大扩展的范围,可以更有效地找到全局最优路径。

八邻域扩展

八邻域扩展允许从当前节点向八个方向移动,这有助于更灵活地避开障碍物。

# 八邻域的移动方向 directions = [ (-1, 0), # 上 (1, 0), # 下 (0, -1), # 左 (0, 1), # 右 (-1, -1), # 左上 (-1, 1), # 右上 (1, -1), # 左下 (1, 1) # 右下 ]
启发式函数

使用欧氏距离作为启发式函数,可以更好地估计到目标的距离。

def heuristic(node, goal): return ((node[0] - goal[0]) ** 2 + (node[1] - goal[1]) ** 2) ** 0.5

算法实现

以下是扩展邻域A*算法的一个简单实现:

import heapq def astar(grid, start, goal): open_set = [] heapq.heappush(open_set, (0, start)) came_from = {} g_score = { (x, y): float('inf') for x in range(len(grid)) for y in range(len(grid[0])) } g_score[start] = 0 f_score = { (x, y): float('inf') for x in range(len(grid)) for y in range(len(grid[0])) } f_score[start] = heuristic(start, goal) while open_set: current = heapq.heappop(open_set) current_node = current[1] if current_node == goal: break for move in directions: neighbor = (current_node[0] + move[0], current_node[1] + move[1]) if 0 <= neighbor[0] < len(grid) and 0 <= neighbor[1] < len(grid[0]): if grid[neighbor[0]][neighbor[1]] == 1: continue tentative_g_score = g_score[current_node] + 1 if tentative_g_score < g_score[neighbor]: came_from[neighbor] = current_node g_score[neighbor] = tentative_g_score f_score[neighbor] = g_score[neighbor] + heuristic(neighbor, goal) heapq.heappush(open_set, (f_score[neighbor], neighbor)) return came_from

代码分析

  • 优先队列:使用heapq模块实现优先队列,方便快速取出F(n)最小的节点。
  • 启发式函数heuristic函数使用欧氏距离,可以更快地向目标靠近。
  • 扩展邻域:通过directions列表定义了八邻域移动,增加了算法的灵活性。

总结

扩展邻域A算法在传统A算法的基础上,通过增加扩展的方向数量,能够更有效地找到全局最优路径。上述代码实现了一个简单的八邻域扩展A*算法,适用于大多数栅格地图的路径规划问题。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/11 4:19:47

位运算及状压DP

文章目录位运算简介与、或、异或左移和右移关于优先级常见应用内置函数状压DP简介核心练习题位运算 简介 位运算就是基于整数的二进制表示进行的运算。由于计算机内部就是以二进制来存储数据&#xff0c;位运算是相当快的。 比赛题目中出现的位运算基本有 5 种&#xff0c;分…

作者头像 李华
网站建设 2026/2/10 18:56:39

揭秘空间转录组热力图绘制全过程:5个R语言核心代码块让你效率翻倍

第一章&#xff1a;空间转录组热力图的核心意义与应用场景空间转录组热力图是解析组织内基因表达空间异质性的关键可视化工具。它将高通量测序数据与组织切片的空间坐标相结合&#xff0c;直观呈现不同基因在组织微环境中的表达分布模式&#xff0c;帮助研究人员识别功能区域、…

作者头像 李华
网站建设 2026/2/12 8:59:36

日志收集方案

1.应用场景常用于日志采集和数据回流场景1.1 日志类型非容器化日志即python组件/go组件/java组件业务日志&#xff0c;可自由进行日志轮转&#xff0c;支持按时间、大小、历史、总容量等容器化日志(适用于stdout/stderr)单行最大长度是16k&#xff0c;即超过最大长度&#xff0…

作者头像 李华
网站建设 2026/2/15 1:58:17

亚马逊小卖家逆袭:蓝海市场的精准切入与增长法则

在巨头林立的亚马逊生态中&#xff0c;小卖家的生存空间看似不断压缩&#xff0c;然而&#xff0c;真正聪明的经营者明白&#xff1a;避开红海正面竞争&#xff0c;转向精细化、差异化的蓝海战略&#xff0c;才是以小博大的关键。数据导航&#xff1a;发现被忽视的机会当多数卖…

作者头像 李华