MPC(模型预测控制)-Simulink仿真

article/2025/11/9 10:44:28

文章目录

      • 一、为什么使用MPC控制器?
      • 二、什么是MPC控制器?
      • 三、MPC控制器的参数如何设置?
        • 3.1 采样时间
        • 3.2 预测范围、控制范围
        • 3.3 约束条件
        • 3.4 权重
      • 四、自适应增益调度和非线性MPC
      • 五、Simulink仿真MPC控制器
        • 5.1 数学分析
        • 5.2 实验过程

一、为什么使用MPC控制器?

  • ① MPC可以处理多输入耦合控制多输出的问题:

    在这里插入图片描述

  • ② MPC可以处理对于控制量有约束的问题

    比如,驾驶汽车的时候,汽车速度和转角都有上限

  • ③ MPC具有预测效果

    即MPC考虑的不是根据当前参考值进行控制,而是根据预测时间内的参考去预测当前的控制量,比如在小车转弯时,就避免了可能在过弯处急转弯。

在这里插入图片描述

MPC需要的算力高一些,因为MPC控制过程中,每个时间步都要求解一个相同形式不同参数的优化问题。

二、什么是MPC控制器?

在这里插入图片描述

  • 小车的数学模型:

在这里插入图片描述

iteminputsoutputs
Plant Model(被控对象的数学模型)之后m个控制量之后p个时间步的预测输出
  • 优化器:

在这里插入图片描述

iteminputsoutputs
优化器(数学模型, 之后p个时间步的参考轨迹, 约束条件)之后m个控制量

​ 优化器要考虑两点:

​ ① 预测轨迹与参考轨迹偏差最小

​ ②控制量不突变
C o s t F u n c t i o n ≐ J = ∑ i = 1 p w e e k + i 2 + ∑ i = 0 p − 1 w Δ u Δ u k + i 2 Cost Function \doteq J = \sum_{i=1}^{p} w_e e_{k+i}^2 + \sum_{i=0}^{p-1} w_{\Delta u} {\Delta u_{k+i}}^2 CostFunctionJ=i=1pweek+i2+i=0p1wΔuΔuk+i2

尽管优化器输出的是之后 p 个时间步的控制量,但是在当前时间步, M P C 仅将这个最有序列的第一步应用到汽车上,忽略其余部分 {\color{Red} 尽管优化器输出的是之后p个时间步的控制量,但是在当前时间步,}\\ {\color{Red} MPC仅将这个最有序列的第一步应用到汽车上,忽略其余部分} 尽管优化器输出的是之后p个时间步的控制量,但是在当前时间步,MPC仅将这个最有序列的第一步应用到汽车上,忽略其余部分

三、MPC控制器的参数如何设置?

  • 参数既会影响控制器的性能,又会影响计算复杂度。

  • MPC主要的参数如下:

    • ① 采样时间
    • ② 预测范围、控制范围
    • ③ 约束
    • ④ 损失函数的权重

3.1 采样时间

采样时间过大,当干扰发生,控制器无法做出及时的反应。

采样时间过小,会导致过多的计算负载。

在这里插入图片描述

可以测量系统的阶跃响应,根据上升时间选择采样时间

3.2 预测范围、控制范围

我们应该选择一个涵盖系统重要动态的预测范围

预测范围过短,无法及时反映,可能会在弯道处急转弯

预测范围过长,之后的不可预测事件可能会白白浪费算力。

我们通常选择 20-30个样本覆盖系统的动态响应,如下图:

在这里插入图片描述

通常只有前几个时间步的控制对于预测影响较大(因为前几个要拽向ref轨迹,后面的维持稳定), 因此,选择大的控制范围只会白白增大计算复杂度

经验法则: 控制范围 = 10%~20% × 预测范围

3.3 约束条件

可以对 控制量、控制量变化率、状态量进行约束

约束分为硬约束和软约束,无法违反的(比如最大车速)叫硬约束

软约束可以违反,但我们不希望违反,可以把它设计到损失函数之中

建议将输出约束设置为软约束,并避免对控制量及其变化率设置硬约束,否则可能会出现无解的情况

