模型预测控制:设定点跟踪(Set Point Tracking)

news2025/1/21 3:02:02

模型预测控制:设定点跟踪(Set Point Tracking)

模型预测控制(Model Predictive Control, MPC)不仅可以用于系统稳定性问题,还可以用于设定点跟踪问题(Set Point Tracking),即系统需要跟踪一个动态变化的参考输入。本文将介绍如何将设定点跟踪问题转化为稳定性问题,并使用MPC解决。

系统描述

首先,我们假设系统模型为一个离散时间线性时不变(LTI)系统:

x k + 1 = A x k + B u k x_{k+1} = A x_k + B u_k xk+1=Axk+Buk

其中:

  • x k x_k xk是时间步 k k k的系统状态向量
  • u k u_k uk是时间步 k k k的控制输入向量
  • A A A是状态转移矩阵
  • B B B是输入矩阵

对于设定点跟踪问题,目标是让系统状态 x k x_k xk跟踪一个参考状态 x r x_r xr,同时控制输入 u k u_k uk跟踪一个参考输入 u r u_r ur

转化为稳定性问题

设定误差状态为:

e k = x k − x r e_k = x_k - x_r ek=xkxr

误差控制输入为:

v k = u k − u r v_k = u_k - u_r vk=ukur

将其代入系统状态方程:

e k + 1 = x k + 1 − x r = A x k + B u k − x r = A ( x k − x r ) + B ( u k − u r ) + A x r + B u r − x r e_{k+1} = x_{k+1} - x_r = A x_k + B u_k - x_r = A (x_k - x_r) + B (u_k - u_r) + A x_r + B u_r - x_r ek+1=xk+1xr=Axk+Bukxr=A(xkxr)+B(ukur)+Axr+Burxr

考虑到在稳态时 A x r + B u r = x r A x_r + B u_r = x_r Axr+Bur=xr,则有:

e k + 1 = A e k + B v k e_{k+1} = A e_k + B v_k ek+1=Aek+Bvk

这样,我们将设定点跟踪问题转化为误差状态的稳定性问题。

优化问题

优化问题的目标是最小化误差状态和控制输入的代价函数,同时满足系统的约束。代价函数可以表示为:

J = ∑ i = 0 N − 1 ( e k + i ∣ k T Q e k + i ∣ k + v k + i ∣ k T R v k + i ∣ k ) + e k + N ∣ k T P e k + N ∣ k J = \sum_{i=0}^{N-1} \left( e_{k+i|k}^T Q e_{k+i|k} + v_{k+i|k}^T R v_{k+i|k} \right) + e_{k+N|k}^T P e_{k+N|k} J=i=0N1(ek+ikTQek+ik+vk+ikTRvk+ik)+ek+NkTPek+Nk

其中:

  • N N N是预测时域长度
  • Q Q Q是误差状态权重矩阵
  • R R R是误差控制输入权重矩阵
  • P P P是终端误差状态权重矩阵

约束条件为:

e k + i + 1 ∣ k = A e k + i ∣ k + B v k + i ∣ k ∀ i = 0 , … , N − 1 x m i n ≤ e k + i ∣ k + x r ≤ x m a x ∀ i = 1 , … , N u m i n ≤ v k + i ∣ k + u r ≤ u m a x ∀ i = 0 , … , N − 1 \begin{align*} e_{k+i+1|k} &= A e_{k+i|k} + B v_{k+i|k} \quad \forall i = 0, \ldots, N-1 \\ x_{min} &\leq e_{k+i|k} + x_r \leq x_{max} \quad \forall i = 1, \ldots, N \\ u_{min} &\leq v_{k+i|k} + u_r \leq u_{max} \quad \forall i = 0, \ldots, N-1 \end{align*} ek+i+1∣kxminumin=Aek+ik+Bvk+iki=0,,N1ek+ik+xrxmaxi=1,,Nvk+ik+urumaxi=0,,N1

Python代码示例

以下是一个简单的Python代码示例,展示如何实现设定点跟踪的线性MPC:

