我是靠谱客的博主 过时黑米,这篇文章主要介绍MATLAB:ode45ode45,现在分享给大家,希望可以做个参考。


ode45

ode45实际上是数值分析中数值求解微分方程组的一种方法,4阶五级Runge-Kutta算法。

调用方法

复制代码
1
[t,x]=ode45(Fun,tspan,x0,options,pars)

其实这种方程的每一个状态变量都是t的函数,我们可以从现代控制理论的状态空间来想。因此返回[ t,x ],其中t是一个列向量,x是n×n的矩阵,它的每一列就是其中一个状态变量随t的变化值。

  • t 返回列向量的时间点
  • X 返回对应T的求解列向量

之后定义.m函数亦或是匿名函数f = @ ( t , x )来描述微分方程组的右边部分,并且是列向量。(注意匿名函数一定是先t后x并且一定有t占位)

EG1:

%三维点或线图 - MATLAB plot3 - MathWorks 中国 

复制代码
1
2
3
4
5
6
f = @(t,x)[-x(2)-x(3);x(1)+0.2*x(2);0.2+(x(1)-5.7)*x(3)]; [t,y] = ode45(f,[0,100],[0;0;0]); plot(t,y); figure; plot3(y(:,1),y(:,2),y(:,3))

 改造:

复制代码
1
2
3
4
5
6
7
8
9
10
f = @(t,x)[-x(2)-x(3);x(1)+0.2*x(2);0.2+(x(1)-5.7)*x(3)]; [t,y] = ode45(f,[0,100],[0;0;0]); plot(t,y(:,1),"b") hold on plot(t,y(:,2),"y") plot(t,y(:,3),"r") legend("x(t)","y(t)","z(t)"); figure; plot3(y(:,1),y(:,2),y(:,3))%第一列,第二列,第三列分别为x,y,z的数据做成三维图

 

求解非刚性微分方程 - 中阶方法 - MATLAB ode45 - MathWorks 中国

最后

以上就是过时黑米最近收集整理的关于MATLAB:ode45ode45的全部内容,更多相关MATLAB内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(93)

评论列表共有 0 条评论

立即
投稿
返回
顶部