⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 estim.m

📁 数字通信第四版原书的例程
💻 M
字号:
function [ae,be,ce,de] = estim(a,b,c,d,l,e,f)
%ESTIM Form continuous Kalman estimator.
%	[Ae,Be,Ce,De] = ESTIM(A,B,C,D,L) produces the Kalman estimator 
%	based on the continuous system (A,B,C,D) with Kalman gain matrix
%	L assuming all the outputs of the system are sensor outputs.  The
%	resulting state-space estimator is
%		  .
%		 xHat  = [A-LC] xHat + Ly
%
%		|yHat| = |C| xHat
%		|xHat|   |I|
%
%	and has estimated sensors yHat and estimated states xHat as 
%	outputs, and sensors y as inputs.  
%
%	[Ae,Be,Ce,De] = ESTIM(A,B,C,D,L,SENSORS,KNOWN) forms the Kalman 
%	estimator using the sensors specified by SENSORS, and the 
%	additional known inputs specified by KNOWN.  The resulting system
%	has estimated sensors and states as outputs, and the known inputs
%	and sensors as inputs.  The KNOWN inputs are non-stochastic inputs
%	of the plant and are usually control inputs.
%
% 	See also: REG,DCONTROL,DESTIM,LQR,DLQR,LQE and DLQE.

%	Clay M. Thompson 7-2-90
%	Copyright (c) 1986-93 by the MathWorks, Inc.

error(nargchk(5,7,nargin));
if ~((nargin==5)|(nargin==7)), error('Wrong number of input arguments.'); end

error(abcdchk(a,b,c,d));

[nx,na] = size(a);
[ny,nu] = size(d);

if (nargin==5)
  sensors = [1:ny]; known = [];
end
if (nargin==7)
  sensors = e; known = f;
end

nsens = length(sensors); nknown = length(known);

% Check size of L with number of states and sensors
[nl,ml] = size(l);
if (ml~=nsens)
  error('Number of sensors and size of L matrix don''t match.'); end
if (nl~=nx)
  error('The A and L matrices must have the same number of rows.'); end

inputs = [1:nsens] + nu; states = [1:nx] + ny;

% --- Form continuous Kalman estimator ---
ae = a;
be = [b,l];
ce = [c;eye(nx)];
de = [d, zeros(ny,nsens);zeros(nx,nu), zeros(nx,nsens)];

% close sensor feedback loop
[ae,be,ce,de] = cloop(ae,be,ce,de,sensors,-inputs);
[ae,be,ce,de] = ssselect(ae,be,ce,de,[known,inputs],[sensors,states]);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -