MATLAB 模型参考自适应控制 - Model Reference Adaptive Control

本文主要是介绍MATLAB 模型参考自适应控制 - Model Reference Adaptive Control,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

系列文章目录


文章目录

  • 系列文章目录
  • 前言
  • 一、参考模型
  • 二、扰动与不确定性模型
  • 三、直接 MRAC
    • 名义模型
    • 参数更新
    • 间接 MRAC
    • 估计器模型和控制器增益
    • 参数更新
    • 学习修正
    • 参考文献


前言

模型参考自适应控制模块计算控制动作,使不确定的受控系统跟踪给定参考被控对象模型的行为。使用该程序块,可以实现以下模型参考自适应控制 (MRAC) 算法。

  • 直接 MRAC - 根据被控对象与参考工厂模型状态之间的实时跟踪误差,估算反馈和前馈控制器增益。

  • 间接 MRAC - 根据参考设备模型与估计系统状态之间的跟踪误差,估计被控对象系统的参数。然后,根据估计系统和参考模型的参数推导出反馈和前馈控制器增益。

直接和间接 MRAC 还能估算被控系统的外部干扰和不确定性模型。然后,控制器在计算控制动作时使用该模型对干扰和不确定性进行补偿。

在这两种情况下,控制器都会根据跟踪误差实时更新估计参数和干扰模型。


一、参考模型

对于直接和间接 MRAC 而言,以下参考被控对象模型是理想的系统,它描述了您在实践中想要实现的理想行为。
x ˙ m ( t ) = A m x m ( t ) + B m r ( t ) {\dot{x}}_{m}(t)=A_{m}x_{m}(t)+B_{m}r(t) x˙m(t)=Amxm(t)+Bmr(t)
此处

  • r(t) 是外部参考信号。

  • xm(t) 是被控对象模型的状态。由于 r(t) 已知,因此可以通过模拟参考模型得到 xm(t)。

  • Am 是恒定状态矩阵。对于一个稳定的参考模型,Am 必须是一个 Hurwitz 矩阵,其每个特征值都必须是严格的负实部。

  • Bm 是控制有效矩阵。

二、扰动与不确定性模型

模型参考自适应控制模块维护着受控系统中干扰和模型不确定性的内部模型 u a d u_{a d} uad
u a d = w T ϕ ( x ) u_{a d}=w^{T}\phi(x) uad=wTϕ(x)
w 是控制器根据跟踪误差实时更新的自适应控制权重向量。

要定义 ϕ(x),可以使用以下特征定义之一。

  • 被控对象的状态向量 - 这种方法可能无法充分反映系统的不确定性。在不了解干扰和模型不确定性的复杂性时,使用状态作为特征可能是一个有用的起点。

  • 高斯径向基函数 - 当扰动和模型的不确定性是非线性的,且扰动模型的结构未知时,请使用此选项。径向基函数要求事先了解模型的运行域,这在某些情况下可能比较困难。

  • 单隐层神经网络 - 当扰动和模型的不确定性是非线性的,扰动模型的结构未知,并且您没有运行域的先验知识时,请使用此选项。神经网络是一种通用函数近似器,可以近似任何连续函数。

  • 提供给控制器模块的外部源 - 使用该选项可自定义特征向量。如果您知道干扰和不确定性模型的结构,则可以使用该选项。例如,您可以使用自定义特征向量来确定特定的未知被控对象参数。

三、直接 MRAC

直接 MRAC 控制器的控制结构如下

在这里插入图片描述

控制器计算控制输入 u(t) 的方法如下
u ( t ) = k x x ( t ) + k r r ( t ) − u a d u a d = w T ϕ ( x ) \begin{array}{c}{{u(t)=k_{x}x(t)+k_{r}r(t)-u_{a d}}}\\ {{u_{a d}=w^{T}\phi(x)}}\end{array} u(t)=kxx(t)+krr(t)uaduad=wTϕ(x)

此处

  • x(t) 是受控系统的状态。

  • r(t) 是外部参考信号。

  • kx 和 kr 分别是反馈和前馈控制器增益。

  • u a d u_{a d} uad 是根据扰动模型得出的自适应控制分量。
    ϕ ( x ) \phi(x) ϕ(x) 包含干扰模型特征。

  • w 是自适应扰动模型权重向量。

  • V 是隐藏层权重向量。

