news 2026/4/16 12:54:47

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于文献的‘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倍——这说明足够的预测步长对海上运动的惯性补偿至关重要。

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

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

多模态学习架构

一、什么是多模态学习? 多模态(Multimodal)指的是不同类型的数据形式:文本、图像、音频、视频、点云、传感器信号等。人类天然就是多模态学习 者——同时通过视觉、听觉、听觉来理解世界。多模态学习的核心目标是让模型能够联合理…

作者头像 李华
网站建设 2026/4/13 5:10:20

再见了ThreadLocal,我决定用ScopedValue!

今天我们来聊聊一个即将改变我们编程习惯的新特性——ScopedValue。有些小伙伴在工作中,一提到线程内数据传递就想到ThreadLocal,但真正用起来却遇到各种坑:内存泄漏、数据污染、性能问题等等。其实,ScopedValue就像ThreadLocal的…

作者头像 李华
网站建设 2026/4/14 1:06:37

【机器人路径规划】基于6种算法(黑翅鸢优化算法BKA、SSA、MSA、RTH、TROA、COA)求解机器人路径规划研究附Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。🍎 往期回顾关注个人主页:Matlab科研工作室🍊个人信条:格物致知,完整Matlab代码及仿真咨询…

作者头像 李华
网站建设 2026/4/14 22:58:08

华为OD机试 B卷 - 稀疏矩阵扫描 (C++ Python JAVA JS GO)

稀疏矩阵扫描 华为OD机试B卷 - 华为OD上机考试B卷 100分题型 华为OD机试真题目录点击查看: 华为OD机试真题题库目录|机考题库 算法考点详解 题目描述 如果矩阵中的许多系数都为零,那么该矩阵就是稀疏的。对稀疏现象有兴趣是因为它的开发可以带来巨大…

作者头像 李华
网站建设 2026/4/15 23:48:02

Go Module构建

添加依赖包 在Go Module项目中添加新依赖包,可以通过修改源码并执行相关命令完成。以添加github.com/google/uuid为例: package mainimport ("github.com/google/uuid""github.com/sirupsen/logrus" )func main() {logrus.Println(&…

作者头像 李华