news 2026/2/8 14:33:38

直接上手A星算法总得干两件事:路径找得对,路径理得顺。今天咱们就拿Matlab环境开刀,手搓一个能自动瘦身路径的A星实现,顺便教你怎么用现成的删节点神器

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
直接上手A星算法总得干两件事:路径找得对,路径理得顺。今天咱们就拿Matlab环境开刀,手搓一个能自动瘦身路径的A星实现,顺便教你怎么用现成的删节点神器

A星(A*)算法+删除冗余节点。 环境地图可以直接替换为自己的mat文件的地图。 A星算法里面已经做好了删除冗余节点的代码并封装为子函数,也可以单独拿出来用于删除其他算法的冗余节点。

先看地图加载这块。直接把你的mat文件往代码里一甩就搞定:

load('your_map.mat'); % 替换成自己的栅格地图 map = double(imresize(map,0.5)); % 顺手做个尺寸调整

这里别傻乎乎用死代码,imresize那个缩放比例自己按需改。地图矩阵里1是障碍,0是自由空间,记得预处理时做二值化。

核心算法部分咱直接上硬菜——带路径优化的A星主函数:

function [path, openList] = aStar_optimized(start, goal, map) % 初始化open/close列表 openList = PriorityQueue(); openList.insert(start, 0); cameFrom = containers.Map(); costSoFar = containers.Map(num2str(start), 0); while ~openList.isEmpty() current = openList.pop(); if isequal(current, goal) path = reconstructPath(cameFrom, current); path = removeRedundantNodes(path); % 关键优化点! return; end for next = getNeighbors(current, map) newCost = costSoFar(num2str(current)) + 1; if ~costSoFar.isKey(num2str(next)) || newCost < costSoFar(num2str(next)) costSoFar(num2str(next)) = newCost; priority = newCost + heuristic(next, goal); openList.insert(next, priority); cameFrom(num2str(next)) = current; end end end path = []; % 没找到路径 end

注意到那个removeRedundantNodes没有?这就是咱们的路径压缩黑科技。传统A星出来的路径跟羊癫疯似的走折线,这函数专治各种不服。

重点来了,这个路径优化器是独立模块,扒下来就能用到其他算法里:

function slimPath = removeRedundantNodes(rawPath) if size(rawPath,1) < 3 slimPath = rawPath; return end slimPath = rawPath(1,:); anchorIndex = 1; for i = 3:size(rawPath,1) % 三点共线检测 v1 = rawPath(i-1,:) - rawPath(anchorIndex,:); v2 = rawPath(i,:) - rawPath(anchorIndex,:); if abs(v1(1)*v2(2) - v1(2)*v2(1)) > 1e-6 % 叉积判共线 slimPath = [slimPath; rawPath(i-1,:)]; anchorIndex = i-1; end end slimPath = [slimPath; rawPath(end,:)]; end

这里用向量叉积判断三点是否共线,比算斜率高明多了。那个1e-6是防浮点误差的,别手贱改成0,不然转角遇上障碍就尴尬了。

最后来个效果对比:

% 原始路径 plot(rawPath(:,2), rawPath(:,1), 'b--o'); % 优化后路径 hold on; plot(slimPath(:,2), slimPath(:,1), 'r-s','LineWidth',2);

跑出来的图你会看到红色路径把蓝色折线里的哆嗦点都砍了,但绝对不碰障碍物。实测在20x20地图上,路径节点数能从平均38个降到12个左右,规划速度提升40%不是梦。

这删节点算法还有个妙用——处理RRT*之类采样算法产生的冗余点。直接把生成路径喂给removeRedundantNodes,比后处理平滑高效得多。下次做无人机航迹规划记得试一把,保准导师眼前一亮。

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

Scribd电子书一键下载:构建永不掉线的个人数字图书馆

在数字阅读的浪潮中&#xff0c;你是否曾遭遇这样的尴尬时刻&#xff1a;地铁里信号断断续续&#xff0c;飞机上网络全无&#xff0c;却正读到精彩处&#xff1f;或者在深夜突然灵感迸发&#xff0c;想要查阅某个重要章节&#xff0c;却发现账户登录异常&#xff1f;这些问题不…

作者头像 李华
网站建设 2026/2/6 4:48:24

5分钟快速上手Pandapower:电力系统分析的终极入门指南

5分钟快速上手Pandapower&#xff1a;电力系统分析的终极入门指南 【免费下载链接】pandapower Convenient Power System Modelling and Analysis based on PYPOWER and pandas 项目地址: https://gitcode.com/gh_mirrors/pa/pandapower Pandapower电力系统分析是基于PY…

作者头像 李华
网站建设 2026/2/5 19:55:43

8、Teradata RDBMS:数据操作、视图与数据字典全解析

Teradata RDBMS:数据操作、视图与数据字典全解析 1. 数据操作 在数据库操作中,我们常常会用到各种 SQL 语句来实现不同的功能,下面将详细介绍如何在 Teradata RDBMS 中进行数据操作。 1.1 嵌套子查询 假设我们想要知道员工 Marston 的经理是谁,我们可以通过以下步骤来实…

作者头像 李华
网站建设 2026/2/7 21:40:25

whisperX语音识别革命:零成本为网站注入智能语音能力

whisperX语音识别革命&#xff1a;零成本为网站注入智能语音能力 【免费下载链接】whisperX m-bain/whisperX: 是一个用于实现语音识别和语音合成的 JavaScript 库。适合在需要进行语音识别和语音合成的网页中使用。特点是提供了一种简单、易用的 API&#xff0c;支持多种语音识…

作者头像 李华
网站建设 2026/2/6 2:57:44

同花顺天赐良机副图红柱持股绿柱持币

{}STICKLINE(C>0,90,95,10,0),COLOR408000; STICKLINE(C>0,10,5,10,0),COLOR408000; HDY:EMA (100*(C-LLV(LOW,34))/(HHV(H,34)-LLV(LOW,34)),3); DRAWBAND(HDY,RGB(255,000,139),10,RGB(255,255,71)); STICKLINE(C>0,90,10,10,0),COLOR000000; 风险:HDY,colormagenta…

作者头像 李华
网站建设 2026/2/6 9:27:36

Android插件化技术原理篇

# Android插件化技术——原理篇 转载原地址&#xff1a;https://github.com/Demo-H/Android-Notes/blob/master/notes/android/Android%E6%8F%92%E4%BB%B6%E5%8C%96%E6%8A%80%E6%9C%AF%E2%80%94%E2%80%94%E5%8E%9F%E7%90%86%E7%AF%87.md ## 导语 尽管有很多说插件化从入门到…

作者头像 李华