龙格库塔法求解微分方程

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

在https://blog.csdn.net/weixin_42141390/article/details/110184743一文中,我们曾经讨论了欧拉法,龙格-库塔法也跟欧拉法一样,是用梯形的面积去替代积分的面积的一种方法。

欧拉法简介

设有微分方程:
d x ( t ) d t = f ( x ) \frac{dx(t)}{dt} = f(x) dtdx(t)=f(x)
x ( t 0 ) = x 0 x(t_0)=x_0 x(t0)=x0已知。

我们对上述方程进行积分,积分区域为 [ t 0 , t 1 ] , Δ t = t 1 − t 0 [t_0,t_1],\Delta t = t_1-t_0 [t0,t1],Δt=t1t0,可得:
x ( t 1 ) = x ( t 0 ) + ∫ t 0 t 1 f ( t ) d t x(t_1)=x(t_0)+\int_{t_0}^{t_1}f(t)dt x(t1)=x(t0)+t0t1f(t)dt
其中 x ( t 1 ) x(t_1) x(t1)就是我们要求解的东西了。于是,就差积分怎么解决了。

对于欧拉法来说,积分是靠梯形面积来近似,如下所示:
∫ t 0 t 1 f ( t ) d t = f ( x ( t 0 ) ) ( t 1 − t 0 ) = f ( x 0 ) Δ t \int_{t_0}^{t_1}f(t)dt = f(x(t_0))(t_1-t_0)=f(x_0)\Delta t t0t1f(t)dt=f(x(t0))(t1t0)=f(x0)Δt
带入上述方程即可得:
x ( t 1 ) = x ( t 0 ) + f ( x 0 ) Δ t x(t_1)=x(t_0)+f(x_0)\Delta t x(t1)=x(t0)+f(x0)Δt
按照上式进行递推,即可得:
x k + 1 = x k + f ( x k ) Δ t x_{k+1} = x_{k} + f(x_{k})\Delta t xk+1=xk+f(xk)Δt
其中 x 0 x_0 x0 已知。问题就搞定了。
在这里插入图片描述

二阶龙格-库塔法

对于微分方程 d x d t = f ( x ) \frac{dx}{dt} = f(x) dtdx=f(x)
由于梯形的上底取得不合理,导致欧拉法存在一定的误差和不稳定性,于是需要对其进行改进。龙格库塔法的递推公式为:
x k = x k − 1 + Δ t ( λ 1 m 1 + λ 1 m 2 ) x_{k} = x_{k-1} + \Delta t(\lambda_{1}m_1+\lambda_1 m_2) xk=xk1+Δt(λ1m1+λ1m2)
其中: m 1 = f ( x k − 1 ) m_1 = f(x_{k-1}) m1=f(xk1) m 2 = f ( x k − 1 + m 1 ⋅ p Δ t ) m_2=f(x_{k-1}+m_1\cdot p\Delta t) m2=f(xk1+m1pΔt),且 p ⋅ λ 2 = 1 / 2 , λ 1 + λ 2 = 1 p\cdot \lambda_2 = 1/2, \lambda_1+\lambda_2=1 pλ2=1/2,λ1+λ2=1

若: p = 1 , λ 1 = 1 / 2 , λ 2 = 1 / 2 p = 1, \lambda_1=1/2, \lambda_2=1/2 p=1,λ1=1/2,λ2=1/2,则二阶龙格-库塔法等价于改进欧拉法。

高阶龙格-库塔法

我们可以对二阶龙格-库塔法进行推广,如三阶龙格-库塔法的递推公式为:
x k = x k − 1 + Δ t 6 ( m 1 + 4 m 2 + m 3 ) x_{k} = x_{k-1} + \frac{\Delta t}{6}(m_1 + 4 m_2 + m_3) xk=xk1+6Δt(m1+4m2+m3)
其中: m 1 = f ( x k − 1 ) , m 2 = f ( x k − 1 + 1 / 2 ⋅ m 1 Δ t ) , m 3 = f ( x k − 1 + ( 2 m 2 − m 1 ) Δ t ) m_1 = f(x_{k-1}), m_2 = f(x_{k-1}+1/2 \cdot m_1 \Delta t), m_3 = f(x_{k-1}+ (2m_2-m1)\Delta t) m1=f(xk1),m2=f(xk1+1/2m1Δt),m3=f(xk1+(2m2m1)Δt)

