LMIs in Control/pages/H-2 filtering
For systems that have disturbances, filtering can be used to reduce the effects of these disturbances. Described on this page is a method of attaining a filter that will reduce the effects of the disturbances as completely as possible. To do this, we look to find a set of new coefficient matrices that describe the filtered system. The process to achieve such a new system is described below. The H2-filter tries to minimize the average magnitude of error.
For the application of this LMI, we will look at linear systems that can be represented in state space as
data:image/s3,"s3://crabby-images/3eb7e/3eb7ea5dd449d03468ece08a5aa9c8c29c636bdd" alt="{\displaystyle {\begin{aligned}{\dot {x}}&=Ax+Bw,x(0)=x_{0}\\y&=Cx+Dw\\z&=Lx\end{aligned}}}"
where
represent the state vector, the measured output vector, and the output vector of interest, respectively,
is the disturbance vector, and
and
are the system matrices of appropriate dimension.
To further define:
is
and is the state vector,
is
and is the state matrix,
is
and is the input matrix,
is
and is the exogenous input,
is
and is the output matrix,
and
are
and are feedthrough matrices, and
and
are
and are the output and the output of interest, respectively.
The data are
(the disturbance vector), and
and
(the system matrices). Furthermore, the
matrix is assumed to be stable
We need to design a filter that will eliminate the effects of the disturbances as best we can. For this, we take a filter of the following form:
data:image/s3,"s3://crabby-images/72454/72454c79f2a9c3ede0d0e01bc71dd8ee7e4f31fd" alt="{\displaystyle {\begin{aligned}{\dot {\sigma }}&=A_{f}\sigma +B_{f}y,\sigma (0)=\sigma _{0}\\{\hat {z}}&=C_{f}\sigma ,\end{aligned}}}"
where
is the state vector,
is the estimation vector, and
are the coefficient matrices of appropriate dimensions.
Note that the combined complete system can be represented as
data:image/s3,"s3://crabby-images/1f880/1f88090b3db45ca5f89b9983311b3c668a2d666d" alt="{\displaystyle {\begin{aligned}{\dot {x}}_{e}&={\tilde {A}}x_{e}+{\tilde {B}}w,x_{e}(0)=x_{e0}\\{\tilde {z}}&={\tilde {C}}x_{e},\end{aligned}}}"
where
is the estimation error,
data:image/s3,"s3://crabby-images/4b575/4b57537ee5f87560500dd7dc245a40e429df1ee9" alt="{\displaystyle {\begin{aligned}x_{e}={\begin{bmatrix}x\\\sigma \end{bmatrix}}\\\end{aligned}}}"
is the state vector of the system, and
are the coefficient matrices, defined as:
data:image/s3,"s3://crabby-images/ae8ed/ae8ed493d522c9c8fd8d0a3e1a1ad465c48f92f5" alt="{\displaystyle {\begin{aligned}{\tilde {A}}={\begin{bmatrix}A&0\\B_{f}C&A_{f}\end{bmatrix}},{\tilde {B}}={\begin{bmatrix}B\\B_{f}D\end{bmatrix}},\\{\tilde {C}}={\begin{bmatrix}L&-C_{f}\end{bmatrix}}\end{aligned}}}"
In other words, for the system defined above we need to find
such that
data:image/s3,"s3://crabby-images/a9969/a996927e1b67216cafffbb7177a186b1a0049a5a" alt="{\displaystyle {\begin{aligned}||G_{{\tilde {z}}w}(s)||_{2}<\gamma ,\end{aligned}}}"
where
is a positive constant, and
data:image/s3,"s3://crabby-images/1e88f/1e88f0c66baa52063467d118134db1295d7f28ae" alt="{\displaystyle {\begin{aligned}G_{{\tilde {z}}w}(s)={\tilde {C}}(sI-{\tilde {A}})^{-1}{\tilde {B}}\end{aligned}}}"
For this LMI, the solution exists if one of the following sets of LMIs hold:
Matrices
exist that obey the following LMIs:
data:image/s3,"s3://crabby-images/5a5e3/5a5e3fbb1b395d21cdec680db11ec7b6f01a59b2" alt="{\displaystyle {\begin{aligned}R-X&>0,\\trace(Q)&<\gamma ^{2},\\{\begin{bmatrix}-Q&*&*\\L^{T}&-R&*\\-N^{T}&-X&-X\end{bmatrix}}&<0,\\{\begin{bmatrix}RA+A^{T}R+ZC+C^{T}Z^{T}&*&*\\M^{T}+ZC+XA&M^{T}+M&*\\B^{T}R+D^{T}Z^{T}&B^{T}X+D^{T}Z^{T}&-I\end{bmatrix}}&<0.\\\end{aligned}}}"
or
Matrices
exist that obey the following LMIs:
data:image/s3,"s3://crabby-images/ffda4/ffda4dfabf5d3c92eaa256b57bcda1b0e02bfdf3" alt="{\displaystyle {\begin{aligned}{\bar {R}}-{\bar {X}}&>0,\\trace({\bar {Q}})&<\gamma ^{2},\\{\begin{bmatrix}-{\bar {Q}}&*&*\\{\bar {R}}B+{\bar {Z}}D&-{\bar {R}}&*\\{\bar {X}}B+{\bar {Z}}D&-{\bar {X}}&-I\end{bmatrix}}&<0,\\{\begin{bmatrix}{\bar {R}}A+A^{T}{\bar {R}}+{\bar {Z}}C+C^{T}{\bar {Z}}^{T}&*&*\\{\bar {M}}^{T}+{\bar {Z}}C+{\bar {X}}A&{\bar {M}}^{T}+{\bar {M}}&*\\L&-{\bar {N}}&-I\end{bmatrix}}&<0.\\\end{aligned}}}"
To find the corresponding filter, use the optimized matrices from the first solution to find:
data:image/s3,"s3://crabby-images/baceb/baceb4ccbf3500c13568b9497cd7ad9de0cd72e5" alt="{\displaystyle A_{f}=X^{-1}M,B_{f}=X^{-1}Z,C_{f}=N}"
Or the second solution to find:
data:image/s3,"s3://crabby-images/4a1ad/4a1adfda9f434ec01709cc321ca0ebf13e38e45b" alt="{\displaystyle A_{f}={\bar {X}}^{-1}{\bar {M}},B_{f}={\bar {X}}^{-1}{\bar {Z}},C_{f}={\bar {N}}}"
These matrices can then be used to produce
to construct the final filter below, that will best eliminate the disturbances of the system.
data:image/s3,"s3://crabby-images/1f880/1f88090b3db45ca5f89b9983311b3c668a2d666d" alt="{\displaystyle {\begin{aligned}{\dot {x}}_{e}&={\tilde {A}}x_{e}+{\tilde {B}}w,x_{e}(0)=x_{e0}\\{\tilde {z}}&={\tilde {C}}x_{e},\end{aligned}}}"
This implementation requires Yalmip and Sedumi.
https://github.com/rezajamesahmed/LMImatlabcode/blob/master/H2_Filtering.m
H-infinity filtering
This LMI comes from
- [1] - "LMIs in Control Systems: Analysis, Design and Applications" by Guang-Ren Duan and Hai-Hua Yu
Other resources:
Duan, G. (2013). LMIs in control systems: analysis, design and applications. Boca Raton: CRC Press, Taylor & Francis Group.