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

📄 connect.m

📁 经典通信系统仿真书籍《通信系统与 MATLAB (Proakis)》源代码
💻 M
字号:
function [aa,bb,cc,dd] = connect(a,b,c,d,q,iu,iy)
%CONNECT  Given the block diagram of a system, CONNECT can be used to
%	form an (A,B,C,D) state-space model of the system.
%
%	[Ac,Bc,Cc,Dc] = CONNECT(A,B,C,D,Q,INPUTS,OUTPUTS)  returns the 
%	state-space matrices (Ac,Bc,Cc,Dc) of a system given the block 
%	diagonal, unconnected (A,B,C,D) matrices and a matrix Q that 
%	specifies the interconnections.  The matrix Q has a row for each 
%	input, where the first element of each row is the number of the 
%	input.  The subsequent elements of each row specify where the 
%	block gets its summing inputs, with negative elements used to 
%	indicate minus inputs to the summing junction.  For example, if 
%	block 7 gets its inputs from the outputs of blocks 2, 15, and 6, 
%	and the block 15 input is negative, the 7'th row of Q would be 
%	[7 2 -15 6].  The vectors INPUTS and OUTPUTS are used to select 
%	the final inputs and outputs for (Ac,Bc,Cc,Dc). 
%
%	For more information see the User's Guide.   
%	See also BLKBUILD and CLOOP.

%	Copyright (c) 1986-93 by the MathWorks, Inc.
% 	J.N. Little 7-24-85
% 	Last modified JNL 6-2-86

[mq,nq] = size(q);
[md,nd] = size(d); 

% Form k from q, the feedback matrix such that u = k*y forms the
% desired connected system.  k is a matrix of zeros and plus or minus ones.

k = zeros(nd,md);
% Go through rows of Q
for i=1:mq
	% Remove zero elements from each row of Q
	qi = q(i,find(q(i,:)));
	[m,n] = size(qi);
	% Put the zeros and +-ones in K
	if n ~= 1
		k(qi(1),abs(qi(2:n))) = sign(qi(2:n));
	end
end

% Use output feedback to form closed loop system
%	.
%	x = Ax + Bu
%	y = Cx + Du      where  u = k*y + Ur 
%
bb = b/(eye(nd) - k*d);
aa = a + bb*k*c;
t = eye(md) - d*k;
cc = t\c;
dd = t\d;

% Select just the outputs and inputs wanted:
bb = bb(:,iu);
cc = cc(iy,:);
dd = dd(iy,iu);

⌨️ 快捷键说明

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