龙格库塔方法的原理和案例及MTATLAB编程

article/2025/8/29 22:25:24

文章目录

  • 龙格库塔法的原理
  • 利用四阶龙格库塔法求解一个案例
  • 用MATLAB编程

龙格库塔法的原理

 在百度百科中是这么解释的:在各种龙格-库塔法当中有一个方法十分常用,以至于经常被称为“RK4”或者就是“龙格-库塔法”。该方法主要是在已知方程导数和初值信息,利用计算机仿真时应用,省去求解微分方程的复杂过程。

令初值问题表述如下。
y ′ = f ( x n , y n ) , y ( x 0 ) = y 0 y^{\prime}= f(x_n,y_n),y(x_0)=y_0 y=f(xn,yn)y(x0)=y0
 则,对于该问题的RK4由如下方程给出:
y n + 1 = y n + h 6 ( k 1 + 2 k 2 + 2 k 3 + k 4 ) y_{n+1}=y_n+\frac h 6(k_1+2k_2+2k_3+k_4) yn+1=yn+6h(k1+2k2+2k3+k4)
 其中,
k 1 = f ( x n , y n ) k_1= f(x_n,y_n) k1=f(xn,yn)
k 2 = f ( x n + h 2 , y n + h 2 k 1 ) k_2= f(x_n+{h\over2},y_n+{h\over2}k_1) k2=f(xn+2h,yn+2hk1)
k 3 = f ( x n + h 2 , y n + h 2 k 2 ) k_3= f(x_n+{h\over2},y_n+{h\over2}k_2) k3=f(xn+2h,yn+2hk2)
k 4 = f ( x n + h , y n + h k 3 ) k_4= f(x_n+h,y_n+hk_3) k4=f(xn+h,yn+hk3)
 我开始在理解的时候花了挺长时间,毕竟公式很难让人理解,因此我才想把我遇到的困难和理解写下来,帮助大家理解龙格库塔这个方法。
 在我看来龙格库塔方法就是改良之后的欧拉法,求解精度更高。就是用已知点和所求点这两个点之间几个点的斜率,加权平均后得出的斜率就为所求点与已知点的斜率。
在这里插入图片描述
 上图就是我所举的例子,事实上我们只知晓 y ′ y^{\prime} y,即 k 1 k_1 k1, k 2 k_2 k2, k 3 k_3 k3, k 4 k_4 k4,以及 y 0 y_0 y0。这样我们就可以通过四阶龙格库塔方法进行不断迭代,求出 y 1 , y 2 … y n y_1,y_2 \dots y_n y1,y2yn

利用四阶龙格库塔法求解一个案例

  如 y ′ = x + x y y^{\prime}=x+xy y=x+xy这样一个表达式,我们若用正常的数学方法求解或许并不困难。但是一旦表达式变得很复杂, 例如 y ′ = sin ⁡ ( x ) cos ⁡ ( y ) + x y y^{\prime}=\sin(x)\cos(y)+xy y=sin(x)cos(y)+xy这样的微分方程,求解起来就会相当麻烦。因此利用龙格库塔法求解,会使问题变得较简单方便。一般我们使用四阶龙格库塔方程解决问题,这样求解的精度较高,且求解速度较快。
  我们举 y = x + x y y=x+xy y=x+xy这样一个简单的微分方程来说明一下,由于 y ′ = f ( x , y ) y^{\prime}=f(x,y) y=f(x,y),因此 f ( x , y ) = d y d x = x + x y f(x,y)={dy \over dx}=x+xy f(x,y)=dxdy=x+xy,我们需要知道 y ( x 0 ) = y 0 y(x_0)=y_0 y(x0)=y0为多少,在此案例中,我们设 x 0 = 0 x_0=0 x0=0, y ( 0 ) = y 0 = 0 y(0)=y_0=0 y(0)=y0=0,我们设步长 h = 0.1 h=0.1 h=0.1,计算公式如下所示:
k 1 = f ( x 0 , y 0 ) = f ( 0 , 0 ) = 0 + 0 = 0 k_1= f(x_0,y_0)=f(0,0)=0+0=0 k1=f(x0,y0)=f(0,0)=0+0=0