import numpy as np
from scipy.linalg import solve_discrete_are
from scipy.optimize import minimize
import matplotlib.pyplot as plt

# Define the system model
A = np.array([[1.1]])
B = np.array([[1.0]])
Q = np.array([[1.0]])
R = np.array([[0.1]])
N = 10  # Prediction horizon

# Define constraints
x_min = -10.0
x_max = 10.0
u_min = -1.0
u_max = 1.0

# Terminal weight matrix P
P = solve_discrete_are(A, B, Q, R)

# Initial state and reference state
x0 = np.array([0.0])
x_r = np.array([5.0])
u_r = np.array([0.5])

def cost_function(v, x0, x_r, u_r):
    e = x0 - x_r
    cost = 0.0
    for i in range(N):
        e = A @ e + B * v[i]
        cost += e.T @ Q @ e + v[i] * R * v[i]
    cost += e.T @ P @ e
    return cost

# Optimization
v0 = np.zeros(N)
constraints = [{'type': 'ineq', 'fun': lambda v: v + u_r - u_min},
               {'type': 'ineq', 'fun': lambda v: u_max - (v + u_r)}]

result = minimize(cost_function, v0, args=(x0, x_r, u_r), constraints=constraints)
v_opt = result.x

# Apply the optimal control input
x = x0
x_history = [x]
u_history = []
for v in v_opt:
    u = v + u_r
    u_history.append(u)
    x = A @ x + B * u
    x_history.append(x)

# Convert x_history to a 1D array of scalars
x_history = [x.item() for x in x_history]

# Plot results
plt.plot(range(N+1), x_history, label='State')
plt.axhline(y=x_r, color='r', linestyle='--', label='Reference state')
plt.xlabel('Time step')
plt.ylabel('State')
plt.title('Linear MPC for Set Point Tracking')
plt.legend()
plt.grid(True)
plt.show()

plt.plot(range(N), u_history, label='Control input')
plt.axhline(y=u_r, color='r', linestyle='--', label='Reference input')
plt.xlabel('Time step')
plt.ylabel('Control input')
plt.title('Control Input for Set Point Tracking')
plt.legend()
plt.grid(True)
plt.show()

在这里插入图片描述
在这里插入图片描述

代码解释

  1. 系统模型和参数定义

    • 定义系统的状态矩阵 A A A和输入矩阵 B B B
    • 定义代价函数中的权重矩阵 Q Q Q R R R
    • 设置预测时域长度 N N N
    • 定义状态和控制输入的约束。
  2. 终端权重矩阵计算

    • 使用 solve_discrete_are 计算离散时间代数Riccati方程的解,得到终端权重矩阵 P P P
  3. 初始状态和参考状态

    • 定义系统的初始状态 x 0 x_0 x0和参考状态 x r x_r xr
    • 定义参考控制输入 u r u_r ur
  4. 代价函数

    • 定义代价函数 cost_function,用于计算给定误差控制输入序列 v v v 的代价。
  5. 优化

    • 使用 minimize 函数进行优化,得到最优误差控制输入序列 v o p t v_{opt} vopt
  6. 应用控制输入

    • 计算实际控制输入 u = v + u r u = v + u_r u=v+ur,并更新系统状态 x x x
    • 记录系统状态和控制输入的历史数据。
  7. 绘制结果

    • 绘制系统状态和参考状态的变化曲线。
    • 绘制控制输入和参考输入的变化曲线。

结论

通过将设定点跟踪问题转化为稳定性问题,MPC可以用于动态跟踪参考输入。本文介绍了设定点跟踪问题的基本概念、系统模型、优化问题和LMPC算法,并提供了一个简单的Python代码示例,展示了MPC在单输入系统中的应用。通过在线解决优化问题,MPC能够有效地实现系统状态的最优控制和参考输入的跟踪。

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

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

相关文章

13_旷视轻量化网络--ShuffleNet V2

回顾一下ShuffleNetV1:08_旷视轻量化网络--ShuffleNet V1-CSDN博客 1.1 简介 ShuffleNet V2是在2018年由旷视科技的研究团队提出的一种深度学习模型,主要用于图像分类和目标检测等计算机视觉任务。它是ShuffleNet V1的后续版本,重点在于提供更高效的模…

