基于强化学习Q-learning算法的无人机三维路径规划算法原理与实现,MATLAB代码

基于强化学习Q-learning算法的无人机三维路径规划算法原理与实现,MATLAB代码

一、算法概述

本文基于Q-learning离线强化学习,实现三维栅格环境下无人机无碰撞、最短路径、最少步数路径规划。无人机具备1格/2格三维全向移动、对角线飞行、悬停能力,通过与环境交互迭代学习最优策略,以到达终点、路径距离、移动步数、避障为核心目标,输出满足约束的最优飞行路径。

二、环境与核心建模

1. 三维状态空间

将无人机飞行空间离散化为三维栅格地图,状态定义为无人机坐标:
S={(x,y,z)∣1≤x≤Xmax, 1≤y≤Ymax, 1≤z≤Zmax} S = \left\{ (x,y,z) \mid 1 \le x \le X_{max},\ 1 \le y \le Y_{max},\ 1 \le z \le Z_{max} \right\} S={(x,y,z)∣1≤x≤Xmax​, 1≤y≤Ymax​, 1≤z≤Zmax​}

  • (x,y,z)(x,y,z)(x,y,z):无人机空间位置
  • Xmax,Ymax,ZmaxX_{max},Y_{max},Z_{max}Xmax​,Ymax​,Zmax​:地图边界(代码中为10×10×1010 \times 10 \times 1010×10×10)

2. 动作空间(代码实现)

54种动作,包含:

  • 6个轴向1格移动、12个平面斜向1格移动、8个空间斜向1格移动
  • 6个轴向2格移动、12个平面斜向2格移动、8个空间斜向2格移动
  • 1个悬停动作 (0,0,0)(0,0,0)(0,0,0)

动作集合:
A={(Δx,Δy,Δz)∣Δx,Δy,Δz∈{−2,−1,0,1,2}, 非全零}∪{(0,0,0)} A = \{ (\Delta x,\Delta y,\Delta z) \mid \Delta x,\Delta y,\Delta z \in \{-2,-1,0,1,2\},\ 非全零 \} \cup \{ (0,0,0) \} A={(Δx,Δy,Δz)∣Δx,Δy,Δz∈{−2,−1,0,1,2}, 非全零}∪{(0,0,0)}

3. 约束条件

  1. 边界约束:坐标必须在地图范围内
  2. 避障约束:禁止进入障碍物坐标
  3. 目标约束:从起点(2,2,2)(2,2,2)(2,2,2)到达终点(9,9,8)(9,9,8)(9,9,8)

三、Q-learning核心数学原理

1. Q值函数