k 2 = f ( x 0 + h 2 , y 0 + k 1 × h 2 ) = f ( 0 + 0.05 , 0 + 0 × 0.05 ) = 0.05 + 0 = 0.05 k_2= f(x_0+\frac h 2,y_0+ k_1 \times{h \over 2})=f(0+0.05,0+0\times0.05)=0.05+0=0.05 k2=f(x0+2h,y0+k1×2h)=f(0+0.05,0+0×0.05)=0.05+0=0.05

k 3 = f ( x 0 + h 2 , y 0 + k 2 × h 2 ) = f ( 0 + 0.05 , 0 + 0.05 × 0.05 ) = 0.05 + 0.05 × 0.0025 = 0.050125 k_3= f(x_0+\frac h 2,y_0+k_2\times{h \over 2})=f(0+0.05,0+0.05\times0.05)=0.05+0.05\times0.0025=0.050125 k3=f(x0+2h,y0+k2×2h)=f(0+0.05,0+0.05×0.05)=0.05+0.05×0.0025=0.050125
k 4 = f ( x 0 + h 2 , y 0 + k 3 × h 2 ) = f ( 0 + 0.1 , 0 + 0.050125 × 0.1 ) = 0.1 + 0.1 × 0.050125 = 0.10050125 k_4= f(x_0+\frac h 2,y_0+k_3\times{h \over 2})=f(0+0.1,0+0.050125\times0.1)=0.1+0.1\times0.050125=0.10050125 k4=f(x0+2h,y0+k3×2h)=f(0+0.1,0+0.050125×0.1)=0.1+0.1×0.050125=0.10050125
y 1 = y 0 + h 6 ( k 1 + 2 k 2 + 2 k 3 + k 4 ) ≈ 0 + 0.1 6 × 0.3008 = 0.0050 y_1=y_0+\frac h 6(k_1+2k_2+2k_3+k_4)\approx0+\frac {0.1}{6} \times 0.3008= 0.0050 y1=y0+6h(k1+2k2+2k3+k4)0+60.1×0.3008=0.0050
  到此我们已经求出 y 1 = 0.0050 y_1= 0.0050 y1=0.0050,就可把 y 1 y_1 y1带入下一步继续迭代,可是有的同学就会问 x 1 x_1 x1等于多少,由于我们设的步长 h = 0.1 h=0.1 h=0.1,因此 x 1 = x 0 + h = 0.1 x_1=x_0+h=0.1 x1=x0+h=0.1,扩展后则为 x n = x 0 + n h x_n=x_0+nh xn=x0+nh
 我们需要验通过四阶龙格库塔法求解的值准不准确,因此我们用经典的微分方程解法去求解,求解过程如下:
y ′ = d y d x = x + x y y^{\prime}=\frac {dy}{dx}=x+xy y=dxdy=x+xy
d y d x = x ( 1 + y ) \frac {dy}{dx}=x(1+y) dxdy=x(1+y)
d y 1 + y = x d x \frac {dy}{1+y}=xdx 1+ydy=xdx
 两边同时积分
ln ⁡ ( 1 + y ) = 1 2 x 2 + C \ln{(1+y)}={1\over 2}x^2+C ln(1+y)=21x2+C
y = e 1 2 x 2 + C y=e^{{1\over 2}x^2}+C y=e21x2+C
 我们设 x 0 = 0 x_0=0 x0=0时, y 0 = 0 y_0=0 y0=0,因此 C = − 1 C=-1 C=1,即 y = e 1 2 x 2 − 1 y=e^{{1\over 2}x^2}-1 y=e21x21,当 x 1 = 0.1 x_1=0.1 x1=0.1时, y 1 = 0.0050 y_1=0.0050 y1=0.0050。验证后我们发现四阶龙格库塔法的精确度确实很高。

用MATLAB编程

clc,clear;
syms x y %设置符号变量x,y
f(x,y)=x*y+x;
z(x)=exp(1/2*x^2)-1%我们计算得出的方程,用于验算
df=f;
y0=0;%设y0=0
a=0;%设起始点
b=3;%设终点
h=0.1;%设步长
[x1,y1]=FourLongkuta(df,y0,a,b,h);%用四阶龙格库塔法求解
figure
plot(a:h:b,z(a:h:b))
hold on
plot(a:h:b,y1,'r')
legend('原函数','龙格库塔法')
hold off

 下面是四阶龙格库塔方法的函数:

