无人船模型辨识

文章介绍了船舶运动的不同建模方法,如Abkowitz模型和MMG模型,以及在线辨识技术在无人艇和水下潜航器控制中的应用,包括一阶线性模型辨识和数据驱动的神经网络建模。此外,还讨论了自抗干扰控制和模型参考自适应控制在航迹控制中的重要性。
摘要由CSDN通过智能技术生成

一、船舶运动模型

国内外学者常将船体假设为刚体,基于刚体运 动理论研究船舶操纵运动建模问题,建立的模型主
要有 Abkowitz 整体型模型   MMG 分离型模型 mathematical modeling group model) 矩阵向量模   响应型模型等4个类型。Abkowitz整体型模 型是基于3阶泰勒级数展开建立船舶运动状态变量 与推进系统参量之间的函数,以描述作用于船体、螺旋桨、舵,以及其相互间作用的水动力和力矩。该模 型在描述船舶操纵运动上具有较高精度,但模型极其复杂,涉及大量参数,并且有些参数无法辨识,无任何物理意义。MMG分离型模型分别对作用于船体、螺旋桨、舵,以及其相互作用的力和力矩进行分析建模。模型中的各参数均具有物理意义,但在保证足够精确度的前提下模型有较多参数且非线性强,使得模型参数辨识变得困难。矩阵向量模型由Fossen提出,以矩阵向量的形式描述作用于船舶的力和力矩,方便分析船舶的稳定性和被动性,以便于船舶运动控制器的设计。响应型模型描述的是船首对操舵的响应关系,最具代表的是 Nomoto一阶 / 二阶线性和非线性模型

二、模型辨识方法

1、在线辨识

研究典型动力系统故障在线辨识与重构控制技术,同时基于运载与控制能力在线评估技术,稳定裕度在线辨识的参数重构控制技术,实现目标的在线变更,轨迹在线规划等功能
通过对闭环系统施加激励,采用频域辨识方法,由输入输出数据求解系统的频率特性函数,得到系统的稳定裕度 。基于稳定裕度在线辨识结果,采用自适应调参控制。
(1)一阶线性模型辨识
     [1]  等. 无人 艇艏 计.中国航海2021
    在 受外 环境 影响导 响应 的情况 实现 艇艏 设计基 在线 动模 利用 小二乘 响应 行在线 识。依 在线 计基 艇艏
(2)数据驱动辨识
[2]耿令波,等:数据驱动的水下潜航器在线建模及运动控制技术.数字海洋与水下攻防2021
    借鉴机器翻译领域广泛使用的 Transformer 网络结构,在其基础上进行一定适应性改造,得到
用于水下潜航器建模的神经网络模型。
   编码器由一维卷积构成,主要接收历史数据,用于对潜航器当前所处状态进行学习。解码器由
LSTM 构成,主要接收未来输入数据,用于在历史状态基础上驱动潜航器达到未来的状态。
Encoder 输入为过去 10个时间步的状态量及操纵控制量,状态量包括俯仰角、横滚角、加速度及
角速度,操纵控制量包括舵角控制量、推进器控制量。

三、无模型航迹控制

1、自抗干扰控制

算法运用数据驱动思想,将作用于被控系统的所有不确定因素均视为未知扰动,根据系统输入输出信息对未知扰动进行实时估计并给予补偿 [8],结构简单,易于工程实现,已成功运用于机器人 、风电场等众多领域的实际应用中。

[1] 李诗杰.船舶自抗扰无模型自适应航迹控制.中国舰船研究2023

四、模型参考自适应控制

在自适应控制中,模型参考自适应控制(Model Reference Adaptive Control,MRAC)是一种常见的方法。MRAC旨在将被控对象的输出与参考模型的输出匹配,通过在线调整控制器参数来实现这个目标。它基于一个模型参考器,该参考器包含所期望的系统响应特性。控制器的参数通过不断观测系统输出和参考模型输出之间的差异,并通过适应算法进行更新,以实现输出的匹配。

模型参考自适应控制的关键步骤包括:

  1. 设计参考模型:确定期望的系统响应特性,并将其表示为参考模型的输出。

  2. 确定控制器结构:选择适当的控制器结构,以便能够根据误差信号实时调整控制器参数。

  3. 定义误差信号:计算系统输出与参考模型输出之间的差异,作为误差信号。

  4. 设计自适应算法:根据误差信号和适应规则,设计控制器参数更新算法,以实现误差的最小化。

  5. 实施控制器:将设计好的控制器与被控对象连接起来,通过不断观测系统输出和参考模型输出之间的误差,进行参数调整。

需要注意的是,模型参考自适应控制需要对被控对象的动态特性有一定的了解,并且需要进行系统辨识来获取系统模型。此外,控制器参数的收敛性和稳定性也是需要考虑的问题。

