中国汽车工程师之家--聚集了汽车行业80%专业人士 

论坛口号:知无不言,言无不尽!QQ:542334618 

本站手机访问:直接在浏览器中输入本站域名即可 

  • 592查看
  • 0回复

[MATLAB] matlab实现RK45(Runge-Kutta45、ode45)求解器算法

[复制链接]


该用户从未签到

发表于 26-8-2023 15:35:15 | 显示全部楼层 |阅读模式

汽车零部件采购、销售通信录       填写你的培训需求,我们帮你找      招募汽车专业培训老师


RK45求解器,又称为Dormand-Prince求解器。这是比较精确的求解器,可以快速地求解微分方程,但是,需要消耗一些内存。在matlab simulink中默认条件下,系统自动选择RK45求解器。用户可以根据实际问题,选择合适的求解器。

Dopri54是Dormand / Prince龙格-库塔的一种方法,Dopri54由龙格-库塔简单法构成,阶为5和4。因此,五阶龙格-库塔法是利用一步向前+四阶龙格-库塔法估计误差。

本文分享一个简单例子来从m代码实现RK45求解器,matlab也可以用自带的ode45函数来求解微分方程:Matlab通过ode系列函数求解微分方程

假定y'=y,y(0) = 1,很明显结果的理论解为y(t)=e^t,

matlab代码

clcclose allcleary0 = 1;[t,y] = dopri54c('fun', 0, 1, y0, 0.0001);
figureplot(t,y)function u = fun(x, y)u=y;function[t_1, y_1]=dopri54c(funcion,t0,t1,y0,tol)%Dormand and Prince 54 code.%INPUT%funcion - 函数句柄%t0 - 开始时间.%t1 - 结束时间.%y0 - 初始值.%tol - 局部误差%OUTPUT%y - 输出t=t0;y=y0;h=tol^(1/5)/4;step=0;nrej=0;fcall=1;a4=[44/45 -56/15 32/9]';a5=[19372/6561 -25360/2187 64448/6561 -212/729]';a6=[9017/3168 -355/33 46732/5247 49/176 -5103/18656]';a7=[35/384 0 500/1113 125/192 -2187/6784 11/84]';e=[71/57600 -1/40 -71/16695 71/1920 -17253/339200 22/525]';k1=feval(funcion,t,y);t_1 = t;y_1 = y;
whilet < t1ift+h > t1h=t1-t; endk2=feval(funcion,t+h/5,y+h*k1/5);k3=feval(funcion,t+3*h/10,y+h*(3*k1+9*k2)/40);k4=feval(funcion,t+4*h/5,y+h*(a4(1)*k1+a4(2)*k2+a4(3)*k3));k5=feval(funcion,t+8*h/9,y+h*(a5(1)*k1+a5(2)*k2+a5(3)*k3+a5(4)*k4));k6=feval(funcion,t+h,y+h*(a6(1)*k1+a6(2)*k2+a6(3)*k3+a6(4)*k4+a6(5)*k5));yt=y+h*(a7(1)*k1+a7(3)*k3+a7(4)*k4+a7(5)*k5+a7(6)*k6);k2=feval(funcion,t+h,yt);est=norm(h*(e(1)*k1+e(2)*k2+e(3)*k3+e(4)*k4+e(5)*k5+e(6)*k6),inf);fcall=fcall+6;
ifest < tolt=t+h;k1=k2;step=step+1;y=yt;t_1 = [t_1; t];y_1 = [y_1; y];elsenrej=nrej+1;endh=.9*min((tol/(est+eps))^(1/5),10)*h;
end

matlab实现RK45(Runge-Kutta45、ode45)求解器算法w1.jpg

matlab实现RK45(Runge-Kutta45、ode45)求解器算法w2.jpg

结果符合预期

快速发帖

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|手机版|小黑屋|Archiver|汽车工程师之家 ( 渝ICP备18012993号-1 )

GMT+8, 3-1-2025 18:41 , Processed in 0.306365 second(s), 32 queries .

Powered by Discuz! X3.5

© 2001-2013 Comsenz Inc.