3.4 权重

损失函数由多个部分组成,需要设置权重

比如最基本的,我们既希望预测轨迹接近参考轨迹,又希望控制量是平滑的。

四、自适应增益调度和非线性MPC

在这里插入图片描述

  • 线性系统 + 线性约束 + 时不变约束条件 => 可以使用线性时不变MPC控制器 => 凸优化问题

在这里插入图片描述

  • 但是如果系统是非线性的,就要使用自适应MPC、时间表MPC

    • 自适应MPC:具体思路是在非线性模型的各个工作点,建立多套线性模型

      自适应MPC的线性模型在不同工作点上结构,超参数相同,只是矩阵参数不同而已

在这里插入图片描述

  • 时间表MPC: 对于不同工作点,需要设置不同数量超参数(控制量数目、预测步长…)的模型
    在这里插入图片描述

如果是非线性的,那么优化问题就会变成多极值点的非凸优化问题,求解较复杂

在这里插入图片描述

五、Simulink仿真MPC控制器

在这里插入图片描述

itemvalue
输出量(状态量)(横向位置Y、偏航角\phi)
控制量(前轮转角delta)

假定 V x 恒为 15 m / s , 使用线性化汽车模型 假定V_x恒为15m/s , 使用线性化汽车模型\\ 假定Vx恒为15m/s,使用线性化汽车模型

模型下载地址: https://www.mathworks.com/matlabcentral/fileexchange/68992-designing-an-mpc-controller-with-simulink?s_eid=PSM_15028

(一定要记得路径,matlab界面的路径一定得是模型文件路径。路径不对的话,plant和reference的mask无法显示正确,会显示问号,同时直接运行会报错)

步骤: https://ww2.mathworks.cn/help/releases/R2017b/mpc/examples/autonomous-vehicle-steering-using-model-predictive-control.html

5.1 数学分析

下面依次介绍各个模块:

  • ① Plant: 车辆线性模型

    右键Plant模块,选择Block Parameters:

在这里插入图片描述

