Matlab中龙格-库塔(Runge-Kutta)方法原理及实现

合集下载

matlab四阶龙格库塔法解方程组

matlab四阶龙格库塔法解方程组

matlab四阶龙格库塔法解方程组摘要:1.MATLAB 与四阶龙格- 库塔法简介2.四阶龙格- 库塔法求解方程组的原理3.MATLAB 中实现四阶龙格- 库塔法的方法4.四阶龙格- 库塔法在MATLAB 中的应用实例5.总结与展望正文:一、MATLAB 与四阶龙格- 库塔法简介MATLAB 是一种广泛应用于科学计算、数据分析和可视化的编程语言,它为用户提供了丰富的函数库和工具箱,使得各种数学运算和工程计算变得简单易行。

在MATLAB 中,求解方程组是工程和技术领域中常见的问题,而四阶龙格- 库塔法(RK4)是一种高效的数值求解方法。

二、四阶龙格- 库塔法求解方程组的原理四阶龙格- 库塔法是一种基于分步法的四阶数值积分方法,用于求解常微分方程初值问题。

它通过将求解区间分为若干个小区间,然后在每个小区间内,对导数进行四次评估,最后以加权平均的方式获取区间内函数的平均斜率,从而近似求得该区间内函数的值。

通过这种方式,可以逐步求解出方程组的解。

三、MATLAB 中实现四阶龙格- 库塔法的方法在MATLAB 中,可以使用自定义函数和循环结构实现四阶龙格- 库塔法求解方程组。

以下是一个简单的示例:```matlabfunction dXdt = rk4(t, X, f, dt)% 计算k1k1 = f(t, X);% 计算k2k2 = f(t + dt/2, X + 0.5*dt*k1);% 计算k3k3 = f(t + dt/2, X + 0.5*dt*k2);% 计算k4k4 = f(t + dt, X + dt*k3);% 计算四阶龙格- 库塔法导数dXdt = (k1 + 2*k2 + 2*k3 + k4) / 6;end```四、四阶龙格- 库塔法在MATLAB 中的应用实例假设我们要求解如下方程组:```x" = 2*y - zy" = x + 2*zz" = -x + y```我们可以使用MATLAB 中的四阶龙格- 库塔法求解该方程组,具体步骤如下:1.定义方程组的函数形式:```matlabfunction f = example_function(t, X)f(1, X) = [2*X(2) - X(3); X(1) + 2*X(3); -X(1) + X(2)];end```2.设置求解参数:```matlabtspan = [0, 10];dt = 0.01;```3.初始化解:```matlabX0 = [1; 1; 1];```4.使用四阶龙格- 库塔法求解方程组:```matlab[~, X] = ode45(@(t, X) example_function(t, X), tspan, X0, dt);```5.绘制解的曲线:```matlabplot3(X(:, 1), X(:, 2), X(:, 3));xlabel("x");ylabel("y");zlabel("z");title("四阶龙格- 库塔法求解示例");```五、总结与展望四阶龙格- 库塔法作为一种高效的数值积分方法,在MATLAB 中得到了广泛的应用。

matlab龙格库塔方法求解二元二阶常微分方程组

matlab龙格库塔方法求解二元二阶常微分方程组

matlab龙格库塔方法求解二元二阶常微分方程组文章标题:深入探讨matlab中的龙格库塔方法及其在求解二元二阶常微分方程组中的应用摘要:在科学与工程领域,常常需要求解复杂的微分方程组,而matlab作为一种强大的数学工具,提供了许多求解微分方程组的方法。

本文将深入探讨matlab中的龙格库塔方法及其在求解二元二阶常微分方程组中的应用,以便读者全面理解该方法并能灵活应用于实际问题中。

正文:一、介绍龙格库塔方法龙格-库塔法(Runge-Kutta methods)是一种数值求解常微分方程的方法,通过将微分方程的解进行离散化,将微分方程转化为差分方程,从而进行数值求解。

龙格库塔方法通过迭代计算,能够得到微分方程的数值解,广泛应用于科学计算和工程技术领域。

二、matlab中的龙格库塔方法在matlab中,龙格库塔方法通过ode45函数实现,该函数能够对一阶或高阶常微分方程进行数值求解。

用户可以通过设定初始条件、微分方程表达式,以及积分区间等参数,快速得到微分方程的数值解。

ode45函数采用自适应步长的方式进行求解,能够有效解决微分方程解的数值稳定性和精确度问题。

