自适应反步控制:理论与设计

自适应反步控制

文章目录

  • 自适应反步控制
    • 1. 基本思想
      • A. 第一步
      • B. 第二步

1. 基本思想

基于传统反步法,考虑了系统方程中以线性形式出现的未知参数。核心思想包括参数估计率和控制率。

考虑二阶系统:
{x˙1=x2+φ1T(x1)θx˙2=u+φ2T(x1,x2)θ(1)\begin{cases} \dot{x}_1 = x_2 + \varphi_1^{T}(x_1)\theta \\ \dot{x}_2 = u + \varphi_2^{T}(x_1, x_2)\theta \end{cases} \tag{1} {x˙1=x2+φ1T(x1)θx˙2=u+φ2T(x1,x2)θ(1)

其中 θ\thetaθ 是未知的常数参数(列向量),φ1(x1)\varphi_1(x_1)φ1(x1)φ2(x1,x2)\varphi_2(x_1,x_2)φ2(x1,x2) 为已知的非线性函数。uuu 是控制输入,xrx_rxrx1x_1x1 期望跟踪到的轨迹。


设计目标有二确保闭环系统的所有状态保持有界;让 x1x_1x1 渐进跟踪到 xrx_rxr

假设:参考轨迹 xrx_rxr 及其导数有界并可预测;φ1(x1)\varphi_1(x_1)φ1(x1)φ2(x1,x2)\varphi_2(x_1,x_2)φ2(x1,x2) 是已知且连续可微的;参数不确定性是线性形式出现的。这些假设的目的是保证在设计自适应律时,Lyapunov 导函数可以被有效约束,并且更新率是可实现的。

如果参数 θ\thetaθ 已知,可以使用静态积分分反步法设计虚拟控制率 α1\alpha_1α1,但此处的参数 θ\thetaθ 并非已知,所以需要设计合适的 θ\thetaθ 更新规则以保证闭环稳定。


A. 第一步

定义跟踪误差
z1=x1−xr(2)z_1 = x_1 - x_r \tag{2} z1=x1xr(2)
z2=x2−α1−x˙r(3)z_2 = x_2 - \alpha_1 - \dot{x}_r \tag{3} z2=x2α1x˙r(3)

z2z_2z2 表示“实际 x2x_2x2 与理想目标值 α1+x˙r\alpha_1 + \dot{x}_rα1+x˙r 之间的偏差”。

对(2)求导数,并将(1)、(3)带入:
z˙1=x˙1−x˙r=x2+φ1T(x1)θ−x2+z2+α1=z2+α1+φ1Tθ(4)\dot{z}_1 = \dot{x}_1 - \dot{x}_r = x_2 + \varphi_1^{T}(x_1)\theta - x_2 + z_2 + \alpha_1 = z_2 + \alpha_1 + \varphi_1^{T}\theta \tag{4} z˙1=x˙1x˙r=x2+φ1T(x1)θx2+z2+α1=z2+α1+φ1Tθ(4)

其中 θ\thetaθ 是未知的,不能直接使用已知参数的反步法。设计 θ^1\hat{\theta}_1θ^1 用以近似 θ\thetaθ;同时设计一个参数更新率来在线调整 θ^1\hat{\theta}_1θ^1

设计 Lyapunov 候选函数:
V1=12z12+12θ~1TΓ−1θ~1(5)V_1 = \frac{1}{2} z_1^2 + \frac{1}{2} \tilde{\theta}_1^{T} \Gamma^{-1} \tilde{\theta}_1 \tag{5} V1=21z12+21θ~1TΓ1θ~1(5)
其中 Γ>0\Gamma > 0Γ>0 是参数更新率的自适应增益矩阵,θ~1=θ−θ^1\tilde{\theta}_1 = \theta - \hat{\theta}_1θ~1=θθ^1 表示参数估计误差。

对其求导:
V˙1=z1z˙1+θ~1TΓ−1θ~˙1(6)\dot{V}_1 = z_1 \dot{z}_1 + \tilde{\theta}_1^{T} \Gamma^{-1} \dot{\tilde{\theta}}_1 \tag{6} V˙1=z1z˙1+θ~1TΓ1θ~˙1(6)

将(4)带入:
V˙1=z1(z2+α1+φ1Tθ)+θ~1TΓ−1θ~˙1(7)\dot{V}_1 = z_1(z_2 + \alpha_1 + \varphi_1^{T}\theta) + \tilde{\theta}_1^{T} \Gamma^{-1} \dot{\tilde{\theta}}_1 \tag{7} V˙1=z1(z2+α1+φ1Tθ)+θ~1TΓ1θ~˙1(7)

展开:
V˙1=z1z2+z1α1+z1φ1Tθ^1+z1φ1Tθ~1−θ~1TΓ−1θ^˙1(8)\dot{V}_1 = z_1 z_2 + z_1 \alpha_1 + z_1 \varphi_1^{T} \hat{\theta}_1 + z_1 \varphi_1^{T} \tilde{\theta}_1 - \tilde{\theta}_1^{T} \Gamma^{-1} \dot{\hat{\theta}}_1 \tag{8} V˙1=z1z2+z1α1+z1φ1Tθ^1+z1φ1Tθ~1θ~1TΓ1θ^˙1(8)

由于 φ1Tθ~=θ~1Tφ1\varphi_1^{T}\tilde{\theta} = \tilde{\theta}_1^{T}\varphi_1φ1Tθ~=θ~1Tφ1,可得:
V˙1=z1z2+z1α1+z1φ1Tθ^1+θ~1T(φ1z1−Γ−1θ^˙1)(9)\dot{V}_1 = z_1 z_2 + z_1 \alpha_1 + z_1 \varphi_1^{T} \hat{\theta}_1 + \tilde{\theta}_1^{T}(\varphi_1 z_1 - \Gamma^{-1} \dot{\hat{\theta}}_1) \tag{9} V˙1=z1z2+z1α1+z1φ1Tθ^1+θ~1T(φ1z1Γ1θ^˙1)(9)

定义虚拟控制 α1\alpha_1α1 和参数更新率:
α1=−c1z1−φ1Tθ^1\alpha_1 = -c_1 z_1 - \varphi_1^{T} \hat{\theta}_1 α1=c1z1φ1Tθ^1
θ^˙1=Γφ1z1(10)\dot{\hat{\theta}}_1 = \Gamma \varphi_1 z_1 \tag{10} θ^˙1=Γφ1z1(10)

带入可得:
V˙1=−c1z12+z1z2(11)\dot{V}_1 = -c_1 z_1^2 + z_1 z_2 \tag{11} V˙1=c1z12+z1z2(11)


B. 第二步

设计实际控制输入 uuu,使 z2→0z_2 \to 0z20

由(3)可得:
z˙2=x˙2−α˙1−x¨r(12)\dot{z}_2 = \dot{x}_2 - \dot{\alpha}_1 - \ddot{x}_r \tag{12} z˙2=x˙2α˙1x¨r(12)

注意 α1\alpha_1α1 实际上是 x1x_1x1θ^1\hat{\theta}_1θ^1xrx_rxr 的函数,故采用复合函数求导方式。


选取新的 Lyapunov 函数:
V2=V1+12z22(14)V_2 = V_1 + \frac{1}{2} z_2^2 \tag{14} V2=V1+21z22(14)

求导:
V˙2=−c1z12+z2(z1+z˙2)(15)\dot{V}_2 = -c_1 z_1^2 + z_2(z_1 + \dot{z}_2) \tag{15} V˙2=c1z12+z2(z1+z˙2)(15)

为消除未知参数项 θ\thetaθ,设计:
u=−z1−c2z2+∂α1∂x1x2−(φ2−∂α1∂x1φ1)Tθ^2+∂α1∂θ^1Γφ1z1+∂α1∂xrx˙r+x¨r(18)u = -z_1 - c_2 z_2 + \frac{\partial \alpha_1}{\partial x_1} x_2 - \left( \varphi_2 - \frac{\partial \alpha_1}{\partial x_1} \varphi_1 \right)^T \hat{\theta}_2+ \frac{\partial \alpha_1}{\partial \hat{\theta}_1} \Gamma \varphi_1 z_1 + \frac{\partial \alpha_1}{\partial x_r} \dot{x}_r + \ddot{x}_r \tag{18} u=z1c2z2+x1α1x2(φ2x1α1φ1)Tθ^2+θ^1α1Γφ1z1+xrα1x˙r+x¨r(18)

此时(13)变为:
z˙2=−z1−c2z2+(φ2−∂α1∂x1φ1)T(θ−θ^2)(19)\dot{z}_2 = -z_1 - c_2 z_2 + \left( \varphi_2 - \frac{\partial \alpha_1}{\partial x_1} \varphi_1 \right)^T (\theta - \hat{\theta}_2) \tag{19} z˙2=z1c2z2+(φ2x1α1φ1)T(θθ^2)(19)

定义新的 Lyapunov 函数:
V2=V1+12z22+12θ~2TΓ−1θ~2(20)V_2 = V_1 + \frac{1}{2} z_2^2 + \frac{1}{2} \tilde{\theta}_2^{T} \Gamma^{-1} \tilde{\theta}_2 \tag{20} V2=V1+21z22+21θ~2TΓ1θ~2(20)

求导:
V˙2=−c1z12−c2z22−θ~2TΓ−1θ^˙2+θ~2T(φ2−∂α1∂x1φ1)z2(21)\dot{V}_2 = -c_1 z_1^2 - c_2 z_2^2 - \tilde{\theta}_2^{T} \Gamma^{-1} \dot{\hat{\theta}}_2 + \tilde{\theta}_2^{T} \left( \varphi_2 - \frac{\partial \alpha_1}{\partial x_1} \varphi_1 \right) z_2 \tag{21} V˙2=c1z12c2z22θ~2TΓ1θ^˙2+θ~2T(φ2x1α1φ1)z2(21)

令:
θ^˙2=Γ(φ2−∂α1∂x1φ1)z2(22)\dot{\hat{\theta}}_2 = \Gamma \left( \varphi_2 - \frac{\partial \alpha_1}{\partial x_1} \varphi_1 \right) z_2 \tag{22} θ^˙2=Γ(φ2x1α1φ1)z2(22)

最终得到:
V˙2=−c1z12−c2z22(23)\dot{V}_2 = -c_1 z_1^2 - c_2 z_2^2 \tag{23} V˙2=c1z12c2z22(23)

可保证系统全局渐近稳定。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/92383.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/92383.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[Oracle] LEAST()函数

LEAST() 是 Oracle 中一个非常有用的函数,用于从一组表达式中返回最小值LEAST()函数会从给定的参数列表中返回最小的值,它与GREATEST()函数正好相反语法格式LEAST(expr1, expr2 [, expr3, ...])参数说明expr1, expr2, ...:要比较的表达式(至少…

SVM算法实战应用

目录 用 SVM 实现鸢尾花数据集分类:从代码到可视化全解析 一、算法原理简述 二、完整代码实现 三、代码解析 1. 导入所需库 2. 加载并处理数据 3. 划分训练集和测试集 4. 训练 SVM 模型 5. 计算决策边界参数 6. 生成决策边界数据 7. 绘制样本点 8. 绘制…

深度虚值期权合约有什么特点?

本文主要介绍深度虚值期权合约有什么特点?深度虚值期权合约是期权市场中一类特殊且风险收益特征鲜明的合约,其核心特点可归纳为以下六点。深度虚值期权合约有什么特点?一、定义:执行价与标的价差距极大深度虚值期权是指执行价&…

(LeetCode 面试经典 150 题) 86. 分隔链表(链表+双指针)

题目:86. 分隔链表 思路:双指针,时间复杂度0(n)。 双指针来维护小于x的链表和不小于x的链表即可,后面将两个链表连起来即可。 C版本: /*** Definition for singly-linked list.* struct ListNode {* int val;* …

安全扫描:检测到目标站点存在javascript框架库漏洞问题(vue)

如果升级Vue版本有限制或者时间比较紧急,可以暂时用下面方式来,规避检测到目标站点存在javascript框架库vue漏洞。 在 vue.config.js 中配置: module.exports {configureWebpack: {optimization: {minimizer: [new (require(terser-webpack-plugin))({t…

【性能测试】-2- JMeter工具的使用

一、基础脚本搭建🎯 核心目标:用 JMeter 搭性能测试 “骨架”(测试计划、线程组、取样器、监听器)📋 测试计划:整个测试的 “容器”,所有测试组件都放这里🧵 线程组:模拟…

从零构建桌面写作软件的书籍管理系统:Electron + Vue 3 实战指南

📚 从零构建桌面写作软件的书籍管理系统:Electron Vue 3 实战指南 💡 本文深入探讨了基于 Electron Vue 3 技术栈的桌面写作软件中书籍管理系统的设计与实现,涵盖了书籍的创建、编辑、删除等核心功能的完整技术方案,…

2025华数杯数学建模A题【 多孔膜光反射性能的优化与控制】原创论文讲解(含完整python代码)

大家好呀,从发布赛题一直到现在,总算完成了2025华数杯数学建模A题【 多孔膜光反射性能的优化与控制】完整的成品论文。本论文可以保证原创,保证高质量。绝不是随便引用一大堆模型和代码复制粘贴进来完全没有应用糊弄人的垃圾半成品论文。A题论…

网络相关(AI回答)

网管交换机都支持带tag的以太帧吗DeepSeek-R1 回答完成深度思考完成 用时24秒,搜索全网20篇资料是的,所有网管交换机都支持处理和转发带Tag(802.1Q VLAN标签)的以太网帧,这是其核心功能之一。以下是关键要点&#xff1…

每日五个pyecharts可视化图表-bars(5)

探索pyecharts库中条形图的高级用法与定制技巧,打造精美数据可视化图表 在数据可视化中,条形图是最常用的图表类型之一。它能够清晰地展示不同类别的数据对比,帮助我们快速理解数据特征。本文将为您介绍pyecharts库中条形图的5种高级用法&…

分布式版本控制工具Git

一.开发中为什么需要Git因为在多人开发中Git可以管理代码,而且每个人都可以从库里面下载代码进行修改,每个人上传和修改Git都会有记录,如果出现大错误,还可以回退到正常版本。二.Git原理我们首先从代码库(Remote)下载代码到工作区…

OpenAI重磅开源GPT-oss:首款支持商用的AI Agent专属模型

今日凌晨,OpenAI宣布开源两款全新大模型——GPT-oss-120B(1168亿参数)与GPT-oss-20B(209亿参数),成为全球首个支持商业化应用的开放权重推理模型。该模型专为AI智能体(Agent)设计&am…

【STM32】GPIO的输入输出

GPIO是通用的输入输出接口,可配置8种输入模式,输出模式下可控制端口输出高低电平,用于点亮LED、控制蜂鸣器、模拟通信协议等;输入模式下可以读取端口的高低电平或者电压,用于读取按键、外接模块的电平信号、ADC的电压采…

5分钟了解OpenCV

在数字化时代,图像和视频已经成为信息传递的核心载体。从手机拍照的美颜功能到自动驾驶的路况识别,从医学影像分析到安防监控系统,视觉技术正深刻改变着我们的生活。而在这背后,OpenCV 作为一款强大的开源计算机视觉库&#xff0c…

Oracle 关闭 impdp任务

Oracle 关闭 impdp任务 执行 impdp system/123456 attachSYS_EXPORT_TABLE_01 执行 stop_jobimmediate

数据结构——链表2

1.2 实现单链表 在上一篇文章中&#xff0c;单链表的实现只有一少部分&#xff0c;这一篇接着来了解单链表剩下的接口实现。 SList.h#pragma once #include<stdio.h> #include<stdlib.h> #include<assert.h>//定义单链表就是定义节点&#xff0c;因为单链表…

Windows和Linux应急响应以及IP封堵

目录 1、Windows入侵排查思路 1.1 检查系统账号安全 1.2 检查异常端口、进程 1.3 检查启动项、计划任务、服务 1.4 检查系统相关信息 1.5 自动化查杀 1.6 日志分析 系统日志分析 Web 访问日志 2、Linux 入侵排查思路 2.1 账号安全 2.1.1、基本使用 2.1.2、入侵排查…

MIT成果登上Nature!液态神经网络YYDS

2025深度学习发论文&模型涨点之——液态神经网络液态神经网络&#xff08;Liquid Neural Networks&#xff0c;LNN&#xff09;是一种受生物神经系统启发的连续时间递归神经网络&#xff08;RNN&#xff09;&#xff0c;其核心创新在于将静态神经网络转化为由微分方程驱动的…

AI 对话高效输入指令攻略(四):AI+Apache ECharts:生成各种专业图表

- **AI与数据可视化的革命性结合**:介绍AI如何降低数据可视化门槛,提升效率。 - **Apache ECharts:专业可视化的利器**:使用表格对比展示ECharts的特点、优势和适用场景。 - **四步实现AI驱动图表生成**:通过分步指南讲解从环境准备到图表优化的全流程,包含多个代码示例及…

vue2 基础学习 day04 (结构/样式/逻辑、组件通信、进阶语法)下

一、非父子通信-event bus 事件总线1.作用非父子组件之间&#xff0c;进行简易消息传递。(复杂场景→ Vuex)2.步骤创建一个都能访问的事件总线 &#xff08;空Vue实例&#xff09;import Vue from vue const Bus new Vue() export default BusA组件&#xff08;接受方&#xf…