news 2026/6/5 2:37:59

智能车辆路径跟踪控制:纯跟踪控制与Stanley控制算法,其他线相关算法。 主要是MATLAB程序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
智能车辆路径跟踪控制:纯跟踪控制与Stanley控制算法,其他线相关算法。 主要是MATLAB程序

智能车辆路径跟踪控制:纯跟踪控制与Stanley控制算法,其他线相关算法。 主要是MATLAB程序,可以根据需要的路径进行跟踪

最近在倒腾无人车路径跟踪算法,发现纯跟踪(Pure Pursuit)和Stanley这俩经典方法真是让人又爱又恨。今儿咱们直接上代码实战,手把手看看这俩货到底怎么玩转轨迹跟踪。

先搞个测试路径热热身。假设咱们要让小车跑个半径10米的圆:

theta = 0:0.1:2*pi; refPath = [10*cos(theta'); 10*sin(theta')]; % 圆形参考路径 scatter(refPath(:,1), refPath(:,2), 10, 'filled');

纯跟踪的核心在于预瞄点选择。看看这个魔性的lookahead distance参数怎么影响跟踪效果:

function delta = pure_pursuit(currentPos, lookahead_dist, refPath) % 找距离最近的路径点 [~, idx] = min(vecnorm(refPath - currentPos, 2, 2)); % 前看L距离的路径点 target_idx = idx; while target_idx <= length(refPath) && norm(refPath(target_idx,:)-currentPos) < lookahead_dist target_idx = target_idx + 1; } % 计算转向角(核心公式) alpha = atan2(refPath(target_idx,2)-currentPos(2), refPath(target_idx,1)-currentPos(1)) - currentYaw; delta = atan(2 * wheelbase * sin(alpha) / lookahead_dist); end

这里有个坑:预瞄距离得随速度动态调整。低速时设0.5米能完美跟弯道,但速度一快就容易画龙——这时候得用速度系数动态放大,比如L = 0.3*v + 0.5

智能车辆路径跟踪控制:纯跟踪控制与Stanley控制算法,其他线相关算法。 主要是MATLAB程序,可以根据需要的路径进行跟踪

接下来是Stanley算法,这货对航向误差特别敏感。核心代码长这样:

function delta = stanley_control(currentPos, currentYaw, v, refPath) % 找最近点 [nearest_point, idx] = min(vecnorm(refPath - currentPos, 2, 2)); path_yaw = atan2(refPath(idx+1,2)-refPath(idx,2), refPath(idx+1,1)-refPath(idx,1)); % 横向误差计算 front_axle = currentPos + wheelbase/2 * [cos(currentYaw), sin(currentYaw)]; cross_track_error = sign(dot([front_axle(2)-refPath(idx,2)], [-sin(path_yaw), cos(path_yaw)])) * nearest_point; % 转向控制(注意这个k参数) heading_error = path_yaw - currentYaw; delta = heading_error + atan(k * cross_track_error / (v + 0.1)); % 防除零 end

重点在k参数的调整——我试过当车速超过10m/s时,k值超过0.3就会让方向盘抽风。建议用PID参数整定法来找最佳值。

实测对比发现:纯跟踪在8字路径的交叉点容易走外道,这时候Stanley的航向修正就派上用场了。但Stanley在急弯时如果车速过高,横向误差项会突然暴涨,需要加个tanh函数限幅。

最后给个实时调试建议:在回调函数里动态绘制预瞄点和误差向量,比看数据直观十倍。比如这样实时显示预瞄点:

set(preview_point, 'XData', refPath(target_idx,1), 'YData', refPath(target_idx,2)); drawnow

这俩算法其实都是调参小能手,参数对了啥路况都能跑。下次试试把两者结合——用Stanley修正航向,用纯跟踪控制预瞄距离,说不定有惊喜。代码扔GitHub了,需要自取。

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

台达 24es 与两台施耐德 ATV310 变频器的 RTU 通讯示例

台达24es通讯&#xff08;rtu方式&#xff09;两台施耐德ATV310变频器示例 施耐德变频器的rtu有一点麻烦&#xff0c;是和大多变频器通讯不一样&#xff0c;它有它的逻辑&#xff0c;但这并不妨碍我们和它的通讯&#xff0c;比如用台达plc来通讯&#xff0c;点动频率&#xff0…

作者头像 李华
网站建设 2026/5/29 0:47:04

探索 SSM 甜品交易系统

ssm甜品交易系统&#xff0c;包含文档&#xff0c;Javassm Ecplice&#xff0c;jsp最近在折腾一个超有趣的项目——SSM 甜品交易系统&#xff01;今天就来和大家分享一下我的一些经历和发现。这个系统主要涉及到 Java、SSM&#xff08;Spring Spring MVC MyBatis&#xff09;…

作者头像 李华
网站建设 2026/6/3 0:26:49

select count(*) 表名 和select count(*) from 表名

mysql一次核对数据&#xff0c;少写了一个from&#xff0c;直接写成下面的sql了。select count(*) 表名结果无论哪个表都返回1&#xff0c;把我吓得捏了一把汗还以为数据被谁清空了。。原来是自己的手误&#xff0c;select count(*) 表名相当于把表名当成了列的别名&#xff0c…

作者头像 李华
网站建设 2026/5/30 11:21:49

Qwen3-Embedding-4B部署教程:Python调用避坑指南

Qwen3-Embedding-4B部署教程&#xff1a;Python调用避坑指南 1. Qwen3-Embedding-4B介绍 Qwen3 Embedding 模型系列是 Qwen 家族中专为文本嵌入和排序任务打造的最新成员&#xff0c;基于强大的 Qwen3 系列基础模型构建。该系列覆盖多种参数规模&#xff08;0.6B、4B 和 8B&a…

作者头像 李华
网站建设 2026/5/28 22:43:33

RS ASIO音频延迟消除技术:实时演奏优化的完整解决方案

RS ASIO音频延迟消除技术&#xff1a;实时演奏优化的完整解决方案 【免费下载链接】rs_asio ASIO for Rocksmith 2014 项目地址: https://gitcode.com/gh_mirrors/rs/rs_asio 您是否遇到这些音频延迟困扰&#xff1f; 当您满怀激情地在摇滚史密斯中弹奏时&#xff0c;是…

作者头像 李华