三、龙格库塔方法在求解二元二阶常微分方程组中的应用考虑如下形式的二元二阶常微分方程组:$$\begin{cases}y_1' = f_1(t, y_1, y_2) \\y_2' = f_2(t, y_1, y_2)\end{cases}$$其中,$y_1(t)$和$y_2(t)$是未知函数,$f_1(t, y_1, y_2)$和$f_2(t,y_1, y_2)$分别表示其对应的函数表达式。

通过matlab中的ode45函数,可以将该二元二阶常微分方程组转化为一阶常微分方程组的形式,然后利用龙格库塔方法进行数值求解。

设定初始条件$y_1(0) = y1_0, y_2(0) = y2_0$,对应的一阶方程组为:$$\begin{cases}u_1' = u_3 \\u_2' = u_4 \\u_3' = f_1(t, u_1, u_2) \\u_4' = f_2(t, u_1, u_2)\end{cases}$$其中,$u_1(t) = y_1(t), u_2(t) = y_2(t), u_3(t) = y_1'(t), u_4(t) =y_2'(t)$,通过ode45函数求解该一阶常微分方程组即可得到原二元二阶常微分方程组的数值解。

常微分方程组的四阶RungeKutta龙格库塔法matlab实现

常微分方程组的四阶RungeKutta龙格库塔法matlab实现

