Optimal filtering is a means of adaptive extraction of a weak desired signal in the presence of noise and interfering signals. Optimal filters normally are free from stability
problems. There are simple operational checks on an optimal filter when it is being used that indicate whether it is operating correctly. Optimal filters are
probably easier to make adaptive to parameter changes than suboptimal filters.The goal of optimal filtering is to design a filter that acts on the output
of the generalized plant and optimizes the transfer matrix from w to the filtered output.
Consider the continuous-time generalized LTI plant with minimal states-space realization
data:image/s3,"s3://crabby-images/1cfe9/1cfe9bc4e68657f5438b21d7aa85ed709c257972" alt="{\displaystyle {\begin{aligned}{\dot {x}}&=Ax+B_{1}w\\z&=C_{1}x+D_{11}w,\\y&=C_{2}x+D_{21}w,\end{aligned}}}"
where it is assumed that
is Hurwitz.
The matrices needed as inputs are
.
An
-optimal filter is designed to minimize the
norm of
in following equation.
data:image/s3,"s3://crabby-images/f3040/f3040ebf69d51a971918a0e7eee783d1c46ad04c" alt="{\displaystyle {\begin{aligned}{\tilde {P}}(s)={\tilde {C}}_{1}(sI-{\tilde {A}})^{-}1{\tilde {B}}_{1}+{\tilde {D}}_{11},\\{\text{where}}\\{\tilde {A}}={\begin{bmatrix}A&&0\\B_{f}C_{2}&&A_{f}\end{bmatrix}}&<0\\{\tilde {B}}_{1}={\begin{bmatrix}B_{1}\\B_{f}D_{21}\end{bmatrix}}&<0\\{\tilde {C}}_{1}={\begin{bmatrix}C_{1}-D_{f}C_{2}-C_{f}\end{bmatrix}}&<0\\{\tilde {D}}_{11}=D_{11}-D_{f}D_{21}\\\end{aligned}}}"
To ensure that
has a finite
norm, it is required that
, which results in
Solve for
,
and
that minimize
subject to
.
data:image/s3,"s3://crabby-images/7c2b3/7c2b301bdfdbed7d5f645d193ca204acdcdddc6e" alt="{\displaystyle {\begin{aligned}{\begin{bmatrix}YA+A^{T}Y+B_{n}C_{2}&&A_{n}+C_{2}^{T}B_{n}^{T}+A^{T}X&&YB_{1}+B_{n}D_{21}\\\star &&A_{n}+A_{n}^{T}&&XB_{1}+B_{n}D_{21}\\\star &&\star &&-1\end{bmatrix}}&<0\\{\begin{bmatrix}-Z&&C_{1}-D_{f}C_{2}&&-C_{f}\\\star &&-Y&&-X\\\star &&\star &&-X\end{bmatrix}}&<0\\Y-X>0\\trZ</nu\end{aligned}}}"
The filter is recovered by
and
.
MATLAB code of
Optimal filter