对于单隐层神经网络, u a d u_{a d} uad
u a d = w T σ ( V T x ) u_{a d}=w^{T}\sigma(V^{T}x) uad=wTσ(VTx)
此处

  • V 是隐层权重向量。

  • σ 是 sigmoid 激活函数。

控制器计算受控系统状态与参考模型状态之间的误差 e(t)。然后利用该误差实时调整 kx、kr 和 w 的值。

名义模型

受控系统通常具有建模不确定性和外部干扰,其标称状态方程如下。控制器在更新控制器参数时,会使用这一预期的标称被控对象行为。
x ˙ ( t ) = A x ( t ) + B ( u ( t ) + f ( x ) ) {\dot{x}}(t)=A x(t)+B(u(t)+f(x)) x˙(t)=Ax(t)+B(u(t)+f(x))
这里的

  • x(t) 是要控制系统的状态。

  • u(t) 是控制输入。

  • A 是恒定的状态转换矩阵。

  • B 是恒定的控制有效矩阵。

  • f(x) 是系统中匹配的不确定性。

参数更新

直接 MRAC 控制器使用以下公式更新状态矢量、径向基函数和外部源特征定义的控制器增益和干扰模型权重
k ˙ x = Γ x x ( t ) e T ( t ) P B k ˙ r = Γ r r ( t ) e T ( t ) P B w ˙ = Γ w ϕ ( x ) e T ( t ) P B \begin{array}{l}{{\dot{k}_{x}=\Gamma_{x}x(t)e^{T}(t)P B}}\\ {{\dot{k}_{r}=\Gamma_{r}r(t)e^{T}(t)P B}}\\ {{\dot{w}=\Gamma_{w}\phi(x)e^{T}(t)P B}}\end{array} k˙x=Γxx(t)eT(t)PBk˙r=Γrr(t)eT(t)PBw˙=Γwϕ(x)eT(t)PB
单隐层干扰模型更新方程使用相同的控制器增益更新和以下更新方程。
w ˙ = − ( σ ( V T x ) − σ ′ ( V T x ) V T x ) e T ( t ) P B Γ w V ˙ = − Γ V x e T ( t ) P B w T σ ( V T x ) \begin{array}{l}{{\dot{w}=-(\sigma(V^{T}x)-{{\sigma}}^{\prime}(V^{T}x)V^{T}x){{e}}^{T}(t){{P}}{{B}}\Gamma_{w}}}\\ {{\dot{V}=-\Gamma{{V}}{{x}}{{e}}^{T}(t){{P}}{{B}}w^{T}{{\sigma}}(V^{T}x)}}\end{array} w˙=(σ(VTx)σ(VTx)VTx)eT(t)PBΓwV˙=ΓVxeT(t)PBwTσ(VTx)

Here, P is the solution to the following Lyapunov function based on the reference model state matrix and B is the control effective matrix from the nominal plant model.
A m T P + P A m + Q = 0 A_{m}^{T}P+P A_{m}+Q=0 AmTP+PAm+Q=0
这里,Q 是大小为 N 乘 N 的正定矩阵,其中 N 是状态向量 x(t) 的大小

间接 MRAC

间接 MRAC 控制器的控制结构如下。参考模型为

在这里插入图片描述

控制器计算控制输入 u(t) 的方法如下
u ( t ) = k x x ( t ) + k r r ( t ) − u a d u a d = w T ϕ ( x ) \begin{array}{c}{{u(t)=k_{x}x(t)+k_{r}r(t)-u_{a d}}}\\ {{u_{a d}=w^{T}\phi(x)}}\end{array} u(t)=kxx(t)+krr(t)uaduad=wTϕ(x)

这里:

  • x ^ ( t ) \hat{x}(t) x^(t) 是由估计模型产生的受控系统估计状态。

  • r(t) 是外部参考信号。

  • kx 和 kr 分别是反馈和前馈控制器增益。

  • u a d u_{a d} uad 是根据扰动模型得出的自适应控制分量。

  • ϕ ( x ) \phi(x) ϕ(x) 包含干扰模型特征。

  • w 是自适应扰动模型权重向量。