Q(s,a)Q(s,a)Q(s,a) 表示状态sss下执行动作aaa的长期累积奖励期望,是算法核心决策依据:
Q(s,a)←Q(s,a)+α⋅[R(s,a)+γ⋅max⁡a′Q(s′,a′)−Q(s,a)] Q(s,a) \leftarrow Q(s,a) + \alpha \cdot \left[ R(s,a) + \gamma \cdot \max_{a'} Q(s',a') - Q(s,a) \right] Q(s,a)←Q(s,a)+α⋅[R(s,a)+γ⋅a′max​Q(s′,a′)−Q(s,a)]
参数定义

  • α\alphaα:学习率,控制更新步长(代码中动态衰减:0.25→0.050.25 \to 0.050.25→0.05)
  • γ\gammaγ:折扣因子,权衡远期奖励(代码中γ=0.99\gamma=0.99γ=0.99)
  • R(s,a)R(s,a)R(s,a):即时奖励
  • s′s's′:执行动作后的新状态
  • max⁡Q(s′,a′)\max Q(s',a')maxQ(s′,a′):下一状态最优动作价值

2. 动作选择策略

采用**ε\varepsilonε-贪心策略+动态衰减**,平衡探索与利用:
π(a∣s)={arg⁡max⁡aQ(s,a)概率 1−ε(利用最优策略)随机合法动作概率 ε(探索未知环境) \pi(a|s)= \begin{cases} \arg\max\limits_a Q(s,a) & 概率\ 1-\varepsilon(利用最优策略)\\ 随机合法动作 & 概率\ \varepsilon(探索未知环境) \end{cases} π(a∣s)={argamax​Q(s,a)随机合法动作​概率 1−ε(利用最优策略)概率 ε(探索未知环境)​
ε\varepsilonε 随训练指数衰减:ε=max⁡(εmin, ε0⋅e−0.007⋅episode)\varepsilon = \max(\varepsilon_{min},\ \varepsilon_0 \cdot e^{-0.007 \cdot episode})ε=max(εmin​, ε0​⋅e−0.007⋅episode)


四、奖励函数Reward设计

本算法以路径最短、无碰撞、必达终点、步数最少为目标,奖励函数分4类场景设计:

1. 奖励函数数学表达式

R(s,a)={3500−15⋅dstep−5⋅Nstep到达终点−1500碰撞障碍物/越界30⋅(dcur−dnext)−10⋅dstep−2⋅Nstep−10悬停30⋅(dcur−dnext)−10⋅dstep−2⋅Nstep正常飞行 R(s,a)= \begin{cases} 3500 - 15 \cdot d_{step} - 5 \cdot N_{step} & \text{到达终点}\\ -1500 & \text{碰撞障碍物/越界}\\ 30 \cdot (d_{cur}-d_{next}) -10 \cdot d_{step} -2 \cdot N_{step} -10 & \text{悬停}\\ 30 \cdot (d_{cur}-d_{next}) -10 \cdot d_{step} -2 \cdot N_{step} & \text{正常飞行} \end{cases} R(s,a)=⎩⎨⎧​3500−15⋅dstep​−5⋅Nstep​−150030⋅(dcur​−dnext​)−10⋅dstep​−2⋅Nstep​−1030⋅(dcur​−dnext​)−10⋅dstep​−2⋅Nstep​​到达终点碰撞障碍物/越界悬停正常飞行​

2. 奖励项详细介绍

  1. 到达终点(最高奖励)
    • 基础奖励:+3500+3500+3500,保证无人机优先到达目标
    • 惩罚项:单步距离越长、总步数越多,奖励越低,强制最短路径+最少步数
  2. 碰撞障碍物/越界(最高惩罚)
    • 惩罚:−1500-1500−1500,让无人机彻底学会避障,杜绝碰撞
  3. 悬停动作(额外惩罚)
    • 惩罚:−10-10−10,避免无人机无效停留,提升飞行效率
  4. 正常飞行(启发式引导)
    • 靠近终点:+30⋅(dcur−dnext)+30 \cdot (d_{cur}-d_{next})+30⋅(dcur​−dnext​),距离缩短越多奖励越高
    • 远离终点:自动产生负奖励,引导无人机向目标飞行
    • 距离惩罚:−10⋅dstep-10 \cdot d_{step}−10⋅dstep​,飞行距离越长惩罚越高
    • 步数惩罚:−2⋅Nstep-2 \cdot N_{step}−2⋅Nstep​,步数越多惩罚越高

3. 奖励设计核心目标

✅ 无人机必须到达终点
✅ 无人机绝对不碰撞障碍物
✅ 飞行路径欧氏距离最小
✅ 飞行移动步数最少
✅ 禁止无效悬停,提升飞行效率


五、算法步骤

阶段1:参数初始化

  1. 初始化三维地图、起点、终点、障碍物坐标
  2. 定义54种移动动作+1种悬停动作
  3. 初始化四维Q表:Q(Xmax,Ymax,Zmax,A)=0Q(X_{max},Y_{max},Z_{max},A) = 0Q(Xmax​,Ymax​,Zmax​,A)=0
  4. 设置超参数:α,γ,ε\alpha,\gamma,\varepsilonα,γ,ε、训练轮数、最大步长

阶段2:Q-learning训练迭代

for 每一轮训练 episode = 1:max_episode 动态衰减学习率α和探索率ε 无人机重置到起点,清空路径、奖励、步数 for 每一步飞行 step = 1:max_step 1. 动作剪枝:剔除越界、碰撞障碍物的无效动作 2. ε-贪心策略选择最优/随机动作 3. 执行动作,得到新状态s' 4. 计算即时奖励R(核心:避障+距离+步数+终点) 5. 更新Q值:Q(s,a) ← Q(s,a)+α[R+γ·maxQ(s',a')−Q(s,a)] 6. 判断终止:到达终点/碰撞/越界 7. 更新状态、累计奖励、飞行路径 end 计算本轮总距离、总步数、总奖励并保存 end 

阶段3:最优路径规划

  1. 加载训练完成的Q表
  2. 从起点出发,每一步选择Q(s,a)Q(s,a)Q(s,a)最大的动作
  3. 严格校验边界与障碍物,保证无碰撞
  4. 到达终点后,输出最优路径、总步数、总距离

阶段4:结果可视化

  1. 绘制奖励收敛曲线
  2. 绘制路径距离收敛曲线
  3. 绘制三维最优路径、起点、终点、障碍物

六、部分MATLAB代码及结果

% 最终结果 final_steps = size(path,1)-1; final_dist =0;for i =1:final_steps final_dist = final_dist + norm(path(i+1,:)-path(i,:)); end fprintf('\n=========================================\n'); fprintf(' 最优步数:%d 步\n', final_steps); fprintf(' 最短距离:%.4f\n', final_dist); fprintf(' 避障状态:无碰撞\n'); fprintf('=========================================\n'); %% 绘图 figure('Color','w','Position',[80,80,1200,380]); subplot(1,3,1); plot(1:max_episode, reward_curve, 'b-','LineWidth',1.6); xlabel('训练轮数'); ylabel('总奖励'); title('奖励收敛曲线'); grid on; subplot(1,3,2); plot(1:max_episode, episode_path_distance, 'r-','LineWidth',1.6); xlabel('训练轮数'); ylabel('路径总距离'); title('距离收敛曲线'); grid on; subplot(1,3,3); hold on; grid on; axis equal; view(3); xlabel('X'); ylabel('Y'); zlabel('Z'); title(sprintf('最优路径 | 步数:%d | 距离:%.2f | 无碰撞',final_steps,final_dist)); xlim([1 x_max]); ylim([1 y_max]); zlim([1 z_max]); plot3(start_state(1),start_state(2),start_state(3),'rs','MarkerSize',11,'LineWidth',2); plot3(end_state(1),end_state(2),end_state(3),'gd','MarkerSize',11,'LineWidth',2); scatter3(obstacle(:,1),obstacle(:,2),obstacle(:,3),100,'k','filled'); plot3(path(:,1),path(:,2),path(:,3),'m-','LineWidth',2.8,'MarkerSize',5); legend('起点','终点','障碍物','最优路径','Location','best');
在这里插入图片描述

七、完整MATLAB见下方名片

Read more

大语言模型LLM解决AI幻觉方法的深度分析

大语言模型LLM解决AI幻觉方法的深度分析

LLM解决AI幻觉方法的深度分析 引言:AI幻觉的定义与研究背景 AI 幻觉作为大型语言模型(LLM)部署的核心挑战,其学术价值体现于对模型"概率生成天性"的机制探索(如 OpenAI 2025 年论文《Why Language Models Hallucinate》揭示的底层逻辑),产业意义则关乎医疗、金融等关键领域的安全应用[1]。当前研究显示,即使开发团队对 LLM 内部运作的理解仍局限于 10%~20%(Anthropic 团队研究),但该现象已引发信息污染、信任危机等风险,同时在科学发现等领域展现创造力价值,成为 AI 可靠性研究的焦点[2][3][4]。 AI 幻觉的权威分类: * 事实性幻觉:生成内容与客观事实冲突,例如错误声称"蜂蜜可帮助糖尿病患者稳定血糖"[2]

AI健身私教:扣子空间助你打造个性化训练计划

AI健身私教:扣子空间助你打造个性化训练计划

AI健身私教:扣子空间助你打造个性化训练计划 🌟 嗨,我是IRpickstars! 🌌 总有一行代码,能点亮万千星辰。 🔍 在技术的宇宙中,我愿做永不停歇的探索者。 ✨ 用代码丈量世界,用算法解码未来。我是摘星人,也是造梦者。 🚀 每一次编译都是新的征程,每一个bug都是未解的谜题。让我们携手,在0和1的星河中,书写属于开发者的浪漫诗篇。 目录 摘要 什么是扣子空间? 如何用扣子空间生成AI健身私教? 1. 用扣子空间生成网页 2. 体验生成的网页 为什么选择扣子空间的生成AI健身私教? 1. 精准内容生成 2. 极速响应与动态优化 为什么选择扣子空间生成AI健身私教? 代码示例:生成AI健身私教网页 1. 开发者输入Prompt(自然语言描述需求) 2. 扣子空间返回HTML代码(示例) 3. 开发者二次优化(通过对话调整) 扣子空间 vs 其他平台(开发者视角) 适用开发者场景 加入扣子空间的创意社区:激发无限可能 如何加入创意社区?

AI辅助开发探索:让快马AI解析并实现7446ccn资料大全更新中的智能推荐功能

AI辅助开发探索:让快马AI解析并实现7446ccn资料大全更新中的智能推荐功能 最近在关注7446ccn资料大全的最新版本更新,发现他们引入了一个很实用的功能——智能推荐算法。这个功能可以根据用户的浏览历史自动推荐相关资料,听起来就很方便。作为一个开发者,我很好奇这个功能背后的实现逻辑,于是决定用AI辅助开发的方式,来探索一下如何快速实现类似的功能原型。 智能推荐功能分析 首先,我们需要明确这个功能的核心需求: 1. 记录用户的浏览历史(这里简化为关键词数组) 2. 根据历史记录匹配资料库中的相关内容 3. 展示推荐结果给用户 这个功能看似简单,但涉及到用户行为分析、内容匹配算法和界面交互等多个环节。传统开发方式可能需要花费不少时间在设计和编码上,但借助AI辅助开发,我们可以大大加快这个过程。 界面原型设计 使用AI辅助开发工具,我们可以快速生成一个简单的界面原型: 1. 用户历史记录区域:显示最近浏览的关键词列表 2. 生成推荐按钮:触发推荐算法 3. 推荐结果区域:展示匹配的资料列表 这个界面不需要从零开始设计,只需要描述清楚需求,AI就能生成可

技术拆解:P2P组网如何一键远程AI

技术拆解:P2P组网如何一键远程AI

文章目录 * **远程访问AI服务的核心是什么?** * **从暴露服务到连接设备** * **核心组件与交互解析** * **安全架构深度剖析** * **一键安装脚本的技术实现** * **# Windows** * **#macOS** * **#Linux** * **与AI工作流的结合实践** 远程访问AI服务的核心是什么? 你自己在电脑或者服务器上装了AI服务,比如大语言模型、Stable Diffusion这些,但是有个头疼的事儿:外面的人或者你在别的地方,怎么既安全又方便地连上这些本地的服务?以前的办法要么得有公网IP,还得敲一堆命令行用SSH隧道,要么就是直接开端口映射,等于把服务直接晾在公网上,太不安全了。 今天咱们就好好说说一种靠P2P虚拟组网的办法,还拿个叫节点小宝的工具举例子,看看它怎么做到不用改啥东西,点一下就装好,还能建个加密的通道,实现那种“服务藏得好好的,想连就能直接连上”的安全远程访问方式。 从暴露服务到连接设备 核心思路转变在于:不再尝试将内网服务端口暴露到公网(一个危险的攻击面),而是将外部访问设