隐式龙格库塔法举例说明

article/2025/8/29 22:17:31

隐式龙格-库塔法

  • 题目
  • 具体分析
    • 前期准备
    • 确定系数
    • MATLAB求解

题目

用隐式中点公式求解常微分方程:
{ d y d x = y , y ( 0 ) = 1. \begin{cases} \dfrac{dy}{dx}=y,\\ y(0)=1. \end{cases} dxdy=y,y(0)=1.

具体分析

前期准备

首先对和在区间上进行离散化,然后构造递推公式,再进一步得到在这些位置的近似取值。
这些离散位置可以表示为:
x 1 , x 2 , ⋯ , x n , ⋯ x_{1},x_{2},\cdots,x_{n},\cdots x1,x2,,xn,
显然, y ( x ) y(x) y(x)在这些离散的点处精确取值为:
y ( x 1 ) , y ( x 2 ) , ⋯ , y ( x n ) , ⋯ y(x_1),y(x_2),\cdots,y(x_n),\cdots y(x1),y(x2),,y(xn),
令相邻两个离散点的间隔为一定值 h h h,则有 x n = x 1 + n h ( n = 1 , 2 , ⋯ ) x_n=x_1+nh(n=1,2,\cdots) xn=x1+nh(n=1,2,),记 f ( x , y ) = y f(x,y)=y f(x,y)=y

p级隐式R-K方法(类似于龙格-库塔法的思想)
{ y n + 1 = y n + h ∑ r = 1 p λ r K r , K r = f ( x n + α r h , y n + h ∑ i = 1 p λ r i K i ) , r = 1 , 2 , ⋯ , p . \begin{cases} y_{n+1}=y_{n}+h\sum\limits_{r=1}^{p}\lambda_{r}K_{r},\\ K_{r}=f(x_n+\alpha_{r}h,y_{n}+h\sum\limits_{i=1}^{p}\lambda_{ri}K_{i}),r=1,2,\cdots,p.\\ \end{cases} yn+1=yn+hr=1pλrKr,Kr=f(xn+αrh,yn+hi=1pλriKi),r=1,2,,p.
我们可利用 T a y l o r Taylor Taylor展开确定系数。(下面以r=1为例)

确定系数

{ y n + 1 = y n + h λ K , ( 1 ) K = f ( x n + α h , y n + h λ ∗ K ) . ( 2 ) \begin{cases} y_{n+1}=y_{n}+h\lambda K,&(1)\\ K=f(x_n+\alpha h,y_{n}+h\lambda_{*}K).&(2)\\ \end{cases} {yn+1=yn+hλK,K=f(xn+αh,yn+hλK).(1)(2)
首先,我们对二式中对 f f f x n x_n xn T a y l o r Taylor Taylor展开,得:
K = f ( x n , y n ) + f x ( x n , y n ) α h + f y ( x n , y n ) h λ ∗ K + o ( h 2 ) K=f(x_n,y_n)+f_x(x_n,y_n)\alpha h+f_y(x_n,y_n)h\lambda_{*}K+o(h^2) K=f(xn,yn)+fx(xn,yn)αh+fy(xn,yn)hλK+o(h2)
解出 K = f ( x n , y n ) + f x ( x n , y n ) α h 1 − f y ( x n , y n ) h λ ∗ K=\frac{f(x_n,y_n)+f_x(x_n,y_n)\alpha h}{1-f_y(x_n,y_n)h\lambda_{*}} K=1fy(xn,yn)hλf(xn,yn)+fx(xn,yn)αh
代入(1)式得:
y n + 1 = y n + h λ f ( x n , y n ) + f x ( x n , y n ) α h 1 − f y ( x n , y n ) h λ ∗ y_{n+1}=y_{n}+h\lambda\frac{f(x_n,y_n)+f_x(x_n,y_n)\alpha h}{1-f_y(x_n,y_n)h\lambda_{*}} yn+1=yn+hλ1fy(xn,yn)hλf(xn,yn)+fx(xn,yn)αh
y ( x n + 1 ) y(x_{n+1}) y(xn+1) x n x_n xn T a y l o r Taylor Taylor展开进行比较:
y ( x n + 1 ) = y ( x n ) + h 1 ! y ′ ( x n ) + h 2 2 ! y ′ ′ ( x n ) + ⋯ y(x_{n+1})=y(x_n)+\frac{h}{1!}y^{'}(x_n)+\frac{h^2}{2!}y^{''}(x_n)+\cdots y(xn+1)=y(xn)+1!hy(xn)+2!h2y(xn)+
得到:
h λ f ( x n , y n ) + f x ( x n , y n ) α h 1 − f y ( x n , y n ) h λ ∗ ≈ h 1 ! y ′ ( x n ) + h 2 2 ! y ′ ′ ( x n ) h\lambda\frac{f(x_n,y_n)+f_x(x_n,y_n)\alpha h}{1-f_y(x_n,y_n)h\lambda_{*}}\approx\frac{h}{1!}y^{'}(x_n)+\frac{h^2}{2!}y^{''}(x_n) hλ1fy(xn,yn)hλf(xn,yn)+fx(xn,yn)αh1!hy(xn)+2!h2y(xn)
即:
λ f ( x n , y n ) + f x ( x n , y n ) α h 1 − f y ( x n , y n ) h λ ∗ ≈ f ( x n , y n ) + h 2 [ f x ( x n , y n ) + f y ( x n , y n ) f ( x n , y n ) ] \lambda\frac{f(x_n,y_n)+f_x(x_n,y_n)\alpha h}{1-f_y(x_n,y_n)h\lambda_{*}}\approx f(x_n,y_n)+\frac{h}{2}[f_x(x_n,y_n)+f_y(x_n,y_n)f(x_n,y_n)] λ1fy(xn,yn)hλf(xn,yn)+fx(xn,yn)αhf(xn,yn)+2h[fx(xn,yn)+fy(xn,yn)f(xn,yn)]
简记为:
λ f + f x α h 1 − f y h λ ∗ ≈ f + h 2 ( f x + f y f ) \lambda\frac{f+f_x\alpha h}{1-f_y h\lambda_{*}}\approx f+\frac{h}{2}(f_x+f_y f) λ1fyhλf+fxαhf+2h(fx+fyf)
化简得:
λ f + λ f x α h = f − f f y h λ ∗ + 1 2 h f x + 1 2 h f y f \lambda f+\lambda f_x\alpha h=f-ff_y h \lambda_{*}+\frac{1}{2}h f_x+\frac{1}{2}h f_y f λf+λfxαh=fffyhλ+21hfx+21hfyf
解得:
λ = 1 , λ ∗ = 1 2 , α = 1 2 . \lambda=1,\lambda_{*}=\frac{1}{2},\alpha=\frac{1}{2}. λ=1,λ=21,α=21.
从而得到隐式中点公式:
{ y n + 1 = y n + h K , ( 1 ) K = f ( x n + 1 2 h , y n + 1 2 h K ) . ( 2 ) \begin{cases} y_{n+1}=y_{n}+h K,&(1)\\ K=f(x_n+\frac{1}{2} h,y_{n}+\frac{1}{2}h K).&(2)\\ \end{cases} {yn+1=yn+hK,K=f(xn+21h,yn+21hK).(1)(2)

MATLAB求解

% Implicit kutta
clear all,close all,clc
f=@(x,y)y;
N=10;h=1/N;
x=linspace(0,1,N+1);
y=[1,zeros(1,N)];
K=randn(1);
for n=1:NK=f(x(n)+1/2*h,y(n)+1/2*h*K);y(n+1)=y(n)+h*K;
end
y_exact=@(x)exp(x);
plot(x,y_exact(x),'-b',x,y,'*r')
axis([0 1 0.9 3.5]),xlabel x,ylabel y
legend('Exact','ImKutta')
error=y_exact(x)-y;

在这里插入图片描述


http://chatgpt.dhexx.cn/article/4GhbBdQu.shtml

相关文章

龙格库塔法求解微分方程

在https://blog.csdn.net/weixin_42141390/article/details/110184743一文中,我们曾经讨论了欧拉法,龙格-库塔法也跟欧拉法一样,是用梯形的面积去替代积分的面积的一种方法。 欧拉法简介 设有微分方程: d x ( t ) d t f ( x )…

数值计算大作业:常微分初值问题数值解法(欧拉法、改进欧拉法、四阶龙格库塔法程序在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