模型参考自适应控制在许多领域都有应用,例如飞行器控制、机器人控制、工业过程控制等。它能够应对系统动态特性的变化和不确定性,提供更好的控制性能和鲁棒性。

Regenerate response

### 回答1: 一阶Nomoto模型是一种常用的无人船动力学建模方法,用于描述船舶的姿态响应。在Matlab中,可以使用传统的数值计算方法来建立该模型。 首先,需要定义模型的参数,包括船舶的质量、艏向力和船舶重心的高度等。然后,根据Nomoto模型的动态方程,编写相应的微分方程,并将其转化为离散形式。 接下来,使用Matlab中的ode45函数进行数值求解。ode45函数是一个常用的求解常微分方程的函数,它可以自动选择合适的步长进行求解。 在求解过程中,需要定义输入信号,可以使用理论上的输入信号或者实际采集到的数据。根据输入信号和Nomoto模型的动态方程,将其转化为初始条件和边界条件。 最后,通过绘制各个输出响应的曲线,可以对船舶的姿态响应进行分析和评估。可以绘制船舶的横倾角、艏向角等与时间的关系曲线,从曲线的形状和变化趋势来判断船舶的稳定性和控制性能。 需要注意的是,在建立模型时,可以根据实际情况对模型进行修正和优化,以提高模型的准确性和可靠性。同时,还可以利用Matlab中的系统辨识工具对模型进行参数辨识和系统特性分析,以进一步优化建模效果。 综上所述,在Matlab中建立一阶Nomoto模型无人船建模工作,可以帮助船舶工程师分析和评估船舶的姿态响应,为船舶的设计和控制提供重要参考。 ### 回答2: 一阶Nomoto模型是一种用于描述船舶姿态动力学行为的数学模型。它是基于船舶的动力学方程以及相关参数推导出来的。 在MATLAB中,可以通过数值求解的方法建立一阶Nomoto模型的仿真模型。具体步骤如下: 首先,需要确定模型中的参数,包括船舶质量、舵角、船舶的惯性系数、阻尼系数等等。这些参数可以通过实验测定或者适当的估计得到。 其次,利用船舶的动力学方程建立数学模型。一阶Nomoto模型假设船舶的响应是一阶传递函数,包括一个传递函数系数和一个延迟时间。形式上可以表示为:G(s)=K/(τs+1),其中K为传递函数系数,τ为延迟时间。 接下来,在MATLAB中编写相应的代码。可以使用MATLAB的控制系统工具箱中的Transfer function函数来表示一阶传递函数模型,以及使用Step函数模拟输入信号。 然后,设置模拟的时间范围、步长和舵角输入信号等参数。可以通过调整这些参数来模拟不同的情况。 最后,运行模型并得到仿真结果。可以绘制船舶的姿态响应曲线,例如船舶的横摇角随时间的变化曲线。通过分析曲线,可以了解船舶的姿态控制性能以及评估可能的改进方案。 需要注意的是,建立一阶Nomoto模型只是对船舶姿态动力学行为的简化描述,实际船舶的动力学行为可能更加复杂。因此,在进行具体应用时,需要综合考虑实际的工况和船舶特性来进行建模和仿真分析。 ### 回答3: 一阶Nomoto模型是一种常用于描述船舶运动动力学行为的数学模型。在Matlab中,我们可以使用微分方程的形式建立这个模型。 首先,我们需要定义模型的变量和参数。假设我们要建立的是船舶的横向运动模型,那么可以定义以下变量和参数: - x: 船舶横向位移 - u: 操纵输入(例如舵角) - v: 船舶横向速度 - m: 船舶质量 - Xdelta: 划船力矩系数 - Xv: 划船阻力系数 - X: 划船阻力 - Xv_dot: 划船阻尼力矩系数 - tau: 划船阻尼力矩时间常数 然后,我们可以建立微分方程描述船舶的运动行为: m * v_dot = -X + Xdelta * u tau * v_dot_dot + v_dot = -Xv * v + Xv_dot * u 将上述微分方程转化为Matlab代码,则可以得到模型建模过程,如下所示: function dxdt = nomoto_model(t, x, u) % 参数定义 m = 1000; % 船舶质量 Xdelta = 10; % 划船力矩系数 Xv = 1000; % 划船阻力系数 Xv_dot = 200; % 划船阻尼力矩系数 tau = 10; % 划船阻尼力矩时间常数 % 微分方程描述 dxdt = zeros(2, 1); dxdt(1) = x(2); % 船舶横向速度 dxdt(2) = (-Xv * x(2) + Xv_dot * u) / (m * tau) - (Xdelta * u) / m; % 船舶横向加速度 end 在使用这个模型时,我们可以通过输入操纵量u的变化来模拟船舶的运动行为。当需要求解船舶横向位移和速度随时间的变化时,可以使用Matlab的ode45函数进行数值求解。 希望以上的回答能够帮到您!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Cretheego

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值