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

article/2025/8/29 22:21:28

作为研究生的入门课,数值计算的大作业算是所有研究生开学的重要编程作业。

    我把矩常微分初值问题用欧拉法、改进欧拉法、与四阶龙格库塔法分别在MATLAB中编程实现。具体的程序详细标注后放在文章最后了,每道题我只展示运算结果与结论,需要的同学自取。下面为作业详解

题目:给定常微分方程初值问题y,=-20*y,0<x≤1;y(0)=1;完成以下工作

1.取h=0.1和h=0.05,使用欧拉法计算,绘制出数值解和精确解图形,观察数值解的稳定性。

Euler数学原理:

   Euler方法就是用差分方程初值问题的解来近似微分方程初值问题的解,即由下面公式依次算出的近似值。这组公式求微分问题的数值解称为向前Euler公式。

图1利用欧拉法不同步长求解微分方程的数值解和原函数图像

 步长分别为0.1和0.05的欧拉法数值解与此点对应的解析解误差的绝对值如下所示

结论:根据上面图像显示,欧拉法在计算数值解的过程中,有明显误差。当h=0.1时数值解稳定性明显低于h=0.05的时候。因此步长取值越大,导致的数值解误差波动越大。为了提高欧拉法在微分方程求解的精度,应适当缩短步长

2.取h=0.1和h=0.05,使用改进欧拉法计算,绘制出数值解和精确解图形,观察数值解的稳定性。

改进欧拉法数学原理:

 利用数值积分方法将微分方程离散化时,若用梯形公式计算式中之右端积分, 即

 直观上容易看出,用梯形公式计算数值积分要比矩形公式好。梯形公式为二阶方法。 梯形公式也是隐式格式,一般需用迭代法求解,迭代公式为

 按上式计算问题的数值解时,如果每步只迭代一次,相当于将 Euler 公式 与梯形公式结合使用:先用Euler公式求yn+1的一个初步近似值y,n+1. ,称为预测值,然 后用梯形公式校正求得近似值 yn+1,即

上称为由 Euler 公式和梯形公式得到的预测—校正系统,也叫改进 Euler 法。

为便于编制程序上机,上常改写成

本问使用改进欧拉法获得的函数图像如下图所示 

图2利用改进欧拉法不同步长求解微分方程的数值解和原函数图像

 步长分别为0.1和0.05的改进欧拉法数值解与此点对应的解析解误差的绝对值如下所示

 结论:根据上面图像显示,改进欧拉法在计算数值解的过程中,在步数较大的时候仍比 步数较小误差大。但是由于算法本身为二阶精度,数值计算结果稳定性明显比普通的欧拉法更好。

3.取h=0.1和h=0.05,使用经典四阶龙格库塔法计算,绘制出数值解和精确解图形,观察数值解的稳定性

龙格库塔法数学原理:

   龙格库塔法是一类数值解微分方程的算法,其中较常见的是四阶龙格库塔法。核心思想就是通过泰勒展开式进行消元,最后使得局部截断误差为5阶,算法精度达到四阶。具体公式如下

 使用四阶龙格库塔法获得的函数图像如下图所示

图3利用四阶龙格库塔法不同步长求解微分方程的数值解和原函数图像

 步长分别为0.1和0.05的四阶龙格库塔法数值解与此点对应的解析解误差的绝对值如下所示

 结论:根据上面图像显示,四阶龙格库塔法的数值精度在原函数光滑性好的条件下精度最高(四阶)。但是依旧是步长越短,计算的误差越小。

附录:Matlab程序(主程序,欧拉法程序,改进欧拉法程序,四阶龙格库塔法程序,微分方程和原函数程序)

主程序

% Ordinary differential initial value problem
% 常微分初值问题数值解法
% 原函数的图像
h=0.01;%画图节点间距
x=[0:h:1];
k=1/h;
fx=zeros(1,k+1);
for i=1:k+1%将每一步长的x对应的解析解fy求出
fx(i)=primitive_fun(x(i));
end%使用欧拉法求解并画图[x1,y_Eu1,err_Eu1] = Euler_fun('differential_equation',0.1);
[x2,y_Eu2,err_Eu2] = Euler_fun('differential_equation',0.05);
plot(x,fx);
axis on
grid on
hold on
scatter(x1,y_Eu1,'markerfacecolor','b');
hold on
scatter(x2,y_Eu2,'markerfacecolor','r');
legend('原函数图像','h=0.1时欧拉数值解','h=0.05时欧拉数值解')
hold off%使用改进欧拉法求解并画图[x3,y_modEu1,err_modEu1] = modEu_fun('differential_equation',0.1);
[x4,y_modEu2,err_modEu2] = modEu_fun('differential_equation',0.05);
plot(x,fx);
axis on
grid on
hold on
scatter(x3,y_modEu1,'markerfacecolor','f');
hold on
scatter(x4,y_modEu2,'markerfacecolor','c');
legend('原函数图像','h=0.1时改进欧拉法数值解','h=0.05时改进欧拉法数值解')
hold off%使用=4阶Runge-Kutta法求解并画图[x5,y_RK41,err_RK41] = modEu_fun('differential_equation',0.1);
[x6,y_RK42,err_RK42] = modEu_fun('differential_equation',0.05);
plot(x,fx);
axis on
grid on
hold on
scatter(x5,y_RK41,'markerfacecolor','m');
hold on
scatter(x6,y_RK42,'markerfacecolor','k');
legend('原函数图像','h=0.1时4阶Runge-Kutta法数值解','h=0.05时4阶Runge-Kutta法数值解')
hold off

