Starlink卫星动力学系统仿真建模第九讲-滑模(SMC)控制算法原理简介及卫星控制应用


滑模控制(Sliding Mode Control)算法详解


一、基本原理

滑模控制(Sliding Mode Control, SMC)是一种变结构控制方法,通过设计一个滑模面(Sliding Surface),迫使系统状态在有限时间内到达该面,并在滑模面上沿预定轨迹滑动至平衡点。其核心特点是强鲁棒性,能够有效抑制参数不确定性、模型误差和外部扰动。
在这里插入图片描述

关键步骤
  1. 滑模面设计
    定义滑模面 ( s(t) = 0 ),通常选择误差及其导数的线性组合。
    例如,对二阶系统:
    [
    s(t) = \dot{e}(t) + \lambda e(t) \quad (\lambda > 0)
    ]
    其中 ( e(t) = x_{\text{desired}} - x(t) )。

  2. 控制律设计
    设计控制输入 ( u(t) ),使得系统状态在有限时间内收敛到滑模面,并保持滑动。
    控制律一般形式:
    [
    u(t) = u_{\text{eq}}(t) + u_{\text{sw}}(t)
    ]

    • 等效控制 ( u_{\text{eq}} ):抵消系统动态,保证在滑模面上滑动。
    • 切换控制 ( u_{\text{sw}} ):抑制扰动,通常包含符号函数 ( \text{sign}(s) )。
  3. 稳定性分析
    通过李雅普诺夫函数证明 ( \dot{V}(s) \leq -\eta |s| ),确保有限时间收敛。


二、分类
  1. 传统滑模控制

    • 控制律包含不连续项(如符号函数),易引起抖振(高频振荡)。
    • 示例:
      [
      u(t) = K \cdot \text{sign}(s)
      ]
  2. 高阶滑模控制

    • 通过高阶导数平滑抖振,如超螺旋算法(Super-Twisting Algorithm)。
    • 示例(二阶滑模):
      [
      u(t) = -k_1 |s|^{1/2} \text{sign}(s) + v, \quad \dot{v} = -k_2 \text{sign}(s)
      ]
  3. 终端滑模控制

    • 引入非线性滑模面,实现有限时间收敛。
    • 示例:
      [
      s(t) = \dot{e} + \beta e^{q/p} \quad (\beta > 0, , q < p \text{为正奇数})
      ]

三、代码实现(Python)

以二阶系统为例,设计传统滑模控制器。

import numpy as np
import matplotlib.pyplot as plt

class SlidingModeController:
    def __init__(self, lambda_, K, dt):
        self.lambda_ = lambda_  # 滑模面参数
        self.K = K              # 切换增益
        self.dt = dt            # 采样时间
        self.prev_error = 0.0

    def compute(self, desired, actual, actual_derivative):
        error = desired - actual
        error_derivative = (error - self.prev_error) / self.dt
        self.prev_error = error

        # 滑模面 s = error_derivative + lambda * error
        s = error_derivative + self.lambda_ * error

        # 控制律: u = K * sign(s)
        u = self.K * np.sign(s)
        return u

# 系统模型(二阶系统)
def system_model(x, dx, u, dt):
    # 假设系统动力学: ddx = -2*dx - 3*x + u + 扰动
    ddx = -2 * dx - 3 * x + u + 0.5 * np.sin(10 * x)  # 加入扰动
    dx_new = dx + ddx * dt
    x_new = x + dx_new * dt
    return x_new, dx_new

# 参数初始化
lambda_ = 2.0
K = 5.0
dt = 0.01
controller = SlidingModeController(lambda_, K, dt)

# 仿真
desired = 1.0
x, dx = 0.0, 0.0
time = np.arange(0, 10, dt)
x_history = []

for t in time:
    u = controller.compute(desired, x, dx)
    x_new, dx_new = system_model(x, dx, u, dt)
    x, dx = x_new, dx_new
    x_history.append(x)

# 绘图
plt.plot(time, x_history, label='Actual')
plt.plot(time, [desired]*len(time), 'r--', label='Desired')
plt.xlabel('Time (s)')
plt.ylabel('Position')
plt.legend()
plt.show()

四、在卫星姿态控制中的使用示例
场景

控制卫星三轴姿态(俯仰角、偏航角、滚动角),使其跟踪目标姿态角。
动力学模型(以俯仰轴为例):
[
J \ddot{\theta} = u + d(t)
]

  • ( J ):转动惯量
  • ( \theta ):俯仰角
  • ( u ):控制力矩
  • ( d(t) ):外部扰动(如太阳辐射压力)。
滑模控制设计
  1. 定义误差
    [
    e = \theta_{\text{desired}} - \theta
    ]

  2. 滑模面
    [
    s = \dot{e} + \lambda e \quad (\lambda > 0)
    ]

  3. 控制律
    [
    u = J \left( \ddot{\theta}_{\text{desired}} + \lambda \dot{e} \right) - K \cdot \text{sign}(s)
    ]
    (包含等效控制和切换项)

