当前位置: 首页 > news >正文

基于文献的‘12-文献代码复现‘:非线性模型预测控制(NMPC)多无人船USV编队控制form...

12-文献代码复现,基于非线性模型预测控制nmpc的多无人船USV编队控制formation control 。 本代码由matlab中的simulink 模块搭建,采用船舶的fossen模型建模,具体过程可以参见文献的内容。 输出的算例为5条船的情况如下图

清晨的渔港飘着海腥味,五艘无人船在晨雾中悄然启动。它们的运动轨迹看似随意,却始终保持菱形编队稳定前行——这背后是NMPC算法在持续求解最优控制量。今天咱们拆解这个用Simulink实现的五船编队控制方案,从动力学模型到预测控制器,看看如何用代码实现海上芭蕾。

船舶动力学建模

打开Simulink库里的黄色模块,Fossen模型的核心是这组微分方程:

function dxdt = fossenModel(t,x,u) m = 120; % 质量 D = diag([70 80 30]); % 阻尼系数 M = diag([m m m]); nu = x(4:6); % 速度向量 tau = u(1:3); % 控制力 dxdt(1:3,1) = R(x(3))*nu; % 位置导数 dxdt(4:6,1) = M\(tau - D*nu - cross(nu, M*nu)); end function R = R(psi) R = [cos(psi) -sin(psi) 0; sin(psi) cos(psi) 0; 0 0 1]; end

这个旋转矩阵R把船体坐标系的速度转换到惯性坐标系。注意cross(nu, M*nu)项处理了科里奥利力,实测中发现当航速超过2m/s时,忽略这项会导致模型发散。

预测控制器设计

NMPC的核心是滚动优化,这个代价函数模块计算未来N步的误差:

function J = costFunction(predictedStates, references) Q = diag([10,10,5,1,1,0.5]); % 状态权重 R = diag([0.1,0.1,0.05]); % 控制量权重 J = 0; for k = 1:predictionHorizon state_error = predictedStates(:,k) - references(:,k); J = J + state_error'*Q*state_error + u_sequence(:,k)'*R*u_sequence(:,k); end end

调试时发现Q矩阵对航向角的权重过高会导致控制量剧烈震荡,最终采用指数衰减权重:前3步位置权重是后3步的3倍,这样既保证初始快速响应,又避免末端过冲。

编队拓扑实现

五船采用leader-follower结构,这个通讯拓扑生成模块动态计算期望位姿:

function des_pose = formation_pattern(leader_pose) % 菱形编队参数 offsets = [0 0 0; % Leader 15 -8 pi/6; 15 8 -pi/6; -10 12 pi/4; -10 -12 -pi/4]; for i = 2:5 des_pose(i,:) = leader_pose + ... [offsets(i,1)*cos(leader_pose(3)) - offsets(i,2)*sin(leader_pose(3)), ... offsets(i,1)*sin(leader_pose(3)) + offsets(i,2)*cos(leader_pose(3)), ... offsets(i,3)]; end end

实际运行中出现过跟随船"画圈"现象,排查发现是坐标变换时漏掉了航向角偏移量的坐标系转换。修正后加入的offsets(i,3)项确保了期望航向角的相对计算。

仿真结果显示,在3级海况(波浪干扰约0.5m)下,编队位置误差能稳定在1.2米以内。有意思的是,当把预测时域从10步缩短到5步时,虽然计算量降低40%,但转弯时的跟踪误差增大了3倍——这说明足够的预测步长对海上运动的惯性补偿至关重要。

文末彩蛋:尝试在风浪干扰模块中加入周期性横摇扰动后,发现控制器会自动生成蛇形航线来抵消侧向漂移,这或许解释了现实中船舶在风浪中为何会走出之字路线。

http://www.jsqmd.com/news/84637/

相关文章:

  • 【保姆级教程】爆火开源项目 Next AI Draw.io 上手指南:一句话画流程图
  • 韩语教程资源合集
  • 如何用DSPy优化RAG prompt示例
  • 英语口语资源合集
  • 鸿蒙PC UI控件库 - TextInput 文本输入框详解
  • 链表中的回文判断
  • 鸿蒙PC UI控件库 - PasswordInput 密码输入框详解
  • 【大模型预训练】07-数据处理流程设计:从原始数据到模型输入的端到端处理链路
  • 基于VMD-CPA-KELM-IOWAl-CSA-LSSVM碳排放的混合预测模型研究附Matlab代码
  • 【机器人路径规划】基于6种算法(黑翅鸢优化算法BKA、SSA、MSA、RTH、TROA、COA)求解机器人路径规划研究附Matlab代码
  • 基于6种最新算法(小龙虾优化算法COA、MSA、RTH、NOA、BFO、SWO)求解机器人路径规划研究附Matlab代码
  • 【数据结构】排序
  • 【路径规划】基于RRT快速探索随机树算法在包含圆形障碍物的环境中寻找从起点到目标点的路径附matlab代码
  • 【太阳能学报EI复现】基于粒子群优化算法的风-水电联合优化运行分析附Matlab代码
  • go构建web服务
  • 夜莺监控设计思考(三)时序库、agent 的一些设计考量
  • 系统基础服务
  • 数据结构:二叉排序树,平衡二叉树,红黑树的介绍
  • 软件测试面试题集合
  • AI中的优化5-无约束非线性规划之凸性
  • Go Module构建
  • 【time-rs】Duration 结构体详解
  • 深圳|昆明|广州|东莞-奶茶原料批发供应商|奶茶原料供应商|奶茶原料批发市场|奶茶原料批发|奶茶原料推荐|奶茶原料公司——圣旺水吧 - 老百姓的口碑
  • Python基础知识的总结(2)
  • Go程序的执行顺序
  • Java 大视界 -- 基于 Java 的大数据分布式计算在地球物理勘探数据处理与地质结构建模中的应用
  • TDengine 新性能基准测试工具 taosgen
  • Go语言变量
  • 基于天牛须(BAS)与NSGA-Ⅱ混合算法的交直流混合微电网多场景多目标优化调度附Matlab代码
  • JavaWeb-Request应用与Cookie[特殊字符]️Session