MATLAB:ode45


ode45

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

调用方法

[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 中国 

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))

 改造:

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中,可以使用ode45函数来求解微分方程。ode45是一个常用的非刚性ODE求解器,它使用了4阶和5阶的Runge-Kutta方法来进行数值积分。要使用ode45求解微分方程,需要编写一个函数来表示微分方程的右侧。下面是一个示例代码: ```matlab % 定义微分方程的右侧函数 function dxdt = myODE(t, x) % 在这里编写微分方程的右侧表达式 dxdt = x^2 - 2*x + 1; end % 指定积分的时间区间和初始条件 tspan = \[0, 10\]; % 积分时间区间 x0 = 0; % 初始条件 % 使用ode45求解微分方程 \[t, x\] = ode45(@myODE, tspan, x0); % 绘制结果 plot(t, x); xlabel('时间'); ylabel('解'); ``` 在上面的代码中,myODE函数表示微分方程的右侧表达式。t是时间变量,x是未知函数。在这个例子中,微分方程是x' = x^2 - 2x + 1。然后,使用ode45函数对微分方程进行求解,并将结果存储在t和x变量中。最后,使用plot函数绘制结果。 请注意,这只是一个简单的示例,实际的微分方程可能更加复杂。你需要根据你的具体微分方程来编写相应的右侧函数。 #### 引用[.reference_title] - *1* *2* [MATLAB 数学应用 微分方程 常微分方程 求解具有多个初始条件的ODE方程组](https://blog.csdn.net/u013883025/article/details/118485669)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [[MATLAB]常微分方程数值求解(ode45 ode15s ode23 solver)](https://blog.csdn.net/m0_37149062/article/details/105113409)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值