代码片段(简化)
class SatelliteSMController:
    def __init__(self, lambda_, K, J, dt):
        self.lambda_ = lambda_
        self.K = K
        self.J = J
        self.dt = dt
        self.prev_error = 0.0

    def compute(self, theta_desired, theta, dtheta):
        error = theta_desired - theta
        error_derivative = (error - self.prev_error) / self.dt
        self.prev_error = error

        s = error_derivative + self.lambda_ * error
        u_eq = self.J * (0 + self.lambda_ * error_derivative)  # 假设目标角加速度为0
        u_sw = -self.K * np.sign(s)
        u = u_eq + u_sw
        return u

# 卫星姿态动力学仿真
J = 100.0  # 转动惯量
dt = 0.01
controller = SatelliteSMController(lambda_=1.5, K=50, J=J, dt=dt)
theta, dtheta = 0.0, 0.0
theta_desired = np.deg2rad(30)  # 目标30度

for _ in range(1000):
    u = controller.compute(theta_desired, theta, dtheta)
    ddtheta = (u + 10 * np.sin(2 * np.pi * 0.1 * _ * dt)) / J  # 控制输入 + 扰动
    dtheta += ddtheta * dt
    theta += dtheta * dt

五、关键问题与改进
  1. 抖振抑制

    • 使用饱和函数 ( \text{sat}(s/\phi) ) 替代符号函数。
    • 采用高阶滑模(如超螺旋算法)。
  2. 参数选择

    • ( \lambda ) 决定滑模面收敛速度。
    • ( K ) 需大于扰动上界。

六、总结
  • 优点:强鲁棒性,适用于复杂扰动和模型不确定性场景(如航天器、无人机)。
  • 缺点:抖振可能影响执行机构寿命。
  • 应用扩展:结合自适应控制、模糊逻辑,进一步提升性能。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

nss刷题5(misc)

[HUBUCTF 2022 新生赛]最简单的misc 打开后是一张图片&#xff0c;没有其他东西&#xff0c;分离不出来&#xff0c;看看lsb&#xff0c;红绿蓝都是0&#xff0c;看到头是png&#xff0c;重新保存为png&#xff0c;得到一张二维码 扫码得到flag [羊城杯 2021]签到题 是个动图…

【C/C++】删除链表的倒数第 N 个结点(leetcode T19)

考点预览&#xff1a; 双指针法&#xff1a;通过维护两个指针来一次遍历链表&#xff0c;避免了多次遍历链表的低效方法。 边界条件&#xff1a;要特别处理删除头结点的情况。 题目描述&#xff1a; 给你一个链表&#xff0c;删除链表的倒数第 n 个结点&#xff0c;并且返回…

人工智能定义

一、人工智能核心概念体系 1.1 人工智能的本质 人工智能的定义:人工智能(Artificial Intelligence,简称 AI)是指计算机系统能够执行通常需要人类智能才能完成的任务,如学习、推理、解决问题、理解自然语言、识别图像和声音等。它通过模拟人类的智能行为,运用算法和数据…

量子计算的威胁,以及企业可以采取的措施

当谷歌、IBM、Honeywell和微软等科技巨头纷纷投身量子计算领域时&#xff0c;一场技术军备竞赛已然拉开帷幕。 量子计算虽能为全球数字经济带来巨大价值&#xff0c;但也有可能对相互关联的系统、设备和数据造成损害。这一潜在影响在全球网络安全领域引起了强烈关注。也正因如…

0—QT ui界面一览

2025.2.26&#xff0c;感谢gpt4 1.控件盒子 1. Layouts&#xff08;布局&#xff09; 布局控件用于组织界面上的控件&#xff0c;确保它们的位置和排列方式合理。 Vertical Layout&#xff08;垂直布局&#xff09; &#xff1a;将控件按垂直方向排列。 建议&#xff1a;适…

【Uniapp-Vue3】导入uni-id用户体系

在uniapp官网的uniCloud中下载uni-id用户体系 或者直接进入加载&#xff0c;下载地址&#xff1a;uni-id-pages - DCloud 插件市场 进入以后下载插件&#xff0c;打开HbuilderX 选中项目&#xff0c;点击确定 点击跳过 点击合并 右键uniCloud文件夹下的database文件夹&#x…

如何免费使用稳定的deepseek

0、背景&#xff1a; 在AI辅助工作中&#xff0c;除了使用cursor做编程外&#xff0c;使用deepseek R1进行问题分析、数据分析、代码分析效果非常好。现在我经常会去拿行业信息、遇到的问题等去咨询R1&#xff0c;也给了自己不少启示。但是由于官网稳定性很差&#xff0c;很多…

VSCode+PlatformIO报错 找不到头文件

