MPC模型预测控制
最优化控制
研究动机
在一定的约束条件下达到最优的系统表现,最优是综合分析的最优
代价函数与评判标准
对于单输入单输出系统控制,e(t)为误差, u(t)为输入
当 $\int_0^te^2dt$ 最小时,就可以保证系统的追踪性很好
当 $\int_1^tu^2dt$ 最小时,可以保证系统的输入最小,能耗最低
控制过程的代价函数
目的就是设计一个u使J达到最小值
q和r就是我们可以调节的参数,如果 $q>>r$ 那么就是设计过程更加注重误差,如果 $r>>q$的话,就是设计过程更加注重能耗最低
对于多输入多输出的系统控制中
$\frac{dx}{dt} = Ax +Bu$ x是系统的状态变量
$Y=Cx$ Y就是系统的输出
代价方程就是
一个栗子:
$\begin{bmatrix} y_1 \\ y_2\\ \end{bmatrix} = \begin{bmatrix} x_1 \\ x_2 \\ \end{bmatrix}$
$R = \begin{bmatrix}r_1\\r_2\\ \end{bmatrix} = \begin{bmatrix}0\\0\\ \end{bmatrix}$
$⇒E = \begin{bmatrix}e_1\\e_2\\\end{bmatrix} = \begin{bmatrix}y_1-r_1\\y_2-r_2\\\end{bmatrix} = \begin{bmatrix}x_1\\x_2\\\end{bmatrix}$
$⇒E^TQE=\begin{bmatrix}x_1&x_2\\\end{bmatrix}\begin{bmatrix}q_1&0\\0&q_2\\\end{bmatrix}\begin{bmatrix}x_1\\x_2\\\end{bmatrix} = q_1x_1^2+q_2x_2^2$
$⇒u^TRu = r_1u_1^2+r_2u_2^2$
Q和R都是调节矩阵, $q_1,q_2,r_1,r_2$都是权重系数,如果过多的关注 $x_1$的话,可以适当的将 $q_1,r_1$加大,加重权重系数
MPC
通过模型来预测系统在某一时间段内的表现来进行最优化控制,多用于数位控制,多采用离散型状态空间的表达形式 $X_{k+1} = AX_k+Bu_k$
分析步骤
在当前时刻,即k时刻
- 测量/估计当前状态,输出为 $Y_k$
基于 $u_k,u_{k+1},….u_{k+N}$ 来进行最优化, N为预测出空间,N-1为控制范围
代价函数
其中 $E_N^TFE_N$ 代表了最终的结果,就是期望值,也就是最末一点,终端误差,预测区间最后时刻的误差的代价函数,目的就是找到 $J$ 的最小值
并且 Q 与 R 都是对角矩阵
需要找到 $u_k,u_{k+1},….u_{k+N}$ 并非要使用所有的 $u_k$,只实施第一个也就是 $u_k$,当时间到达k+1的时候,就要把窗口,也就是预测区间向右移动,每一步都需要去求解一个最优化问题——滚动优化问题
mpc在预测的过程中会考虑到系统的约束
二次规划
一般形式
当Q为对角矩阵时,这个式子为
就变成了一个最小二乘的形式
对于一个系统状态方程
利用增广矩阵来表示k时刻的预测的结果
其中 N 表示预测的区间
定义
代价函数为
其中
- $X(k+i|k)^TQX(k+i|k)$ 误差加权和
- $u(k+i|k)^TRu(k+i|k)$ 输入加权和
- $x(k+N)^TFx(k+N)$ 终端误差
在k时刻时
根据之前定义简化方程
可令
其中 $M$ 为 $(N+1)\times 1$, $C$ 为 $(N+1)\times N$ 矩阵
则简化为
代价函数为
其中第一项与最后一项为
令
则上式为
中间一项为
令
上式化简为
故而代价函数为
由于
则
分开之后为
对于第2项和第3项,它们互为转置,并且 $\overline{Q}$ 是对称的,所以可以简化合并为
对于第4项和第5项,也可以化简为
可令
最终,代价函数写作
求解最优解,先求导数为0处,即
即
求得
验证是否为极小值
由于H中的 $\overline{Q}$, $C$, $\overline{R}$ 都为正定阵,所以结果一定是正定的,故得证
1 | % 这是一个通用的 MPC 模型预测算法的代码 |
1 | function [E , H]=MPC_Matrices(A,B,Q,R,F,N) |
1 | function u_k= Prediction(x_k,E,H,N,p) |