也有四阶龙格库塔法(最常用):
x k = x k − 1 + Δ t 6 ( m 1 + 2 m 2 + 2 m 3 + m 4 ) x_{k} = x_{k-1} + \frac{\Delta t}{6}(m_1 + 2 m_2 + 2 m_3+m_4) xk=xk1+6Δt(m1+2m2+2m3+m4)
其中: m 1 = f ( x k − 1 ) , m 2 = f ( x k − 1 + 1 / 2 ⋅ m 1 Δ t ) , m 3 = f ( x k − 1 + 1 / 2 ⋅ m 2 Δ t ) , m 4 = f ( x k − 1 + m 3 Δ t ) m_1 = f(x_{k-1}), m_2 = f(x_{k-1}+1/2 \cdot m_1 \Delta t), m_3 = f(x_{k-1}+ 1/2\cdot m_2 \Delta t), m_4 = f(x_{k-1}+m_3\Delta t) m1=f(xk1),m2=f(xk1+1/2m1Δt),m3=f(xk1+1/2m2Δt),m4=f(xk1+m3Δt)

就如我们在欧拉法这篇文章讲的那样,我们可以用泰勒公式来确定龙格库塔法的精确度,可以证明的是,多少阶的龙格库塔法,就有多少阶的精确度。

案例与代码

在这里插入图片描述
可见求解区域为 [0,1],我们设置求解的步数为 100,也即 Δ t = 0.01 s \Delta t = 0.01s Δt=0.01s,代码如下:

import numpy as np
import matplotlib.pyplot as plt
def f(x):return -20*x
def lgkt3(n,x0,t0,tn,f):x = [x0]t = [t0]for i in range(n):dt = (tn-t0)/ntk = t[i]+dtt.append(tk)m1 = f(x[i])*dtm2 = f(x[i]+m1*dt/2)m3 = f(x[i]+(2*m2-m1)*dt)xk = x[i]+dt/6*(m1+4*m2+m3)x.append(xk)return x,tdef lgkt4(n,x0,t0,tn,f):x = [x0]t = [t0]for i in range(n):dt = (tn-t0)/ntk = t[i]+dtt.append(tk)m1 = f(x[i])*dtm2 = f(x[i]+m1*dt/2)m3 = f(x[i]+m2*dt/2)m4 = f(x[i]+m3*dt)xk = x[i]+dt/6*(m1+2*m2+2*m3+m4)x.append(xk)return x,t        
plt.rcParams['font.sans-serif']=['SimHei']
plt.rcParams['axes.unicode_minus'] = Falsefont1 = {'family' : 'SimHei',
'weight' : 'normal',
'size'   : 15,
}def myplot2(n,x0,t0,tn,f):x1,t = lgkt3(n,x0,t0,tn,f)x2,t = lgkt4(n,x0,t0,tn,f)plt.figure(figsize=(12,4))plt.subplot(1,2,1)plt.plot(t,x1,linewidth=3,color='r',label='3阶龙格库塔法')    plt.xlabel('t',fontsize=24)plt.ylabel('x',fontsize=24)plt.legend(prop=font1)plt.grid()plt.subplot(1,2,2)plt.plot(t,x2,linewidth=3,color='b',label='4阶龙格库塔法')plt.xlabel('t',fontsize=24)plt.ylabel('x',fontsize=24)plt.legend(prop=font1)plt.grid()if __name__ == '__main__':myplot2(10,1,0,1,f)

在这里插入图片描述


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

相关文章

数值计算大作业:常微分初值问题数值解法(欧拉法、改进欧拉法、四阶龙格库塔法程序在Matlab中的实现)

作为研究生的入门课,数值计算的大作业算是所有研究生开学的重要编程作业。 我把矩常微分初值问题用欧拉法、改进欧拉法、与四阶龙格库塔法分别在MATLAB中编程实现。具体的程序详细标注后放在文章最后了,每道题我只展示运算结果与结论,需要的同…

Matlab之四阶龙格—库塔法方法:解常微分初值问题

目录 1. 题目 2. 算法原理 3. 代码 4. 结果 4.1 运行结果 4.2 结果分析 【若觉文章质量良好且有用,请别忘了点赞收藏加关注,这将是我继续分享的动力,万分感谢!】 直接通过解题的方式进行学习,代入感更强 1. 题…

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

文章目录 龙格库塔法的原理利用四阶龙格库塔法求解一个案例用MATLAB编程 龙格库塔法的原理 在百度百科中是这么解释的:在各种龙格-库塔法当中有一个方法十分常用,以至于经常被称为“RK4”或者就是“龙格-库塔法”。该方法主要是在…

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

求解初值问题 简介前期准备欧拉法改进的欧拉法龙格-库塔法标准四阶显式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…