function [x1,y1]=FourLongkuta(df,y0,a,b,h)%从左到右依次为已知的导函数,初始函数值,初始横坐标值,终止横坐标值,步长
n=floor((b-a)/h);%求解所需的总步长,floor的用法是取一个小数的最小整数值
y1(1)=y0;%赋值y1(1)=y(t0),且数为双精度,这样以后计算的符号值都会转换成双精度
x1=a:h:b;%设xn的值
for i=1:n%龙格库塔方法进行数值求值      k1=double (df( x1(i),y1(i) ) ) ;%double将符号值转为双精度值可以提高运算速度k2=double (df( x1(i)+h/2,y1(i)+k1*h/2 ) );k3=double (df( x1(i)+h/2,y1(i)+k2*h/2 ) );k4=double (df( x1(i)+h,y1(i)+k3*h ) );y1(i+1)=y1(i)+h*(k1+2*k2+2*k3+k4)/6;   
end
end

四阶龙格库塔法
 由图可以看到四阶龙格库塔法的精度很高,几乎覆盖在原函数上。
 创作不易,请大家多多支持!


http://chatgpt.dhexx.cn/article/abvIi9xG.shtml

相关文章

欧拉法、改进的欧拉法、龙格-库塔法求解初值问题

求解初值问题 简介前期准备欧拉法改进的欧拉法龙格-库塔法标准四阶显式Kutta公式三级三阶显式公式四级四阶显式Kutta公式四级四阶显式Gill公式 示例MATLAB代码结果 简介 通过求解简单的初值问题: { d u d x f ( x , u ) ( 1 ) u ( x 0 ) u 0 ( 2 ) \begin{cases…

6.2 龙格—库塔法

学习目标: 学习龙格-库塔法的具体明确的学习目标可以有以下几点: 理解龙格-库塔法的基本思想和原理:我们应该了解龙格-库塔法的数值求解思想和数值误差的概念,包括截断误差和稳定性等基本概念,并且要熟悉龙格-库塔法的…

四阶龙格库塔法求解一次常微分方程组(python实现)

四阶龙格库塔法求解一次常微分方程组 一、前言二、RK4求解方程组的要点1. 将方程组转化为RK4求解要求的标准形式2. 注意区分每个方程的独立性 三、python实现RK4求解一次常微分方程组1. 使用的方程组2. python代码3. 运行结果 一、前言 之前在博客发布了关于使用四阶龙格库塔方…

四阶龙格库塔算法及matlab代码

常微分方程 Ordinary differential equation,简称ODE,自变量只有一个的微分方程。 例子1: d y d x f ( x , y ) \dfrac {dy} {dx}f(x,y) dxdy​f(x,y) , f ( x , y ) f(x,y) f(x,y)是已知函数 偏微分方程 Partial differential equation…

经典四阶龙格库塔法

关注微信公众号“二进制小站”~~获取更多分析~~(文末二维码~~) 龙格-库塔(Runge-Kutta)方法是一种在工程上应用广泛的高精度单步算法,经常被称为“RK4”或者就是“龙格库塔法”。 令初值问题表述如下。 对于该问题的RK4由如下方程给出: 其中&…

四阶龙格库塔法(Runge-Kutta)求解常微分方程的 Matlab程序及案例

文章目录 1. 算法2. 程序3. 案例4. 联系作者 1. 算法 上一篇介绍了显式欧拉法、隐式欧拉法、两步欧拉法和改进欧拉法求解常微分方程初值问题;其中显式欧拉法和隐式欧拉法是一阶算法精度,截断误差为 O ( h 2 ) O\left( {{h^2}} \right) O(h2)&#xff1b…

【Runge-Kutta】龙格-库塔法求解微分方程matlab仿真

1.软件版本 MATLAB2013b 2.算法理论 龙格-库塔法(Runge-Kutta)是用于模拟常微分方程的解的重要的一类隐式或显式迭代法。龙格库塔法的家族中的一个成员如此常用,以至于经常被称为“RK4”或者就是“龙格库塔法”。令初值问题表述…

龙格-库塔方法学习笔记

1、龙格-库塔法简介 龙格—库塔法是一种在工程上应用广泛的高精度单步算法,其中包括著名的欧拉法,用于数值求解微分方程。 由于此算法精度高,采取措施对误差进行抑制,所以其实现原理也较复杂。 在各种龙格—库塔法当中有一个方法十…

四阶龙格库塔法的计算例子

序 没有对比就没有伤害,本文先给出很多时候直接采用的矩形法,然后与四阶龙格库塔法做比较,着重说明四阶龙格库塔法。 一、矩形法 1.1 原理 设微分方程 y ˙ f ( y ) (1.1) \dot yf(y) \tag{1.1} y˙​f(y)(1.1) 求 y y y。 使用数值方法…

龙格-库塔法(Runge-Kutta methods)

非线性的常微分方程通常是难以求出解析解的,只能通过多次迭代求近似的数值解。 龙格-库塔法(Runge-Kutta methods)是用于非线性常微分方程的解的重要的一类隐式或显式迭代法。简写做RK法。 对于任意的Yf(X),假设某点(Xi,Yi)的斜…

龙格-库塔(Runge-Kutta)方法C++实现

龙格-库塔(Runge-Kutta)方法是一种在工程上应用广泛的高精度单步算法。由于此算法精度高,采取措施对误差进行抑制,所以其实现原理也较复杂。该算法是构建在数学支持的基础之上的。 1 中点法 2传统二阶龙格库塔法: 3 传统三阶龙格库塔法 4 传…

龙格库塔法

1 基本思想 我们求解常微分方程的时候,某些常微分方程有解析方法,但是大多数的常微分方程只能用数值解法来求解。 数值解法的一个基本特点就是“递进式”,顺着节点的顺序一步一步向前推进。 龙格库塔法的基本思想就是利用f(x,y)在某些特殊点…

关于html中文字空格以及换行符的处理

在阮一峰大神的博客中发现空格原来可以有多种处理方式,过去只知道用$nbsp;真是惭愧。长路漫漫吖 目录 1、html里面的空格2、怎样原样显示空格和换行符2.1 使用pre标签2.2 使用white-space设置样式 3、参考链接 1、html里面的空格 在html里面,空格和换行符…

html5中如何取消换行,html5换行符元素: 元素

1. 基本概念 html5中的元素用于产生一个换行符,它的名称br正是单词break的前两个字母;break本身的含义为“打破、拆分”,在此处就引申为换行的意思。 为什么html5要专门定义一个元素来代表换行符呢?我们平常在办公软件中编辑文本的…

linux换行符 r,\r \n 回车换行符详解

\r \n 回车换行符详解 \r \n 回车换行符详解 \r \n 回车换行符详解1. \r \n 回车换行的含义1.1 \r 回车 1.2 \n 换行 2. \r \n 回车换行的历史2.1 \r \n 回车换行的历史 2.2 发展:linux 和 windows的不同 参考: 1.1 \r 回车 回车 CR (carriage return) 含义:return oldline …

html文本换行符

2019独角兽企业重金招聘Python工程师标准>>> p的样式&#xff1a;white-space:pre;或者white-space:pre-wrap;或者white-space:pre-line; <p> abcdef </p> 转载于:https://my.oschina.net/u/3407699/blog/1829940

在html中js如何给字符串中加换行符

var str 如果有一天休息休息下cvcvx,"\n" 那么&#xff5e;&#xff5e;&#xff5e;; 这种写法在html中是会被识别为"如果有一天休息休息下cvcvx,\n 那么&#xff5e;&#xff5e;&#xff5e;" 那么如何保证其这么写会被识别&#xff0c;只需要在该d…

linux cr换行符,回车符CR和换行符LF

我在Windows电脑上做开发时,经常会见到这个现象。代码从远程git仓库clone下来后,然后npm install安装依赖后,打开任意一个代码文件会看到每行结尾处有如下报红: 将鼠标指针停留在行尾报红处,会浮出如下提示: Expected linebreaks to be LF but found CRLF.eslint(linebre…

文本文件换行符

文本文件的每一行结尾用一个或者两个特殊的ASCII字符进行标识&#xff0c;这个标识就是换行符&#xff0c;不同的操作系统中会采用不同的换行符。 1.CR、LF、CRLF 主要的换行符有三种&#xff1a;LF&#xff08;Line Feed即换行&#xff0c;转义字符用“\n”表示&#xff0c;十…

html语言中的换行标签是,什么是换行符标签

HTML语言中换行的代码是什么&#xff1f; 方法有很多&#xff0c;但要做到用的恰到好处 段落标签 一个段落空一行 效果如下&#xff1a; 是默认的换行&#xff0c;在你要换行的地方加进去就行&#xff0c;单个标签 效果如下&#xff1a; 如果有了 ……&#xff0c;从到中的内容…