控制器计算实际系统状态和估计系统状态之间的误差 e(t)。然后利用该误差实时调整 w 的值。控制器还利用 e(t) 实时更新估计模型的参数。增益 kx 和 kr 的值来自估计模型和参考模型的参数。

估计器模型和控制器增益

间接 MRAC 控制器包含以下受控系统的估计模型。
x ^ ˙ ( t ) = A ^ x ( t ) + B ^ u ( t ) \dot{\hat{x}}(t)=\hat{A}x(t)+\hat{B}u(t) x^˙(t)=A^x(t)+B^u(t)
这里:

  • x ^ ˙ ( t ) \dot{\hat{x}}(t) x^˙(t) 是估计的系统状态。

  • u ( t ) u(t) u(t) 是控制输入。

  • A ^ \hat{A} A^ 是估计器的状态转换矩阵。

  • B ^ \hat{B} B^ 是估计器的控制有效矩阵。

在运行过程中,控制器基于估计误差 e(t)更新 A ^ \hat{A} A^ B ^ \hat{B} B^

间接 MRAC 控制器不直接估算控制器增益,而是采用基于动态反演的方法,从参考模型和估算模型的参数中推导出反馈增益 k x k_x kx 和前馈增益 k r k_r kr,具体如下。
k r = B m B ^ k x = 1 B ^ ( A m − A ^ ) \begin{array}{c}{{k_r={\displaystyle\dfrac{B_m}{\hat{B}}}}}\\ {{k_{x}={\displaystyle\frac{1}{\hat{B}}}\left(A_m-\hat{A}\right)}}\end{array} kr=B^Bmkx=B^1(AmA^)
这里, 1 B ^ \displaystyle\frac{1}{\hat{B}} B^1 是矩阵 B ^ \hat{B} B^ 的 Moore-Penrose 摩尔-彭罗斯伪逆。

参数更新

间接 MRAC 控制器使用以下公式更新状态矢量、径向基函数和外部源特征定义的估计模型参数和干扰模型权重
A ^ ˙ = Γ a x ( t ) e T ( t ) P B ^ ˙ = Γ b u ( t ) e T ( t ) P w ˙ = Γ w ϕ ( x ) e T ( t ) P B \begin{array}{l}{{\dot{\hat{A}}=\Gamma_{a}x(t)e^{T}(t)P}}\\ {{\dot{\hat{B}}=\Gamma_{b u(t)}e^T{(t)P}}}\\ {{\dot{w}=\Gamma_{w}\phi(x)e^T{(t)P B}}}\end{array} A^˙=Γax(t)eT(t)PB^˙=Γbu(t)eT(t)Pw˙=Γwϕ(x)eT(t)PB
单隐层干扰模型更新方程使用相同的估计模型参数更新和以下更新方程。
w ˙ = − ( σ ( V T x ) − σ ′ ( V T x ) V T x ) e T ( t ) P B Γ w V ˙ = − Γ V x e T ( t ) P B w T σ ( V T x ) \begin{array}{l}{{\dot{w}=-(\sigma(V^{T}x)-{{\sigma}}^{\prime}(V^{T}x)V^{T}x){{e}}^{T}(t){{P}}{{B}}\Gamma_{w}}}\\ {{\dot{V}=-\Gamma{{V}}{{x}}{{e}}^{T}(t){{P}}{{B}}w^{T}{{\sigma}}(V^{T}x)}}\end{array} w˙=(σ(VTx)σ(VTx)VTx)eT(t)PBΓwV˙=ΓVxeT(t)PBwTσ(VTx)
这里,P 是以下 Lyapunov 函数的解。
k τ T P + P k τ + Q = 0 k_{\tau}^{T}P+P k_{\tau}+Q=0 kτTP+Pkτ+Q=0

kτ 是估计器反馈增益。默认情况下,该值与参考模型状态转换矩阵 Am 相对应。不过,也可以指定不同的估计器反馈增益值。

学习修正

对于直接和间接 MRAC,为了在更高的学习率下增加稳健性,可以修改参数更新,加入一个可选的动量项。您可以从两种可能的学习修改方法中选择一种:sigma 和 e-modification。

