【路径规划】A_star算法无人机二维避障最短路径规划(岛屿地图)【含Matlab源码 2774期】

⛄一、A_star算法简介

1 A Star算法及其应用现状
进行搜索任务时提取的有助于简化搜索过程的信息被称为启发信息.启发信息经过文字提炼和公式化后转变为启发函数.启发函数可以表示自起始顶点至目标顶点间的估算距离, 也可以表示自起始顶点至目标顶点间的估算时间等.描述不同的情境、解决不同的问题所采用的启发函数各不相同.我们默认将启发函数命名为H (n) .以启发函数为策略支持的搜索方式我们称之为启发型搜索算法.在救援机器人的路径规划中, A Star算法能结合搜索任务中的环境情况, 缩小搜索范围, 提高搜索效率, 使搜索过程更具方向性、智能性, 所以A Star算法能较好地应用于机器人路径规划相关领域.

2 A Star算法流程
承接2.1节, A Star算法的启发函数是用来估算起始点到目标点的距离, 从而缩小搜索范围, 提高搜索效率.A Star算法的数学公式为:F (n) =G (n) +H (n) , 其中F (n) 是从起始点经由节点n到目标点的估计函数, G (n) 表示从起点移动到方格n的实际移动代价, H (n) 表示从方格n移动到目标点的估算移动代价.

如图2所示, 将要搜寻的区域划分成了正方形的格子, 每个格子的状态分为可通过(walkable) 和不可通过 (unwalkable) .取每个可通过方块的代价值为1, 且可以沿对角移动 (估值不考虑对角移动) .其搜索路径流程如下:
在这里插入图片描述
图2 A Star算法路径规划
Step1:定义名为open和c

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
基于A*算法的实际海图船舶航行路径规划涉及到以下步骤: 1. 地图表示:将海图转化为图形表示,可以使用栅格地图或者节点图来表示。每个栅格或节点表示一个海图区域,包括海洋、陆地、碍物等。 2. 节点定义:定义节点表示船舶在海图上的位置。每个节点包位置坐标、与邻近节点的连接关系、启发式函数值等信息。 3. 初始化:设置起始节点和目标节点,将起始节点加入到开放列表(Open List)中。 4. A*算法主循环: a. 选择最好的节点:从开放列表中选择最优节点,即具有最小的启发式函数值(f值)的节点。 b. 扩展节点:对选中的节点进行扩展,生成邻近节点,并计算它们的启发式函数值、代价函数值等。 c. 更新节点信息:更新邻近节点的父节点、g值(从起始节点到当前节点的代价)和f值。 d. 判断终止条件:如果目标节点在开放列表中,则路径已找到;如果开放列表为空,则无可行路径。 e. 重复主循环:重复执行上述步骤,直到找到最优路径或者确定无可行路径。 5. 路径回溯:从目标节点开始,通过每个节点的父节点指针,回溯生成最路径。 6. 路径优化(可选):对生成的路径进行优化,比如去除冗余节点、平滑路径等,以得到更优的航行路径。 需要注意的是,在实际海图船舶航行中,还需要考虑到船舶的动力性能、航行限制、危险区域等因素,并进行适当的约束处理。此外,A*算法的性能也可以通过启发式函数的选择、开放列表的实现方式等进行优化,以提高路径规划效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Matlab领域

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值