【无人船】基于模型预测控制(MPC)对USV进行自主控制研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥

🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。

⛳️座右铭:行百里者,半于九十。

 ⛳️赠与读者

👨‍💻做科研,涉及到一个深在的思想系统,需要科研者逻辑缜密,踏实认真,但是不能只是努力,很多时候借力比努力更重要,然后还要有仰望星空的创新点和启发点。当哲学课上老师问你什么是科学,什么是电的时候,不要觉得这些问题搞笑。哲学是科学之母,哲学就是追究终极问题,寻找那些不言自明只有小孩子会问的但是你却回答不出来的问题。建议读者按目录次序逐一浏览,免得骤然跌入幽暗的迷宫找不到来时的路,它不足为你揭示全部问题的答案,但若能让人胸中升起一朵朵疑云,也未尝不会酿成晚霞斑斓的别一番景致,万一它居然给你带来了一场精神世界的苦雨,那就借机洗刷一下原来存放在那儿的“躺平”上的尘埃吧。

     或许,雨过云收,神驰的天地更清朗.......🔎🔎🔎

💥1 概述

摘要
本文介绍了一个旨在自主驾驶无人水面车辆(USV)前往一组航点的模型预测控制(MPC)算法。该算法的设计被认为对在海洋环境中遇到的环境干扰具有鲁棒性。
由于本工作旨在作为概念验证,因此对USV和干扰的建模已经简化。对于真实世界的实施,应考虑更准确的建模。
介绍
这项工作是在前一项工作的基础上进行的,前一项工作的目标是自主控制USV通过一组航点。实施了一个带有恒定位置参考(即当前航点)跟踪的MPC算法,但这种控制方案并未取得良好的跟踪性能。问题可能源于在全局坐标系中对位置变量进行的优化是非线性的。因此,决定重新设计MPC策略,使优化更简单,使用角度和前向速度变量(在船舶坐标系中完全线性的表达)进入优化问题。
在这个新版本中,算法试图在恒定的时间范围内跟踪角度和前向速度的参考值。船舶模型以更简单但准确的方式重新编写,并编写了一个“智能”参考提供算法,使系统对干扰更具鲁棒性。
首先将讨论USV的建模,然后是使用的跟踪策略。接着将解释参考提供算法(包括处理干扰),最后将介绍MPC算法和所获得的结果。
USV建模
本部分解释了用于描述USV行为的物理学,并说明了如何对其进行建模以便用于MPC方案。
物理描述
所研究的USV具有类似双体船的结构,每个船体末端都有两个固定的推进器。
下图提供了船只及作用于其上的力的图形视图。

跟踪
之前的部分涉及船只本地坐标系中描述的变量。但为了将船只驶向航点,需要估计船只的位置 - 或进行测量。为了实现这一点,使用了一种称为“死航行”(dead reckoning)的技术。
死航行
技术上讲,死航行等同于在一个时间步长内对船只的速度进行积分,初始条件为实际位置。
由于船只的速度是在其自身的本地坐标系中获得的,因此其在全局坐标系中的位置取决于船只的角度。
同样,将使用状态空间系统来实现这一点。然而,这个系统将是非线性的。
MPC算法
本部分将描述MPC算法以及如何在Matlab中实现它。
之前的MPC控制方案是优化船只在平面上的位置,以驱动它到达下一个航点。这种方法并未取得良好的结果,因为轨迹在任何意义上都不是最佳的。
可能是由于一个糟糕的优化问题引起的,因为船只在全局平面上的位置是由一个非线性系统给出的 - 这是由于船只坐标系和全局坐标系之间的参考框架变换。
因此,决定使用在船只坐标系中轻松表达的变量。注意到船只的角度和巡航速度应该足以控制船只。由于它们可以在船只坐标系中轻松表达,它们应该提供一个更易处理的优化问题。
在建模部分描述的扩展状态空间系统将用于MPC算法 - 加入了干扰的𝐷𝑥项。即使已经用于非扩展系统,标准的𝐴、𝐵符号也将用于其矩阵。
结果
本部分将展示根据本文描述的MPC算法获得的结果。
用于验证该算法的仿真基于包含10个航点的基准轨迹。USV必须按照规定顺序到达这10个航点。这个测试已经在有干扰和无干扰的情况下进行过 - 在第二个图中,粉色箭头表示干扰的方向。
下面的图中从左到右、从上到下分别表示:USV轨迹与航点、施加在每个电机上的推力、前进速度及其参考值、用于提供算法参考的状态向量中的角度、用于MPC算法的状态向量中的角度和𝑦轴船只速度。
在下面的第一个图中 - 无干扰的仿真 - 主要目标显然已经实现:算法以相当优化的方式驱动船只绕过所有航点。然而,观察到船只前进速度存在偏差 - 添加积分增益可能会解决这个问题。并且在第1000个时间步骤左右出现了一个无法解释的角度漂移。

在第二张图中 - 有干扰的仿真 - 主要目标同样已经被清晰地实现。然而,除了前面段落中指出的两个问题外,还出现了另外两个问题:由于与“最佳”路径的距离没有被优化,MPC算法并不关心其轨迹,只要所有航点都被到达,从而导致非最佳轨迹。此外,船只的𝑦轴速度不是一个优化标准,因此所有干扰都通过MPC直接影响船只。问题在于两个电机的角度不可控制,使得校正𝑦轴速度变得困难。

详细文档及数学模型见第4部分。 

1. 无人船(USV)概述

1.1 定义与特性

无人水面艇(USV)是一种无需人工直接操控的水面机器人,具备自主/半自主航行能力,通过远程控制或预设程序执行任务。其核心优势包括:

  • 多功能性:适用于海洋勘测、环境监测、搜救、军事防御等场景。
  • 持久性:采用锂离子电池或太阳能供电,支持长时任务。
  • 安全性:替代有人船执行危险任务(如反海盗、水雷清除)。
1.2 分类与技术参数

USV按三类标准分类:

  • 自主等级:0级(遥控)至6级(协同自主)。
  • 排水量:微型(<1吨)至超大型(>100吨),影响任务负荷与适航性。
  • 航速:低速(<10节)至超高速(>50节),关联任务响应需求。

2. 模型预测控制(MPC)技术原理

2.1 核心机制

MPC是一种基于动态模型的前馈-反馈优化控制策略,其工作流程包括:

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值