概述
老师布置的作业,要求如下:
根据定理2和莱弗勒算法,使用matlab编写从状态空间转化成传递函数的程序,输入为(A B C D),输出为传递函数或其系数矩阵。代码如下:
clc
clear
A=input('请输入矩阵A:');
B=input('请输入矩阵B:');
C=input('请输入矩阵C:');
D=input('请输入矩阵D:');
[m,n]=size(A);
[x,y]=size(B);
a=zeros(1,m);
R=eye(m);
K=eye(m);
P=R*A;
a(1)=-trace(P)/1;
for i=2:m
R=R*A+a(i-1)*K;
P=R*A;
a(i)=-trace(P)/i;
end %求取出n个特征多项式
cab=zeros(m-1,y);
cab(1,:)=C*A*B;
for i=2:m-1
T=A^i;
cab(i,:)=C*T*B;
end
b=zeros(m,y);
b(1,:)=C*B;
for i=2:m
pk=0;
for j=1:i-2
pk=a(j)*cab(i-1-j,:)+pk;
end
b(i,:)=cab(i-1,:)+pk+a(i-1)*C*B;
end
a
b
最后
以上就是野性鞋垫为你收集整理的状态空间转化成传递函数(附matlab代码)的全部内容,希望文章能够帮你解决状态空间转化成传递函数(附matlab代码)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复