当前位置: 首页 > 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.cnnetsun.cn/news/42660.html

相关文章:

  • 鸿蒙PC UI控件库 - PasswordInput 密码输入框详解
  • day37简单的神经网络@浙大疏锦行
  • 【水果识别】基于机器视觉苹果和香蕉的成熟度和大小检测附Matlab代码
  • JAVA的平凡之路——此峰乃是最高峰JVM-附加小菜-04
  • 【电力系统】电力系统优化与控制热液调度附Matlab代码和报告
  • 基于6种最新算法(小龙虾优化算法COA、MSA、RTH、NOA、BFO、SWO)求解机器人路径规划研究附Matlab代码
  • Golang实战:构建综合多头(逾期+反欺诈)风险查询的高性能客户端
  • 【TSP问题】基于蜣螂算法DBO和改进的蜣螂算法FADBO求解旅行商TSP问题(可根据自己的经纬度设置自己想要到达的地区)附Matlab代码
  • 【太阳能学报EI复现】基于粒子群优化算法的风-水电联合优化运行分析附Matlab代码
  • 数据结构:二叉排序树,平衡二叉树,红黑树的介绍
  • 软件复用的分类与实现
  • google服务
  • 进程PCB
  • 实战教程:1小时掌握逆向Unity游戏 (共13课时)
  • [从零构建操作系统]08 函数调用时栈的底层行为解析
  • 力扣hot100:搜索插入位置
  • Java冷启动全指南:从原理到实战优化
  • 测试 - 单元测试(JUnit)
  • C++中多态
  • c++经典练习题-多分支
  • qt为什么转向用cmake放弃qmake
  • 云屋音视频 SDK 凭何成为信创技术困局的 “破局者”?
  • 纯电动汽车动力经济性仿真:Cruise与Simulink联合仿真(2015版),包含BMS、再...
  • 【怎么理解maven中的镜像和仓库?】
  • comsol枝晶生长,沉积模型,包括:典型,形状成核,随机成核,均匀沉积,雪花晶形成过程。 适...
  • 终极指南:Qwen3-30B-A3B多GPU分布式推理完整解决方案
  • 腾讯混元语音驱动数字人技术:重塑动态视频生成新范式
  • 【MicroPython编程-ESP32篇】-Web页面显示DHT11传感器数据
  • DCDC电池模型:基于Matlab 2018b及以上的应用
  • Day 38 - Dataset 和 DataLoader