对于西格玛修正,每次参数更新的动量项都是动量权重参数 σ 与当前参数值的乘积。例如,以下直接 MRAC 控制器的更新方程就包含了 σ 修正项。
k ˙ x = Γ x x ( t ) e T ( t ) P B + σ k x k ˙ r = Γ r r ( t ) e T ( t ) P B + σ k x w ˙ x = Γ w ϕ ( t ) e T ( t ) P B + σ w \begin{array}{l}{{\dot{k}_{x}=\Gamma_{x}x(t)e^{T}(t)P B+\sigma k_{x}}}\\ {{\dot{k}_{r}=\Gamma_{r}r(t)e^{T}(t)P B+\sigma k_{x}}}\\ {{\dot{w}_{x}=\Gamma_{w}\phi(t)e^{T}(t)P B+\sigma w}}\end{array} k˙x=Γxx(t)eT(t)PB+σkxk˙r=Γrr(t)eT(t)PB+σkxw˙x=Γwϕ(t)eT(t)PB+σw
对于 e-修正,控制器通过误差矢量的规范对 sigma-修正动量项进行缩放。例如,以下间接 MRAC 控制器的更新方程就包含了一个 e 修正项。
A ^ ˙ = Γ a x ( t ) e T ( t ) P + σ ∣ e ( t ) ∣ A ^ B ^ ˙ = Γ b u ( t ) e T ( t ) P + σ ∣ e ( t ) ∣ B ^ w ˙ x = Γ w ϕ ( t ) e T ( t ) P B + σ ∣ e ( t ) ∣ w \begin{array}{l}{{\dot{\hat{A}}=\Gamma_{a}x(t)e^{T}(t)P+\sigma|e(t)|\hat{A}}}\\ {{\dot{\hat{B}}=\Gamma_{b}u(t)e^{T}(t)P+\sigma|e(t)|\hat{B}}}\\ {{\dot{w}_{x}=\Gamma_{w}\phi(t)e^{T}(t)P B+\sigma|e(t)|w}}\end{array} A^˙=Γax(t)eT(t)P+σe(t)A^B^˙=Γbu(t)eT(t)P+σe(t)B^w˙x=Γwϕ(t)eT(t)PB+σe(t)w
要调整这两种方法的学习修正量,可改变动量权重参数 σ 的值。

参考文献

[1] Ioannou, Petros A., and Jing Sun. Robust adaptive control, Courier Corporation, 2012.

[2] Narendra, Kumpati S, and Anuradha M Annaswamy. Stable Adaptive Systems. Courier Corporation, 2012.

[3] Narendra, Kumpati S., and Anuradha M. Annaswamy. “Robust Adaptive Control.” In 1984 American Control Conference, 333–35. San Diego, CA, USA: IEEE, 1984. https://doi.org/10.23919/ACC.1984.4788398

这篇关于MATLAB 模型参考自适应控制 - Model Reference Adaptive Control的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/444957

相关文章

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

图神经网络模型介绍(1)

我们将图神经网络分为基于谱域的模型和基于空域的模型,并按照发展顺序详解每个类别中的重要模型。 1.1基于谱域的图神经网络         谱域上的图卷积在图学习迈向深度学习的发展历程中起到了关键的作用。本节主要介绍三个具有代表性的谱域图神经网络:谱图卷积网络、切比雪夫网络和图卷积网络。 (1)谱图卷积网络 卷积定理:函数卷积的傅里叶变换是函数傅里叶变换的乘积,即F{f*g}

秋招最新大模型算法面试,熬夜都要肝完它

💥大家在面试大模型LLM这个板块的时候,不知道面试完会不会复盘、总结,做笔记的习惯,这份大模型算法岗面试八股笔记也帮助不少人拿到过offer ✨对于面试大模型算法工程师会有一定的帮助,都附有完整答案,熬夜也要看完,祝大家一臂之力 这份《大模型算法工程师面试题》已经上传CSDN,还有完整版的大模型 AI 学习资料,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

AI Toolkit + H100 GPU,一小时内微调最新热门文生图模型 FLUX

上个月,FLUX 席卷了互联网,这并非没有原因。他们声称优于 DALLE 3、Ideogram 和 Stable Diffusion 3 等模型,而这一点已被证明是有依据的。随着越来越多的流行图像生成工具(如 Stable Diffusion Web UI Forge 和 ComyUI)开始支持这些模型,FLUX 在 Stable Diffusion 领域的扩展将会持续下去。 自 FLU

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者