在每次对角线步骤之前,我们首先递归直线 。只有当两次直线递归都未能识别出跳点时,我们才再次对角线步进 。 节点 w,x 的强制邻居,正常扩展 。(也推入开放列表,优先队列) 。
记住:你只能直线跳跃或对角线跳跃;不能分段跳跃 。:::success 维护一个优先队列来存储所有待扩展的节点 对所有节点预先定义启发函数h(n) 用起始状态XS初始化优先队列 设置g(XS)=0,对图中的其他节点设置g(n)=无穷 循环: 如果队列为空,返回FALSE并退出循环 从队列中取出f(n)=g(n)+h(n)最小的节点“n” 将节点“n”标记为已扩展 如果节点“n”是目标状态,返回TRUE并退出循环 对节点“n”的所有未扩展邻居节点“m”: 如果g(m)=无穷 g(m)= g(n) + Cnm 将节点“m”加入队列 如果g(m)>g(n)+Cnm g(m)= g(n) + Cnm 结束对邻居节点的循环 结束主循环 ::: openlist查找具体流程如下²: 初始化起点节点 start ,将起点周围四个角落的空闲节点相对于起点的相对位置加入起点节点的 forced_neighbor_list 。 创建一个 openlist , 将 start 加入 openlist 。 while openlist is not empty: node ← openlist.Pop () 从 node 开始跳跃,首先进行直线跳跃,再进行对角线跳跃 。 用 parent 表示从 node 进行对角线跳跃得到的节点,用 current 表示从 parent 进行直线跳跃得到的节点 。 如果 current 是跳点,而 parent 与 node 是同一个节点,则将 current 加入 openlist , 同时将 current 的父节点指向 node; 如果 current 是跳点,而 parent 与 node 不是同一个节点,则将 parent 和 current 加入 openlist,同时将 current 的父节点指向 parent,将 parent 的父节点指向 node; 如果 current 是障碍物或者边界,则进行对角线跳跃; 如果 parent 是障碍物或者边界,则进入下一轮循环 。例子:

文章插图
- 扩展—>对角线移动
- 最终找到一个关键节点,将其加入开放列表 。
- 从开放列表中弹出它(唯一的节点) 。
- 垂直扩展,在障碍物处结束 。

文章插图
- 水平扩展,遇到一个具有强制邻居的节点 。
- 将其添加到开放列表 。

文章插图
- 对角线扩展,扩展后没有发现任何新的节点 。
- 完成当前节点的扩展 。

文章插图

文章插图
更详细跳点搜索可以参考下面文章:
https://blog.csdn.net/LIQIANGEASTSUN/article/details/118766080
小结:本文介绍了motion plan学院派的框架:
- 前端路径规划
- 后端轨迹生成
- 不确定障碍物预估规划
推荐阅读
-
潮人志Fashion|Moncler羽绒服界的“爱马仕”,它凭什么这么受欢迎?
-
53岁歌手毛宁罕现身,染头发驾豪车生活惬意,曾因吸毒自毁前程
-
何有强|惠若琪机场造型不输“超模”,穿条纹衬衫搭配牛仔裤,气场全开
-
拙言Z世代的尝鲜之选?15天超长文体验华为畅享Z有感
-
体育卡卡说|欧文立山头拒绝复工?美国杨毅点评一针见血:不要给不工作找理由
-
上衣|凯特·阿普顿穿蓝色上衣搭牛仔裤简约休闲, 金发墨镜炫酷迷人!
-
-
-
早餐家庭早餐菜谱,南瓜双色馒头,健康美味营养,动手吧
-
-
「美队回应误发私密照」美队克里斯·埃文斯回应误发自己私密照:记得11月3号去投票!
-
生肖@5月8日~14日星座运程:天秤、天蝎、射手、摩羯、水瓶、双鱼座!
-
年将|巴西经济部维持该国今年GDP萎缩4.7%预估不变,将通胀预期上调至1.83%
-
-
定焦爱科技 为什么有人喜欢买二手手机?应该有以下原因
-
时尚柠檬精|减龄效果惊呆众人!,温碧霞、许晴换新发型
-
大话百科天地 将利用于智能电网建设,清洁能源发展,建设新能源汽车充电设施
-
车管所提醒:在中国即将有1300万机动车被淘汰,很多人不知道
-
疫病|60亿美元!阿斯利康再度携手第一三共合作抗体偶联药物
-
白鲸天下|美国低调派匿名人士栽赃伊朗,重演揭发俄罗斯剧情,遭13国反对