架构师篇-10、DDD实战篇:通过领域模型落地系统

基于领域模型的设计与开发 数据库设计程序设计微服务设计 在线订餐系统的领域事件通知 微服务拆分 事件风暴会议 梳理领域事件进行领域建模识别聚合关系划分限界上下文 用户下单领域模型 更新后的模型 领域模型的设计实现过程 数据库设计 数据库映射:一对一关系…

cesium 添加 Echarts 图层(空气质量点图)

cesium 添加 Echarts 图层(下面附有源码) 1、实现思路 1、在scene上面新增一个canvas画布 2、通坐标转换,将经纬度坐标转为屏幕坐标来实现 3、将ecarts 中每个series数组中元素都加 coordinateSystem: ‘cesiumEcharts’ 2、示例代码 <!DOCTYPE html> <html lan…

EDA期末复习——基础知识

个人名片&#xff1a; &#x1f393;作者简介&#xff1a;嵌入式领域优质创作者&#x1f310;个人主页&#xff1a;妄北y &#x1f4de;个人QQ&#xff1a;2061314755 &#x1f48c;个人邮箱&#xff1a;[mailto:2061314755qq.com] &#x1f4f1;个人微信&#xff1a;Vir2025WB…

iconfont-阿里巴巴矢量图标库 在vue项目使用记录

官网地址&#xff1a;https://www.iconfont.cn/manage/index?manage_typemyprojects&projectId4539761 第一步&#xff1a; 下载资源 ->解压到项目文件夹 第二步 在项目中main.ts 或者main.js 引入资源 import //assets/iconfont/font/iconfont.js; import //assets…

【考研408计算机组成原理】微程序设计重要考点指令流水线考研真题+考点分析

苏泽 “弃工从研”的路上很孤独&#xff0c;于是我记下了些许笔记相伴&#xff0c;希望能够帮助到大家 目录 微指令的形成方式 微指令的地址形成方式 对应考题 题目&#xff1a;微指令的地址形成方式 - 断定方式 解题思路&#xff1a; 答题&#xff1a; 分析考点&…

【训练篇】MLU370-M8 完成 qwen1.5-7b-chat-lora训练及推理

文章目录 前言一、平台环境配置二、环境 or 模型准备1.模型下载2.环境准备2.1 modelscope2.2 transformers2.3 accelerate2.4 deepspeed2.5 peft2.6 环境代码修改 3训练代码准备4 代码修改 三&#xff0c;训练后推理验证四.推理效果展示1.微调前2.微调后 前言 本期我们采用魔塔…

局域网必备文件传输神器,吾爱再出精品,支持电脑、手机无缝对接!

今天给大家带来的不是一般的干货&#xff0c;而是一款让阿星我爱不释手的局域网文件传输神器&#xff0c;而且是吾爱大佬出品。无论是工作还是生活&#xff0c;它都能给你带来极大的便利。这年头&#xff0c;谁还没个跨设备传输文件的需求呢&#xff1f; 手机、电脑、平板&…

一个中文和越南语双语版本的助贷平台开源源码

一个中文和越南语双语版本的助贷平台开源源码。后台试nodejs。 后台 代理 前端均为vue源码&#xff0c;前端有中文和越南语。 前端ui黄色大气&#xff0c;逻辑操作简单&#xff0c;注册可对接国际短信&#xff0c;可不对接。 用户注册进去填写资料&#xff0c;后台审批&…

python(一)下载安装入门

一.下载安装 1、官网下载地址&#xff1a; Python Releases for Windows | Python.org 2、下载安装 1.下载python包&#xff1a;点击下载 2.安装 2.默认点击next即可 3.选择你想安装的路径&#xff0c;点击install即可 4.这里如果出现管理员字样&#xff0c;点击授权即可 安…

专题一: Spring生态初探

