早教吧作业答案频道 -->其他-->
初学matlab,遇到一个问题,就是前面定义了u但是没有定义u(i),怎么后面突然用上了直接用上了u(i)clearall;closeall;h=0.3;%设置步长l=15/h;%求得步数lz=[-1-2];p=[-4-0.5+j-0.5-j];k=2.5;[A,B,C,D]=zp2ss(z,p,
题目详情
初学matlab,遇到一个问题,就是前面定义了u但是没有定义u(i),怎么后面突然用上了直接用上了u(i)
clear all;
close all;
h=0.3; %设置步长
l=15/h; %求得步数l
z=[-1 -2];
p=[-4 -0.5+j -0.5-j];
k=2.5;
[A,B,C,D]=zp2ss(z,p,k); %将零极点转换成状态方程x'(t)=Ax(t)+Bu(t);y(t)=Cx(t)+Du(t);
u=1*ones(l,1);
u0=0 %设定初值
n=length(p); %求得极点的个数;对象阶次
x0=zeros(n,1); %x0初始值设为0
xe0=zeros(n,1); %Xe0初始值也设为0
for i=1:l
time(i)=i*h;
%欧拉法
xe=xe0+h*(A*xe0+B*u0);%X(k+1)=X(k)+h*f(X,t)
ye(i)=C*xe; %y=Cx
%Runge-Kutta
k1=A*x0+B*u0; %k1=f(x,u)
k2=A*(x0+h*k1/2)+B*u0;%k2=f(x+h/2,u+k1/2)
k3=A*(x0+h*k2/2)+B*u0;%k3=f(x+h/2,u+k2/2)
k4=A*(x0+h*k3)+B*u0; %k4=f(x+h,u+k3)
x=x0+h*(k1+2*k2+2*k3+k4)/6;
y(i)=C*x;
%updata datas
u0=u(i); %
x0=x;
xe0=xe;
end
plot(time,u,'k-',time,ye,':',time,y,'r');
xlabel('t');ylabel('y_r(t)、y(t)');
legend('y_r(t) ','Euler:y(t)','Runge-Kutta:y(t)');
clear all;
close all;
h=0.3; %设置步长
l=15/h; %求得步数l
z=[-1 -2];
p=[-4 -0.5+j -0.5-j];
k=2.5;
[A,B,C,D]=zp2ss(z,p,k); %将零极点转换成状态方程x'(t)=Ax(t)+Bu(t);y(t)=Cx(t)+Du(t);
u=1*ones(l,1);
u0=0 %设定初值
n=length(p); %求得极点的个数;对象阶次
x0=zeros(n,1); %x0初始值设为0
xe0=zeros(n,1); %Xe0初始值也设为0
for i=1:l
time(i)=i*h;
%欧拉法
xe=xe0+h*(A*xe0+B*u0);%X(k+1)=X(k)+h*f(X,t)
ye(i)=C*xe; %y=Cx
%Runge-Kutta
k1=A*x0+B*u0; %k1=f(x,u)
k2=A*(x0+h*k1/2)+B*u0;%k2=f(x+h/2,u+k1/2)
k3=A*(x0+h*k2/2)+B*u0;%k3=f(x+h/2,u+k2/2)
k4=A*(x0+h*k3)+B*u0; %k4=f(x+h,u+k3)
x=x0+h*(k1+2*k2+2*k3+k4)/6;
y(i)=C*x;
%updata datas
u0=u(i); %
x0=x;
xe0=xe;
end
plot(time,u,'k-',time,ye,':',time,y,'r');
xlabel('t');ylabel('y_r(t)、y(t)');
legend('y_r(t) ','Euler:y(t)','Runge-Kutta:y(t)');
▼优质解答
答案和解析
由这h=0.3; l=15/h;两句结果:l =50
u=1*ones(l,1);-----------产生50行1列的全1列向量
所以从这句以后,u就是一个有50个元素的全1列向量了
当然有u(1)、u(2).u(50)了
u=1*ones(l,1);-----------产生50行1列的全1列向量
所以从这句以后,u就是一个有50个元素的全1列向量了
当然有u(1)、u(2).u(50)了
看了 初学matlab,遇到一个问...的网友还看了以下:
分母为零无意义,如果分子分母都为零呢a/b可以说是a÷b若b=0,a÷b=c那么cb=ac*0=aa 2020-03-30 …
如图所示的坐标系里面放置3个带电小球,原点位置的小球的电荷量为5.0×10-9C,x轴正方向0.3 2020-05-13 …
求函数值域:Y=根号X²-2X+6,结果已经出来,不对X²-2X+6≥0这里为什么把根号里的东西变 2020-05-21 …
大乐透怎么中.第一次买呵呵请问下大乐透数字中了位置是任意的可以嘛?譬如8等级5元的是3+0或1+2 2020-06-19 …
重力场电场复和场问题电场与重力场的平衡位置含义是什么,合力为0根据mV^2/r速度不就为0了吗求助 2020-06-23 …
初学matlab,遇到一个问题,就是前面定义了u但是没有定义u(i),怎么后面突然用上了直接用上了 2020-07-24 …
一个底数为二次函数的对数方程,定义域是R一个真数为二次函数的对数方程,定义域是R,为什么要真数的△ 2020-07-30 …
定义运算a*b=a(1-b),下面给出了几个结论:1.a*b=b*a2.若a+b=0,则(a*a)+ 2020-11-08 …
2013年4月20日8时02分,四川省雅安市发生里氏7.0级地震,又一次考验我们的应急救援和保障机制 2020-12-06 …
用盐水选种,要求盐水的密度为1.1X10^3m^3,先配置了0.5X10^3m^3的盐水,称出它的质 2021-01-02 …