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

📄 reg.m

📁 本书是电子通信类的本科、研究生辅助教材
💻 M
字号:
function [ac,bc,cc,dc] = reg(a,b,c,d,k,l,e,f,g)
%REG Form continuous LQG controller.
%	[Ac,Bc,Cc,Dc] = REG(A,B,C,D,K,L) produces the LQG controller based
%	on the continuous system (A,B,C,D) with feedback gain matrix, K,
%	and Kalman gain matrix L, assuming all the inputs of the system 
%	are control inputs and all the outputs of the system are sensor 
%	outputs.  The resulting state-space controller is
%		 .
%		xHat = [A-BK-LC+LDK] xHat + Ly
%		uHat = [K] xHat
%
%	and has control feedback commands uHat as outputs and sensors y as
%	inputs.  The controller should be connected to the plant using 
%	negative feedback.
%
%	[Ac,Bc,Cc,Dc] = REG(A,B,C,D,K,L,SENSORS,KNOWN,CONTROLS) forms the
%	LQG controller using the sensors specified by SENSORS, the 
%	additional known inputs specified by KNOWN, and the control inputs
%	specified by CONTROLS. The resulting system has control feedback
%	commands as outputs and the known inputs and sensors as inputs. 
%	The KNOWN inputs are non-stochastic inputs of the plant and are 
%	usually additional control inputs or command inputs.
%
% 	See also: DREG,ESTIM,DESTIM,LQR,DLQR,LQE and DLQE.

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

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

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

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

if (nargin==6)
  sensors = [1:ny]; known = []; controls = [1:nu];
end
if (nargin==9)
  sensors = e; known = f; controls = g;
end

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

% Check size of K and L with number of states, sensors and controls
[nk,mk] = size(k); [nl,ml] = size(l);
if (nk~=nfb)
  error('Number of controls and size of K matrix don''t match.'); end
if (mk~=nx)
  error('The A and K matrices must have the same number of columns.'); end
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

fdbk = [1:nfb] + ny; inputs = [1:nsens] + nu;

% --- Form continuous LQG controller ---
ac = a;
bc = [b,l];
cc = [c;k];
dc = [d, zeros(ny,nsens);zeros(nfb,nu), zeros(nfb,nsens)];

% close sensor and internal control feedback loops
[ac,bc,cc,dc] = cloop(ac,bc,cc,dc,[fdbk,sensors],-[controls,inputs]);
[ac,bc,cc,dc] = ssselect(ac,bc,cc,dc,[known,inputs],fdbk);

⌨️ 快捷键说明

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