📄 luenberger.m
字号:
function T=luenberger(A,B)
n=size(A,1); p=size(B,2); S=[]; sigmas=[]; k=1;
for i=1:p
for j=0:n-1
S=[S,A^j*B(:,i)];
if rank(S)==k, k=k+1;
else, sigmas(i)=j-1; S=S(:,1:end-1); break; end,
end
if k>n, break; end
end
k=k-1; % 如果不是完全可控,则用随机数补足满秩矩阵
if k<n
while rank(S)~=n, S(:,k+1:n)=floor(10*rand(n,n-k)); end
end
L=inv(S); iT=[];
for i=1:p
for j=0:sigmas(i)
iT=[iT; L(i+sum(sigmas(1:i)),:)*A^j];
end,
end
if k<n, iT(k+1:n,:)=L(k+1:end,:); end % 不可控时补足满秩矩阵
T=inv(iT); % 构造变换矩阵
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -