news 2026/7/5 21:08:48

在扩展节点时加入障碍物检测

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
在扩展节点时加入障碍物检测

基于A星与DWA算法融合的动态路径规划,可实现静态避障碍及动态避障

深夜撸代码的时候突然想到,路径规划这玩意儿不就是既要全局最优又得能躲开外卖小哥吗?传统A星在静态地图里确实好用,但遇到动态障碍物直接傻眼。DWA(Dynamic Window Approach)虽然能实时避障,可全局路线容易跑偏。这俩货要是能组CP,效果应该不错吧?

先整点A星的干货。核心思想其实就一句话:把地图网格化,用优先队列找最短路径。咱们用Python简单实现个节点类:

class Node: def __init__(self, parent=None, position=None): self.parent = parent self.position = position self.g = 0 # 实际代价 self.h = 0 # 启发式估计 self.f = 0 # 总代价 def __eq__(self, other): return self.position == other.position def __lt__(self, other): return self.f < other.f

重点在代价计算这块,g值是真实走过的距离,h值用曼哈顿距离做启发。有个小技巧是在计算相邻节点时,可以给障碍物设置惩罚项,让路径自然远离危险区域:

if grid[new_x][new_y] > obstacle_threshold: current_node.g += penalty_cost # 惩罚系数根据实际情况调整

然后是DWA的骚操作,这算法像老司机开车——不断根据当前速度预测未来轨迹。速度采样是关键,别傻乎乎全遍历,用动态窗口缩小范围:

def velocity_samples(v_current, w_current, dt): # 速度增量控制在物理极限内 v_samples = np.linspace(max(0, v_current - a_max*dt), min(v_max, v_current + a_max*dt), num=5) w_samples = np.linspace(max(-w_max, w_current - alpha_max*dt), min(w_max, w_current + alpha_max*dt), num=5) return [(v, w) for v in v_samples for w in w_samples]

评价函数得兼顾目标导向、速度和障碍物距离。有个坑要注意——别把动态障碍物当静态处理,得预测它们的运动轨迹:

def evaluation(v, w, robot_pose, goals, dynamic_obstacles): traj = simulate_trajectory(robot_pose, v, w) # 预测轨迹 heading_score = angle_to_goal(traj[-1], goals) # 朝向目标得分 velocity_score = v # 速度得分 obstacle_score = 0 for obs in dynamic_obstacles: predicted_pos = obs.predict(traj[-1][2]) # 根据当前时间戳预测障碍物位置 obstacle_score += 1.0 / (distance(traj, predicted_pos) + 1e-5) return heading_score + velocity_score - obstacle_score * 10

融合的核心在于让A生成全局航点,DWA负责局部跟踪。但直接这么搞会翻车——当动态障碍物挡住全局路径时,得让A重新规划。这里用了个状态机机制:

class HybridPlanner: def __init__(self): self.global_path = [] self.current_waypoint = 0 def update(self, obstacles): if need_replan(obstacles): # 检测是否被障碍物阻断 self.global_path = a_star_replan() self.current_waypoint = find_nearest_waypoint() local_goal = self.global_path[self.current_waypoint] dwa_velocity = dwa_plan(current_pose, local_goal, obstacles) if reach_threshold(current_pose, local_goal): self.current_waypoint += 1

实测时发现个有趣现象:当动态障碍物速度超过机器人最大速度时,系统会自动生成绕行路径,而不是死磕原路线。这得益于DWA的实时避障和A*的周期重规划形成的正反馈。

最后丢个调参经验:A*的启发式权重别设太高,否则容易贴着障碍物走;DWA的障碍物惩罚系数要和传感器刷新率匹配,否则会抽搐。代码里那些magic number最好做成配置文件,实测时改参数比改代码频繁多了。

这种融合方案在实验室小车上跑出了不错的效果,但放到真实停车场环境还是得考虑点云噪声和通信延迟的问题。下次有机会再聊聊怎么用IMU数据做运动补偿吧。

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

端到端自动驾驶仿真新范式:aiSim如何解决智驾测试的“灾难性挑战“

1 引言&#xff1a;从模块化到端到端的智驾革命随着智能驾驶技术快速发展&#xff0c;端到端解决方案正成为行业新趋势。与传统规则驱动的模块化方案相比&#xff0c;学习驱动的端到端方案具备更强的泛化能力、全面优化优势和持续学习能力。然而&#xff0c;这种变革对仿真测试…

作者头像 李华
网站建设 2026/7/3 15:08:25

【优化】避免繁琐设置字符编码,简单C/C++中文处理方法

字符串字面量在C/C中的中文处理 一、字符串字面量的本质 在C/C中&#xff0c;字符串字面量是存储在静态内存区域的字符数组。其基本形式为&#xff1a; const char* str "中文字符";但直接使用窄字符&#xff08;char&#xff09;处理中文时&#xff0c;常因编码问题…

作者头像 李华
网站建设 2026/6/30 12:16:21

牛客周赛 Round 111

设一个数组 &#xfffd; { 2 , 3 , 4 , 3 , 5 , 1 } b{2,3,4,3,5,1}&#xff0c;则 &#xfffd; ( &#xfffd; ) 2 3 4 5 14 L(b)234514&#xff0c; &#xfffd; ( &#xfffd; ) 1 5 6 R(b)156。 小芳希望小红构造一个长为 &#xfffd; …

作者头像 李华
网站建设 2026/7/3 7:00:12

定性与定量考核的结合

在现代企业管理中&#xff0c;如何科学、公正地评估员工绩效&#xff0c;始终是一个核心议题。要实现全面而准确的评估&#xff0c;关键在于将定量考核的客观性与定性考核的深刻性有效结合。 单纯的定量考核&#xff08;“计件”&#xff09;提供了“做什么”的客观数据&#x…

作者头像 李华
网站建设 2026/7/5 0:19:00

如何衡量团队产出效率

在现代组织中&#xff0c;团队的产出效率直接决定企业的竞争力与执行力。**要科学衡量团队产出效率&#xff0c;核心在于建立多维度的指标体系&#xff0c;将成果、过程与协作因素综合评估&#xff0c;以实现对绩效的量化与优化。**单纯用“工作量”或“加班时间”衡量团队贡献…

作者头像 李华
网站建设 2026/7/2 17:37:57

使用格子玻尔兹曼方法(LBM)模拟热扩散的Matlab代码

使用格子玻尔兹曼方法&#xff08;LBM&#xff09;模拟热扩散&#xff0c;Matlab代码格子玻尔兹曼方法&#xff08;LBM&#xff09;搞热扩散模拟其实挺有意思的&#xff0c;今天咱们用Matlab整一个简单的二维版本。先上核心思路&#xff1a;把温度场当作被动标量&#xff0c;用…

作者头像 李华