如图示&#xff0c;找不到目标头文件 demo工程运行正常&#xff0c;考虑在src文件夹内开辟自己的代码&#xff0c;添加后没有找到 找了些资料&#xff0c;大概记录如下&#xff1a; 1、c_cpp_properties.json 内记录 头文件配置 .vscode 中&#xff0c;此文件是自动生成的&a…

Python 网络爬虫实战全解析:案例驱动的技术探索

Python 网络爬虫实战全解析&#xff1a;案例驱动的技术探索 本文围绕 Python 网络爬虫展开&#xff0c;深入剖析其技术要点&#xff0c;并通过实际案例演示开发流程。从爬虫原理引入&#xff0c;逐步讲解如何使用 Python 中的requests和BeautifulSoup等库进行网页数据抓取与解…

List(3)

前言 上一节我们讲解了list主要接口的模拟实现&#xff0c;本节也是list的最后一节&#xff0c;我们会对list的模拟实现进行收尾&#xff0c;并且讲解list中的迭代器失效的情况&#xff0c;那么废话不多说&#xff0c;我们正式进入今天的学习 list的迭代器失效 之前在讲解vec…

在zotero里部署papaerschat插件,以接入现有大模型

papaerschat插件里集成了openAI的GPT3.5、gpt-4o、gpt-mini大模型以及Claude3、Gemini、Deepseek等大模型。通过接入这些大模型可以辅助我们阅读论文。以部署方式如下&#xff1a; 1.下载zotero的插件市场&#xff0c;用以管理zotero里的插件。下载地址&#xff1a; https://…

Memory Programming ...Error: File does not exist: Max.hex

Memory Programming ... Error: File does not exist: Max.hex 原因 删了确定就可以了

渗透测试【seacms V9】

搭建seacms环境 我选择在虚拟机中用宝塔搭建环境 将在官网选择的下载下来的文件解压后拖入宝塔面板的文件中 创建网站 添加站点 搭建完成seacmsV9 找到一个报错口 代码分析 <?php set_time_limit(0); error_reporting(0); $verMsg V6.x UTF8; $s_lang utf-8; $dfDbn…

仅需三分钟,使用Vue3.x版本组件式风格实现一个消息提示组件!

一、前言 在日常的前端项目开发中&#xff0c;我们时常需要使用到“消息提示”&#xff08;以下简称“消息”&#xff09;这个组件来帮助我们更好的给予用户提示&#xff0c;例如常见的“登录成功”、“操作成功”、“服务器异常”等等提示。 尽管市面上已经有一些组件库提供了…

敏捷开发实践指南:从理论到落地的全面解析

敏捷工程&#xff1a;现代软件开发的变革与实践 近年来&#xff0c;软件工程领域经历了从传统瀑布模型到敏捷开发的深刻转变。这种转变不仅是技术方法的升级&#xff0c;更是团队协作、需求管理和交付模式的革新。本文将从敏捷开发的核心理念、主流方法、实践案例及未来趋势等…

期权帮|股指期货基差和价差有什么区别?

锦鲤三三每日分享期权知识&#xff0c;帮助期权新手及时有效地掌握即市趋势与新资讯&#xff01; 股指期货基差和价差有什么区别&#xff1f; 一、股指期货基差 股指期货基差是指股指期货价格与其对应的现货指数价格之间的差额。 股指期货基差计算公式&#xff1a;基差 现…

【论文解读】《C-Pack: Packed Resources For General Chinese Embeddings》

论文链接&#xff1a;https://arxiv.org/pdf/2309.07597 本论文旨在构建一套通用中文文本嵌入的完整资源包——C-Pack&#xff0c;解决当前中文文本嵌入研究中数据、模型、训练策略与评测基准缺失的问题。论文主要贡献体现在以下几个方面&#xff1a; 大规模训练数据&#xf…

ARM 处理器平台 eMMC Flash 存储磨损测试示例

By Toradex秦海 1). 简介 目前工业嵌入式 ARM 平台最常用的存储器件就是 eMMC Nand Flash 存储&#xff0c;而由于工业设备一般生命周期都比较长&#xff0c;eMMC 存储器件的磨损寿命对于整个设备来说至关重要&#xff0c;因此本文就基于 NXP i.MX8M Mini ARM 处理器平台演示…

html中的元素(2)

在用块级元素完成网页的组织和布局以后&#xff0c;要为其中的每一个小区块添加内容&#xff0c;就需要用到行内元素&#xff1a; 1.字体样式元素 <!DOCTYPE html> <html> <head><meta charset"utf-8"><title>HTML5 保留的文本格式元…

代码随想录二刷|动态规划12

dp动态规划 动态规划五步曲 动态规划数组的含义 dp[i] 递推公式 动态规划数组的初始化 确定遍历顺序 手动模拟验证 动态规划遇到问题要打印dp数组&#xff0c;看和模拟结果哪里不一样 一 基础问题 斐波那契数 题干 斐波那契数 &#xff08;通常用 F(n) 表示&#xf…