常微分方程组的四阶Runge-Kutta方法1.问题:1.1若用普通方法-----仅适用于两个方程组成的方程组编程实现:创建M 文件:function R = rk4(f,g,a,b,xa,ya,N)%UNTITLED2 Summary of this function goes here% Detailed explanation goes here%x'=f(t,x,y) y'=g(t,x,y)%N为迭代次数%h为步长%ya,xa为初值f=@(t,x,y)(2*x-0.02*x*y);g=@(t,x,y)(0.0002*x*y-0.8*y);h=(b-a)/N;T=zeros(1,N+1);X=zeros(1,N+1);Y=zeros(1,N+1);T=a:h:b;X(1)=xa;Y(1)=ya;for j=1:Nf1=feval(f,T(j),X(j),Y(j));g1=feval(g,T(j),X(j),Y(j));f2=feval(f,T(j)+h/2,X(j)+h/2*f1,Y(j)+g1/2);g2=feval(g,T(j)+h/2,X(j)+h/2*f1,Y(j)+h/2*g1); f3=feval(f,T(j)+h/2,X(j)+h/2*f2,Y(j)+h*g2/2); g3=feval(g,T(j)+h/2,X(j)+h/2*f2,Y(j)+h/2*g2); f4=feval(f,T(j)+h,X(j)+h*f3,Y(j)+h*g3);g4=feval(g,T(j)+h,X(j)+h*f3,Y(j)+h*g3);X(j+1)=X(j)+h*(f1+2*f2+2*f3+f4)/6;Y(j+1)=Y(j)+h*(g1+2*g2+2*g3+g4)/6;R=[T' X' Y'];end情况一:对于x0=3000,y0=120控制台中输入:>> rk4('f','g',0,10,3000,120,10)运行结果:ans =1.0e+003 *0 3.0000 0.12000.0010 2.6637 0.09260.0020 3.7120 0.07740.0030 5.5033 0.08860.0040 4.9866 0.11930.0050 3.1930 0.11950.0060 2.7665 0.09510.0070 3.6543 0.07990.0080 5.2582 0.08840.0090 4.9942 0.11570.0100 3.3541 0.1185数据:情况二:对于x0=5000,y0=100命令行中输入:>> rk4('f','g',0,10,5000,100,10)运行结果:ans =1.0e+003 *0 5.0000 0.10000.0010 4.1883 0.11440.0020 3.2978 0.10720.0030 3.3468 0.09220.0040 4.2020 0.08760.0050 4.8807 0.09950.0060 4.2090 0.11260.0070 3.3874 0.10690.0080 3.4011 0.09340.0090 4.1568 0.08890.0100 4.7753 0.0991数据:结论:无论取得初值是哪一组,捕食者与被捕食者的数量总是一个增长另一个减少,并且是以T=5 为周期交替增长或减少的。

内弹道 龙格库塔 计算 matlab

内弹道 龙格库塔 计算 matlab

内弹道是指射程较短的导弹或火箭弹在飞行过程中受到大气阻力和重力等作用的飞行轨迹。

内弹道理论研究的是导弹或火箭弹在发射后到离开大气层再进入大气层末时的飞行过程。

内弹道包括导弹或火箭弹在发射后的加速、稳定、制导、飞行以及飞行过程中的动力学性能仿真等诸多内容。

内弹道有着复杂的飞行特性和动力学方程,在实际工程中需要进行准确的计算和仿真。

内弹道的计算中,龙格库塔(Runge-Kutta)法是一种常用的数值积分方法,在求解微分方程等领域有着广泛的应用。

龙格库塔法是由数学家奥特翁格(C. W. Runge)和马丁庫塔(M. W. J. Kutta)于1900年提出的,用于求解常微分方程初值问题,其优点是精度较高,适用范围广。

在内弹道计算中,可以利用龙格库塔法对导弹或火箭弹的飞行轨迹进行数值模拟和计算,得到较为准确的飞行轨迹数据。

在实际工程中,为了方便进行内弹道的计算,可以使用Matlab等数学建模和仿真软件。

Matlab是一种常用的科学计算软件,具有强大的数值计算和仿真功能,可以用于内弹道计算中的龙格库塔法数值模拟。

在Matlab中,可以编写相应的程序,利用龙格库塔法对导弹或火箭弹的飞行过程进行仿真和计算,得到准确的飞行轨迹和动力学性能数据。

内弹道计算是导弹或火箭弹研究设计中的重要内容,龙格库塔法是一种常用的数值积分方法,Matlab是一种常用的科学计算软件,它们的应用能够有效地进行内弹道的计算和仿真,为导弹或火箭弹的研制提供重要的技术支持。

随着技术的不断发展,内弹道计算已经成为导弹或火箭弹研究设计中不可或缺的一部分。

在内弹道计算中,龙格库塔法是一种常用的数值积分方法,可以对导弹或火箭弹的飞行轨迹进行数值模拟和计算,提供准确的飞行轨迹数据。

而Matlab作为一种强大的科学计算软件,对于内弹道的计算和仿真也有着重要的应用价值。

在实际工程中,使用Matlab编写程序,利用龙格库塔法对导弹或火箭弹的飞行轨迹进行数值模拟和计算,将为导弹或火箭弹的研制提供重要的技术支持。

matlab龙格库塔法程序,给出实例

matlab龙格库塔法程序,给出实例

一、介绍龙格库塔法龙格库塔法(Runge-Kutta method)是一种数值计算方法,用于求解常微分方程的数值解。

它通过多步迭代的方式逼近微分方程的解,并且具有较高的精度和稳定性。

二、龙格库塔法的原理龙格库塔法采用迭代的方式来逼近微分方程的解。

在每一步迭代中,计算出当前时刻的斜率,然后根据这个斜率来求解下一个时刻的值。

通过多步迭代,可以得到微分方程的数值解。

三、龙格库塔法的公式龙格库塔法可以表示为以下形式:k1 = f(tn, yn)k2 = f(tn + h/2, yn + h/2 * k1)k3 = f(tn + h/2, yn + h/2 * k2)k4 = f(tn + h, yn + h * k3)yn+1 = yn + h/6 * (k1 + 2k2 + 2k3 + k4)其中,k1、k2、k3、k4为斜率,h为步长,tn为当前时刻,yn为当前时刻的解,yn+1为下一个时刻的解。

四、使用matlab实现龙格库塔法在MATLAB中,可以通过编写函数来实现龙格库塔法。

下面是一个用MATLAB实现龙格库塔法的简单例子:```matlabfunction [t, y] = runge_kutta(f, tspan, y0, h)t0 = tspan(1);tf = tspan(2);t = t0:h:tf;n = length(t);y = zeros(1, n);y(1) = y0;for i = 1:n-1k1 = f(t(i), y(i));k2 = f(t(i) + h/2, y(i) + h/2 * k1);k3 = f(t(i) + h/2, y(i) + h/2 * k2);k4 = f(t(i) + h, y(i) + h * k3);y(i+1) = y(i) + h/6 * (k1 + 2*k2 + 2*k3 + k4);endend```以上就是一个简单的MATLAB函数,可以利用该函数求解给定的微分方程。

龙格库塔方法及其matlab实现

龙格库塔方法及其matlab实现

龙格库塔方法及其matlab实现龙格-库塔方法及其matlab实现摘要:本文的目的数值求解微分方程精确解,通过龙格-库塔法,加以利用matlab为工具达到求解目的。

龙格-库塔(Runge-Kutta)方法是一种在工程上应用广泛的高精度单步算法,用于数值求解微分方程。

MatLab软件是由美国Mathworks公司推出的用于数值计算和图形处理的科学计算系统环境。

MatLab是英文MATrix LABoratory (矩阵实验室)的缩写。

在MratLab环境下,用户可以集成地进行程序设计、数值计算、图形绘制、输入输出、文件管理等各项操作。

关键词:龙格-库塔 matlab 微分方程1.前言1.1:知识背景龙格-库塔法(Runge-Kutta)是用于非线性常微分方程的解的重要的一类隐式或显式迭代法。

这些技术由数学家卡尔·龙格和马丁·威尔海姆·库塔于1900年左右发明。

通常所说的龙格库塔方法是相对四阶龙格库塔而言的,成为经典四阶龙格库塔法。

该方法具有精度高,收敛,稳定,计算过程中可以改变步长不需要计算高阶导数等优点,但是仍需计算在一些点上的值,比如四阶龙格-库塔法没计算一步需要计算四步,在实际运用中是有一定复杂性的。

Matlab是在20世纪七十年代后期的事:时任美国新墨西哥大学计算机科学系主任的Cleve Moler教授出于减轻学生编程负担的动机,为学生设计了一组调用LINPACK和EISPACK库程序的“通俗易用”的接口,此即用FORTRAN编写的萌芽状态的MATLAB。

经几年的校际流传,在Little的推动下,由Little、Moler、Steve Bangert合作,于1984年成立了MathWorks公司,并把MATLAB正式推向市场。

从这时起,MATLAB的内核采用C语言编写,而且除原有的数值计算能力外,还新增了数据图视功能。

MATLAB以商品形式出现后,仅短短几年,就以其良好的开放性和运行的可靠性,使原先控制领域里的封闭式软件包(如英国的UMIST,瑞典的LUND和SIMNON,德国的KEDDC)纷纷淘汰,而改以MATLAB为平台加以重建。

matlab 变系数微分方程 龙格库塔

matlab 变系数微分方程 龙格库塔

标题:探究matlab中的变系数微分方程及其数值解法——龙格库塔在matlab中,我们常常会遇到变系数微分方程及其数值解法的问题。

变系数微分方程是一类常见的微分方程,在实际问题中具有重要的应用价值。

而龙格库塔是一种常用的数值解法,能够有效地求解变系数微分方程,具有广泛的适用性。

1. 变系数微分方程的概念与应用变系数微分方程是指微分方程中的系数是随自变量或未知函数的变量的而变化的微分方程,通常可以表示为形式:\( \frac{d}{dx}(a(x)y') + b(x)y = f(x) \)。

这类微分方程在物理、工程和经济学等领域中具有广泛的应用,例如在电路中的电流变化、非线性振动系统的描述以及经济增长模型等方面都有相关的应用。

2. 龙格库塔法的原理和适用性龙格库塔法是一种常用的数值解法,用于求解常微分方程组及其初值问题。

与欧拉法相比,龙格库塔法能够更准确地求解微分方程,并具有更好的数值稳定性和收敛性。

具体而言,龙格库塔法通过多步逼近的方式,利用对目标函数在不同点的取值进行加权平均,得到更精确的数值解。

3. 在matlab中求解变系数微分方程的实现在matlab中,我们可以利用ode45、ode23等内置函数,或者自行编写龙格库塔法的求解程序,来求解变系数微分方程。

其中,ode45函数是matlab中最常用的求解微分方程的函数之一,它基于龙格库塔法,能够高效地求解一阶和二阶的常微分方程,并具有良好的数值稳定性和收敛性。

4. 个人观点和总结在我看来,掌握变系数微分方程及其数值解法对于理解和应用微分方程具有重要意义。

通过学习龙格库塔法,我们不仅能够更深入地理解微分方程的数值解法,还能够应用于实际问题中,解决复杂的变系数微分方程。

我建议在学习matlab时,要深入了解变系数微分方程及其数值解法,特别是龙格库塔法,这将对未来的科研和工程实践大有裨益。

在本文中,我们探讨了matlab中的变系数微分方程及其数值解法,重点介绍了龙格库塔法在求解变系数微分方程中的应用。

matlab利用四阶runge-kutta算法求解原理

matlab利用四阶runge-kutta算法求解原理

matlab利用四阶runge-kutta算法求解原理四阶Runge-Kutta(RK4)方法是一种常用的数值求解常微分方程(ODEs)的方法。

下面是RK4方法的基本原理,以及如何在MATLAB中实现:###基本原理:1.ODE表示:我们考虑形如dy/dx=f(x,y)的常微分方程,其中y是未知函数,f是给定的函数。

2.离散化:我们将x轴上的区间分成若干小步长h。

我们的目标是找到每一步上的y值。

3.四阶Runge-Kutta公式:这个方法的核心是通过四个中间步骤来逼近每一步的斜率,然后计算新的y值。

具体的步骤如下:-k1=h*f(x_n,y_n)-k2=h*f(x_n+h/2,y_n+k1/2)-k3=h*f(x_n+h/2,y_n+k2/2)-k4=h*f(x_n+h,y_n+k3)其中,x_n和y_n是当前步的x和y值,h是步长。

新的y值计算为:y_{n+1}=y_n+(k1+2*k2+2*k3+k4)/6###在MATLAB中的实现:在MATLAB中,你可以使用以下的代码来实现四阶Runge-Kutta算法:```matlabfunction[x,y]=runge_kutta_4th_order(f,x0,y0,h,x_end)x=x0:h:x_end;y=zeros(size(x));y(1)=y0;for i=1:(length(x)-1)k1=h*f(x(i),y(i));k2=h*f(x(i)+h/2,y(i)+k1/2);k3=h*f(x(i)+h/2,y(i)+k2/2);k4=h*f(x(i)+h,y(i)+k3);y(i+1)=y(i)+(k1+2*k2+2*k3+k4)/6;endend```这个函数接受一个ODE的右侧函数f,初始值x0和y0,步长h,以及求解的终点x_end。

返回的x和y包含了在给定区间内的解。

你可以调用这个函数并提供你自己的ODE右侧函数f。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

函数功能编辑本段回目录
ode是专门用于解微分方程的功能函数,他有ode23,ode45,ode23s等等,采用的是Runge-Kutta算法。

ode45表示采用四阶,五阶runge-kutta单步算法,截断误差为(Δx)³。

解决的是Nonstiff(非刚性)的常微分方程.是解决数值解问题的首选方法,若长时间没结果,应该就是刚性的,换用ode23来解.
使用方法编辑本段回目录
[T,Y] = ode45(odefun,tspan,y0)
odefun 是函数句柄,可以是函数文件名,匿名函数句柄或内联函数名
tspan 是区间[t0 tf] 或者一系列散点[t0,t1,...,tf]
y0 是初始值向量
T 返回列向量的时间点
Y 返回对应T的求解列向量
[T,Y] = ode45(odefun,tspan,y0,options)
options 是求解参数设置,可以用odeset在计算前设定误差,输出参数,事件等
[T,Y,TE,YE,IE] =ode45(odefun,tspan,y0,options)
在设置了事件参数后的对应输出
TE 事件发生时间
YE 事件解决时间
IE 事件消失时间
sol =ode45(odefun,[t0 tf],y0...)
sol 结构体输出结果
应用举例编辑本段回目录
1 求解一阶常微分方程
程序:
一阶常微分方程
odefun=@(t,y) (y+3*t)/t^2; %定义函数
tspan=[1 4]; %求解区间
y0=-2; %初值
[t,y]=ode45(odefun,tspan,y0);
plot(t,y) %作图
title('t^2y''=y+3t,y(1)=-2,1<t<4')
legend('t^2y''=y+3t')
xlabel('t')
ylabel('y')
% 精确解
% dsolve('t^2*Dy=y+3*t','y(1)=-2')
% ans =
一阶求解结果图% (3*Ei(1) - 2*exp(1))/exp(1/t) - (3*Ei(1/t))/exp(1/t)
2 求解高阶常微分方程
关键是将高阶转为一阶,odefun的书写.
F(y,y',y''...y(n-1),t)=0用变量替换,y1=y,y2=y'...注意odefun方程定义为列向量dxdy=[y(1),y(2)....]
程序:
function Testode45
tspan=[3.9 4.0]; %求解区间
y0=[2 8]; %初值
[t,x]=ode45(@odefun,tspan,y0);
plot(t,x(:,1),'-o',t,x(:,2),'-*')
legend('y1','y2')
title('y'' ''=-t*y + e^t*y'' +3sin2t')
xlabel('t')
ylabel('y')
function y=odefun(t,x)
y=zeros(2,1); % 列向量
y(1)=x(2);
y(2)=-t*x(1)+exp(t)*x(2)+3*sin(2*t);
end
end
高阶求解结果图
相关函数编辑本段回目录
ode23, ode45, ode113, ode15s, ode23s, ode23t, ode23tb
Matlab中龙格-库塔(Runge-Kutta)方法原理及实现(自己写的,非直接调用)
龙格-库塔(Runge-Kutta)方法是一种在工程上应用广泛的高精度单步算法。

由于此算法精度高,采取措施对误差进行抑制,所以其实现原理也较复杂。

该算法是构建在数学支持的基础之上的。

龙格库塔方法的理论基础来源于泰勒公式和使用斜率近似表达微分,它在积分区间多预计算出几个点的斜率,然后进行加权平均,用做下一点的依据,从而构造出了精度更高的数值积分计算方法。

如果预先求两个点的斜率就是二阶龙格库塔法,如果预先取四个点就是四阶龙格库塔法。

一阶常微分方程可以写作:y'=f(x,y),使用差分概念。

(Yn+1-Yn)/h= f(Xn,Yn)推出(近似等于,极限为Yn')
Yn+1=Yn+h*f(Xn,Yn)
另外根据微分中值定理,存在0<t<1,使得
Yn+1=Yn+h*f(Xn+th,Y(Xn+th))
这里K=f(Xn+th,Y(Xn+th))称为平均斜率,龙格库塔方法就是求得K的一种算法。

利用这样的原理,经过复杂的数学推导(过于繁琐省略),可以得出截断误差为O(h^5)的四阶龙格库塔公式:
K1=f(Xn,Yn);
K2=f(Xn+h/2,Yn+(h/2)*K1);
K3=f(Xn+h/2,Yn+(h/2)*K2);
K4=f(Xn+h,Yn+h*K3);
Yn+1=Yn+h*(K1+2K2+2K3+K4)*(1/6);
所以,为了更好更准确地把握时间关系,应自己在理解龙格库塔原理的基础上,编写定步长的龙格库塔函数,经过学习其原理,已经完成了一维的龙格库塔函数。

仔细思考之后,发现其实如果是需要解多个微分方程组,可以想象成多个微分方程并行进行求解,时间,步长都是共同的,首先把预定的初始值给每个微分方程的第一步,然后每走一步,对多个微分方程共同求解。

想通之后发现,整个过程其实很直观,只是不停的逼近计算罢了。

编写的定步长的龙格库塔计算函数:function [x,y]=runge_kutta1(ufunc,y0,h,a,b)%参数表顺序依次是微分方程组的函数名称,初始值向量,步长,时间起点,时间终点(参数形式参考了ode45函数)n=floor((b-a)/h);%求步数
x(1)=a;%时间起点
y(:,1)=y0;%赋初值,可以是向量,但是要注意维数
for ii=1:n
x(ii+1)=x(ii)+h;
k1=ufunc(x(ii),y(:,ii));
k2=ufunc(x(ii)+h/2,y(:,ii)+h*k1/2);
k3=ufunc(x(ii)+h/2,y(:,ii)+h*k2/2);
k4=ufunc(x(ii)+h,y(:,ii)+h*k3);
y(:,ii+1)=y(:,ii)+h*(k1+2*k2+2*k3+k4)/6;
%按照龙格库塔方法进行数值求解
end
调用的子函数以及其调用语句:
function dy=test_fun(x,y)
dy = zeros(3,1);%初始化列向量
dy(1) = y(2) * y(3);
dy(2) = -y(1) + y(3);
dy(3) = -0.51 * y(1) * y(2);
对该微分方程组用ode45和自编的龙格库塔函数进行比较,调用如下:
[T,F] = ode45(@test_fun,[0 15],[1 1 3]);
subplot(121)
plot(T,F)%Matlab自带的ode45函数效果
title('ode45函数效果')
[T1,F1]=runge_kutta1(@test_fun,[1 1 3],0.25,0,15);%测试时改变test_fun的函数维数,别忘记改变初始值的维数
subplot(122)
plot(T1,F1)%自编的龙格库塔函数效果
title('自编的龙格库塔函数')。

相关文档
最新文档