咱们先从整体脉络上看下Spring有哪些模块&#xff0c;重要的概念有个直观印象。 从Spring框架的整体架构和组成对整体框架有个认知。 Spring框架基础概念 Spring基础 - Spring和Spring框架组成 上图是从官网4.2.x获取的原图&#xff0c;目前我们使用最广法的版本应该都是5.x&am…

医院管理系统带万字文档医院预约挂号管理系统基于spingboot和vue的前后端分离java项目java课程设计java毕业设计

文章目录 仓库管理系统一、项目演示二、项目介绍三、万字项目文档四、部分功能截图五、部分代码展示六、底部获取项目源码带万字文档&#xff08;9.9&#xffe5;带走&#xff09; 仓库管理系统 一、项目演示 医院管理系统 二、项目介绍 基于springbootvue的前后端分离医院管…

鱼叉式钓鱼

鱼叉式网络钓鱼&#xff1a; 鱼叉式网络钓鱼是一种网络钓鱼形式&#xff0c;它针对特定个人或组织发送定制消息&#xff0c;旨在引发特定反应&#xff0c;例如泄露敏感信息或安装恶意软件。这些攻击高度个性化&#xff0c;使用从各种来源收集的信息&#xff0c;例如社交媒体资…

运维锅总详解Prometheus

本文尝试从Prometheus简介、架构、各重要组件详解、relable_configs最佳实践、性能能优化及常见高可用解决方案等方面对Prometheus进行详细阐述。希望对您有所帮助&#xff01; 一、Prometheus简介 Prometheus 是一个开源的系统监控和报警工具&#xff0c;最初由 SoundCloud …

【简易版tinySTL】 红黑树- 定义, 插入, 构建

文章目录 旋转左旋右旋 左旋右旋代码实现红黑树的基本性质红黑树的插入红黑树的插入示例红黑树修复代码实现参考资料 旋转 对于一个平衡二叉搜索树&#xff0c;左子树高度为4&#xff0c;右子树高度为2&#xff0c;它们的高度差为2&#xff0c;破坏了平衡性&#xff08;高度差&…

扩展阅读:什么是中断

如果用一句话概括操作系统的原理,那就是:整个操作系统就是一个中断驱动的死循环,用最简单的代码解释如下: while(true){doNothing(); } 其他所有事情都是由操作系统提前注册的中断机制和其对应的中断处理函数完成的。我们点击一下鼠标,敲击一下键盘,执行一个程序,…

忙忙碌碌的混沌之中差点扑了个空而错过年中这条线

文章目录 前言初见端倪混沌初始力不从心心力交瘁拾遗补缺总结 前言 突然意识到过完这个周末已经7月份了&#xff0c;他预示着我的2024年已经过半了&#xff0c;过年回家仿佛还是昨天的事情&#xff0c;怎么转眼间已经到了年中了。心里还是不愿承认这件事&#xff0c;翻开自己2…

使用NFS网关功能将HDFS挂载到本地系统

HDFS安装教程 HDFS安装教程http://t.csdnimg.cn/2ziFd 使用NFS网关功能将HDFS挂载到本地系统 简介 HDFS提供了基于NFS&#xff08;Network File System&#xff09;的插件&#xff0c;可以对外提供NFS网关&#xff0c;供其它系统挂载使用。 NFS 网关支持 NFSv3&#xff0c;并…

etcdctl txn如何使用

TXN 从标准输入中读取多个请求&#xff0c;并将它们应用到单个原子的事务操作中。一个事务包含 一系列的条件、所有条件都满足时要执行的一系列请求、任意条件不满足时要执行的一系列请求。 开启事务&#xff1a; etcdctl txn -i 开启事务后&#xff0c;需要先输入判断条件&a…

Studying-代码随想录训练营day24| 93.复原IP地址、78.子集、90.子集II

第24天&#xff0c;回溯算法part03&#xff0c;牢记回溯三部曲&#xff0c;掌握树形结构结题方法&#x1f4aa; 目录 93.复原IP地址 78.子集 90.子集II 总结 93.复原IP地址 文档讲解&#xff1a;代码随想录复原IP地址 视频讲解&#xff1a;手撕复原IP地址 题目&#xff1…