欧拉法程序

function [x,y_Eu,err] = Euler_fun(fun,h)
%使用欧拉法求解
% h为输入的步长,输出fx为原函数在步长h时所有自变量取值,y_Eu为使用欧拉法求出的数值解,err为解析解和数值解的差值绝对值
%本题x的定义域为[0,1],因此运算次数为k
k=1/h;
%建立对应步长取值的x,y向量组,fx为在取得的每个节点的解析解
fx=zeros(1,k+1);
y_Eu=zeros(1,k+1);
err=zeros(1,k+1);
x=[0:h:1];
%将每一步长的x对应的解析解fy求出for i=1:k+1fx(i)=primitive_fun(x(i));end%计算出在步长为h条件下所有数值解
y_Eu(1)=1;%赋初值x(0)=0,y(0)=1;
for i=1:kf=feval(fun,y_Eu(i));y_Eu(i+1)=y_Eu(i)+h*f;
end
%计算解析解与数值解直接的误差
for i=1:k+1err(i)=abs(y_Eu(i)-fx(i));
end
end

改进欧拉法程序

function [x,y_modEu,err] = modEu_fun(fun,h)
%使用改进欧拉法求解
% h为输入的步长,输出fx为原函数在步长h时所有自变量取值,y_Eu为使用改进欧拉法求出的数值解,err为解析解和数值解的差值绝对值
%本题x的定义域为[0,1],因此运算次数为k
k=1/h;
%建立对应步长取值的x,y向量组,fx为在取得的每个节点的解析解
fx=zeros(1,k+1);
y_modEu=zeros(1,k+1);
err=zeros(1,k+1);
x=[0:h:1];
%将每一步长的x对应的解析解fy求出for i=1:k+1fx(i)=primitive_fun(x(i));end
%计算出在步长为h条件下所有数值解
y_modEu(1)=1;%赋初值x(0)=0,y(0)=1;
for i=1:kf1=h*feval(fun,y_modEu(i));f2=h*feval(fun,y_modEu(i)+f1);y_modEu(i+1)=y_modEu(i)+0.5*(f1+f2);
end
%计算解析解与数值解直接的误差
for i=1:k+1err(i)=abs(y_modEu(i)-fx(i));
end
end

四阶龙格库塔法程序

function [x,y_RK4,err] = Ru_Ku4(fun,h)
%使用4阶Runge-Kutta法求解
% h为输入的步长,输出x为原函数在步长h时所有自变量取值,y_RK4为使用改进欧拉法求出的数值解,err为解析解和数值解的差值绝对值
%本题x的定义域为[0,1],因此运算次数为k
k=1/h;
%建立对应步长取值的x,y向量组,fx为在取得的每个节点的解析解
fx=zeros(1,k+1);
y_RK4=zeros(1,k+1);
err=zeros(1,k+1);
x=[0:h:1];
%将每一步长的x对应的解析解fy求出for i=1:k+1fx(i)=primitive_fun(x(i));end
%计算出在步长为h条件下所有数值解
y_RK4(1)=1;%赋初值x(0)=0,y(0)=1;
for i=1:kK1=h*feval(fun,y_RK4(i));K2=h*feval(fun,y_RK4(i)+K1*0.5);K3=h*feval(fun,y_RK4(i)+K2*0.5);K4=h*feval(fun,y_RK4(i)+K3);y_RK4(i+1)=y_RK4(i)+(K1+2*(K2+K3)+K4)/6;
end
%计算解析解与数值解直接的误差
for i=1:k+1err(i)=abs(y_RK4(i)-fx(i));
end
end

微分方程和原函数程序

function f= differential_equation(y)
%大作业6一直使用的微分方程
f=-20*y;
endfunction f = primitive_fun(x0)
%方程原函数
%求解此微分方程原函数
syms y(x)
eqn = diff(y,x) == -20*y;
cond = y(0) == 1;
y(x) = dsolve(eqn,cond);
f=y(x0);
end


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

相关文章

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

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

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

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

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

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

6.2 龙格—库塔法

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

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

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

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

常微分方程 Ordinary differential equation&#xff0c;简称ODE&#xff0c;自变量只有一个的微分方程。 例子1&#xff1a; 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…

经典四阶龙格库塔法

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

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

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

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

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

龙格-库塔方法学习笔记

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

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

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

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

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

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

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

龙格库塔法

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

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

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

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

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

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…