变量含义
V x V_x Vx小车平行于车身向前的速度
m m m小车总质量
I z I_z IzYaw夹角转动惯量(绕小车中心旋转的转动惯量)
l f l_f lf小车质心到前轮的距离
l r l_r lr小车质心到前轮的距离
C α C_{\alpha} Cα汽车转角刚度((轮胎侧偏角的单位增量所对应的横向力的增量) (N/rad)
ψ \psi ψYaw角

小车是自行车模型 ( b i c y c l e m o d e l w i t h t w o d e g r e e s o f f r e e d o m ) , 且 V x 恒为 15 m / s : {\color{Red} 小车是自行车模型(bicycle \quad model\quad with \quad two\quad degrees\quad of \quad freedom), 且V_x恒为15m/s:} 小车是自行车模型(bicyclemodelwithtwodegreesoffreedom),Vx恒为15m/s:

  • reference: 小车的自行车模型

在这里插入图片描述

  • 原理(1): 前轮运动 = 前轮相对于车身运动 + 车身相对于质心运动(旋转) + 小车质心相对于地面运动

  • 原理(2): Δ 轮胎受到垂直于车身的力 = C r ( 或者 C l ) Δ 轮胎转角 \Delta 轮胎受到垂直于车身的力 = C_{r}(或者C_{l} ) \Delta 轮胎转角 Δ轮胎受到垂直于车身的力=Cr(或者Cl)Δ轮胎转角

    (注意: 自行车模型代替小车模型时,四轮变为两轮,因此 自行车的 C f 应该是小车的 2 C f 自行车的C_f应该是 小车的2C_f 自行车的Cf应该是小车的2Cf)

进行动力学分析:
由于 ψ 较小,简化为线性模型即 : Y ˙ = V x ψ + V y [ 公式一 ] 由于\psi较小,简化为线性模型即: \dot{Y} = V_x \psi + V_y \quad [公式一]\\ 由于ψ较小,简化为线性模型即:Y˙=Vxψ+Vy[公式一]
Δ 前轮相对于车身转角 = ( V y + ψ ˙ l f V x ) Δ 后轮相对于车身转角 = ( − V y − ψ ˙ l r V x ) ⇒ 前轮受到垂直于车身的力 = 2 C f ( − ψ + δ + Δ 前轮相对于车身转角 ) 后轮受到垂直于车身的力 = 2 C r ( − ψ + Δ 后轮相对于车身转角 ) ⇒ 根据 [ 公式一 ] : m y ¨ = − m V x ψ ˙ − m V y ˙ m V y ˙ = 前轮受到垂直于车身的力 + 后轮受到垂直于车身的力 ⇒ m y ¨ = − m V x ψ ˙ + 2 C f [ − ψ + δ − V y + ψ ˙ l f V x ] + 2 C r ( − ψ − V y − ψ ˙ l r V x ) 将 [ 公式一 ] 代入到上式 : y ¨ = − 2 C f + 2 C r m V x y ˙ − ( V x + 2 C f l f − 2 C r l r m V x ) ψ ˙ + 2 C α δ m [ 公式二 ] \Delta 前轮相对于车身转角 = (\frac{V_y + \dot{\psi}l_f}{V_x}) \\ \Delta 后轮相对于车身转角 = (- \frac{V_y - \dot{\psi}l_r}{V_x}) \\ \Rightarrow \\ 前轮受到垂直于车身的力 = 2C_{f} (-\psi + \delta + \Delta 前轮相对于车身转角) \\ 后轮受到垂直于车身的力 = 2C_{r} (-\psi + \Delta 后轮相对于车身转角)\\ \Rightarrow \\ 根据[公式一]: \\ m \ddot{y} = -mV_x \dot{\psi} - m\dot{V_y}\\ m\dot{V_y}=前轮受到垂直于车身的力 + 后轮受到垂直于车身的力 \\ \Rightarrow m\ddot{y} = - m V_x \dot{\psi} + 2C_f[-\psi +\delta - \frac{V_y + \dot{\psi}l_f}{V_x}] +2 C_r (-\psi - \frac{V_y - \dot{\psi}l_r}{V_x}) \\ 将 [公式一]代入到上式: \\ {\color{Red}\ddot{y} = -\frac{2C_f+2C_r}{mV_x}\dot{y} -(V_x+\frac{2C_fl_f-2C_rl_r}{mV_x}) \dot{\psi} + \frac{2C_{\alpha} \delta}{m} \quad [公式二] } Δ前轮相对于车身转角=(VxVy+ψ˙lf)Δ后轮相对于车身转角=(VxVyψ˙lr)前轮受到垂直于车身的力=2Cf(ψ+δ+Δ前轮相对于车身转角)后轮受到垂直于车身的力=2Cr(ψ+Δ后轮相对于车身转角)根据[公式一]:my¨=mVxψ˙mVy˙mVy˙=前轮受到垂直于车身的力+后轮受到垂直于车身的力my¨=mVxψ˙+2Cf[ψ+δVxVy+ψ˙lf]+2Cr(ψVxVyψ˙lr)[公式一]代入到上式:y¨=mVx2Cf+2Cry˙(Vx+mVx2Cflf2Crlr)ψ˙+m2Cαδ[公式二]

求得小车模型的状态空间表达式为 : d d t [ y ˙ ψ ψ ˙ ] = [ − 2 C f + 2 C r m V x 0 − ( V x + 2 C f l f − 2 C r l r m V x ) 0 0 1 − 2 l f C f − 2 l r C r I z V x 0 − 2 l f 2 C f + 2 l r 2 C r I z V x ] [ y ˙ ψ ψ ˙ ] + [ 2 C f m 0 2 l f C f I z ] δ 求得小车模型的状态空间表达式为: \qquad \qquad\qquad\qquad\qquad\qquad\qquad\qquad\qquad\qquad\qquad\qquad \\ \frac{d}{dt} \begin{bmatrix} \dot{y} \\ \psi \\ \dot{\psi} \end{bmatrix} =\begin{bmatrix} -\frac{2C_f+2C_r}{mV_x} & 0 & -(V_x+\frac{2C_fl_f-2C_rl_r}{mV_x}) \\ 0 & 0 & 1\\ -\frac{2l_fC_f-2l_rC_r}{I_z V_x} & 0 & - \frac{2l_f^2C_f+2l_r^2C_r}{I_zV_x} \end{bmatrix} \begin{bmatrix} \dot{y} \\ \psi \\ \dot{\psi} \end{bmatrix} + \begin{bmatrix} 2 \frac{C_f}{m}\\ 0 \\ \frac{2l_fC_f}{I_z} \end{bmatrix} \delta 求得小车模型的状态空间表达式为:dtd y˙ψψ˙ = mVx2Cf+2Cr0IzVx2lfCf2lrCr000(Vx+mVx2Cflf2Crlr)1IzVx2lf2Cf+2lr2Cr y˙ψψ˙ + 2mCf0Iz2lfCf δ
正好就是Parameters中的A,B,C,D矩阵

5.2 实验过程

导入矩阵和参考轨迹参数,双击Params.mat即可:

在这里插入图片描述

需要更换参考轨迹的话,参考以下方法生成新的posRef和yawRef

打开APP->Driving Scenario designer->选择道路和参考轨迹

在这里插入图片描述

开始仿真:

在这里插入图片描述


http://chatgpt.dhexx.cn/article/yQ09fUJT.shtml

相关文章

使用MPC设计控制器

这个例子展示了如何使用MPC设计器设计连续搅拌釜式反应器(CSTR)的模型预测控制器。 一、 CSTR 模型 下面的微分方程表示了涉及放热反应的连续搅拌釜式反应器(CSTR)的线性化模型: 其中 输入为 : CAi -料流中试剂A浓度(kgmol/m3) Tc -反应堆冷却剂温度(℃) 输出为&…

MPC(模型预测控制)控制小车沿轨迹移动——C++实现

任务说明 要求如下图所示,给定一条轨迹,要求控制小车沿这条轨迹移动,同时可以适用于系统带有延时的情况。注意,本篇文章只给出部分C代码参考。 主要流程 首先用运动学自行车模型(Kinematic Bicycle Model&#xff09…

mpc模型预测控制原理详解

mpc模型预测控制原理详解 前言mpc算法步骤mpc算法推导 前言 本文是对mpc模型预测控制学习的记录,主要参照了DR_CAN老师的视频进行学习。视频专栏链接:DR_CAN老师mpc视频专栏。在这篇博客中博主也针对DR_CAN老师的讲解做了详尽的笔记和代码实现。读者可以…

模型预测控制(MPC)解析(一):模型

一、MPC简介 1.1 预测控制的日常应用 模型预测控制的设计目标是计算未来控制变量u的轨迹,以优化未来的系统输出y。优化过程在一个有限的时间窗口进行,并且利用优化时间窗口开始时的系统信息进行优化。为了理解预测控制的基本思想,以一个日常…

MPC控制

基于状态空间模型的控制 模型预测控制(MPC)简介 对基于状态空间模型的控制理解得很到位 在这里我重点讲解一下状态空间模型。那么什么是状态?输出是不是也是状态的一种?对的,输出也是一种状态&#…

MPC模型预测控制

这篇主要讲一下模型预测控制,如果对PID控制了解的同学,那效果更好。如果不了解PID控制,还是熟悉下比较好。 模型预测控制,顾名思义,基于模型,预测未来,进行控制。这个控制是基于模型的&#xf…

模型预测控制(MPC)简介

1.引言 在当今过程控制中,PID当然是用的最多的控制方法,但MPC也超过了10%的占有率。MPC是一个总称,有着各种各样的算法。其动态矩阵控制(DMC)是代表作。DMC采用的是系统的阶跃响应曲线,其突出的特点是解决…

模型预测控制算法(MPC算法)底层逻辑

目录 MPC算法的基本原理 详细解析 预测模型中需要注意的点 滚动优化需要注意的点 构造目标函数约束部分 约束部分 举例说明 复盘总结 MPC算法的基本原理 MPC 的基本原理可以分为三个步骤:预测模型、滚动优化、反馈校正 (1)预测模型…

模型预测控制(MPC)算法原理

模型预测算法是在欧美等国家兴起的应用于工业领域的一种优化控制算法。目前经过多年的发展,在工业领域、智能控制领域等都有应用。随着算法的理论的完善,其已经成为工业领域内经常使用的一种经典算法。虽然在各个领域算法的应用存在差异。但他们都遵循预…

到底什么是模型预测控制MPC(一)

1. 为什么使用MPC控制 在浏览文章的时候,很多文章都是基于MPC来做的。那么究竟什么是模型预测呢? 模型预测也可以说是一种我们熟悉的反馈控制算法,其目的就是预测出未来的输出。以一个生活中的例子引入: 在我们驾驶汽车的时候&am…

MPC控制笔记(一)

转自 我的博客 笔记参考1:Understanding Model Predictive Control(Youtube 带自动生成字幕) 笔记参考2:Understanding Model Predictive Control(B站 生肉) 一、什么是MPC模型预测控制 MPC(Model Predict Control)是一种反馈控制(feedback control)算…

PID与MPC控制方法

记录udacity–无人驾驶工程师课程中控制部分。 MPC代码和实践链接https://github.com/udacity/CarND-MPC-Quizzes 本文按照对udacity课程的理解和翻译而来 1、PID P:Proportional 比例项, 用比例项乘以误差;快速缩小误差; I&…

了解模型预测控制2--什么是模型预测控制(MPC)

本节,我们将讨论模型预测控制器的工作原理。 在控制问题中,控制器的目标是计算被控对象的输入,使得被控对象输出遵循期望的参考信号。模型预测控制器计算此输入的策略是预测未来。 这听起来像算命,但让我们看看它究竟是什么。MPC使…

模型预测控制(MPC,Model Predictive Control)

发展历史 20世纪70年代后期,一类新型的计算机控制算法出现在美法等国的工业过程领域,如动态矩阵控制(DMC,Dynamic Matrix Control)、模型算法控制(MAC,Model Algorithm Control)。1987年,首次有学者阐述了该系列算法的动因、机理及其在控制工…

MPC学习笔记(1)——原理

最近在学习M. W. Mehrez的MPC时发现了很多不了解的细节,分享一下对该算法的梳理与理解。 在自动驾驶或机器人领域中,模型预测控制(Model Predictive Control, MPC)解决的是轨迹规划的问题。其前提条件是环境地图、载体位姿已知,根据MPC算法&…

MPC 控制原理

MPC 控制原理 1 生活中的启示2 实际控制的例子参考文献 Yin 机械工程师 本文引自 一个模型预测控制(MPC)的简单实现. 1 生活中的启示 情景如下:你们团队每天早晨开一次例会,主要会议内容是你汇报工作进度,领导根据工作…

EA建模工具,介绍常用的UML图

[导读] 作为程序猿都最好掌握的一门语言,那就是UML(Unified Modeling Language),统一建模语言(UML)是软件工程领域中一种通用的开发建模语言,旨在提供一种可视化系统设计的标准方法。是开发人员、系统设计人员交流的有…

uml c语言函数流程图,UML流程图模板分享

原标题:UML流程图模板分享 UML是统一建模语言,又称标准建模语言是用来对软件密集系统进行可视化建模的一种语言。UML的定义包括UML语义和UML表示法两个元素。在流程图中也会经常使用到,但是网上关于该主题的模板不是很多,下面是分…

软技能之UML图

软技能之UML图 工欲善其事必先利其器,程序员建模过程中需要用到的建模工具UML。 UML:Unified Modeling Language 统一建模语言。目标是以对象图的方式来描述任何类型的系统。 UML可分为两类:结构型(描述某种结构)、行…

生成C++工程的UML类图和类继承关系图

简介 在进行软件开发时,了解代码结构和关系、类之间的继承关系以及类内部的成员函数和变量定义是非常重要的。为此,我们可以使用Doxygen和Graphviz工具来生成UML类图和类集成关系图。 Doxygen是一个用于从注释的C源代码中生成文档的工具,支…