微分方程数值解法

合集下载

微分方程与数值解法的综述

微分方程与数值解法的综述

微分方程与数值解法的综述微分方程是数学中的一门重要分支,它描述了物理、工程和自然现象中的变化规律。

然而,许多微分方程往往无法通过解析方法得到解析解,这就需要借助数值解法来近似求解。

本文将从微分方程的基本概念入手,介绍常见的数值解法,并探讨其应用领域和优缺点。

一、微分方程的基本概念微分方程是描述函数和它的导数之间关系的方程。

根据方程中出现的未知函数的最高阶导数的阶数,微分方程可分为常微分方程和偏微分方程。

常微分方程中的未知函数只涉及一个自变量,而偏微分方程中的未知函数涉及多个自变量。

在常微分方程中,我们常常遇到一阶和二阶微分方程。

一阶微分方程的一般形式为dy/dx = f(x, y),其中y是未知函数,f(x, y)是已知函数。

二阶微分方程的一般形式为d^2y/dx^2 = f(x, y, dy/dx),其中y是未知函数,f(x, y, dy/dx)是已知函数。

二、数值解法的基本思想数值解法是一种近似求解微分方程的方法。

其基本思想是将微分方程转化为差分方程,并在离散的点上求解差分方程。

数值解法的精度和稳定性是评价其优劣的主要标准。

常见的数值解法包括欧拉法、改进的欧拉法、龙格-库塔法等。

欧拉法是最简单的一种数值解法,它通过将微分方程中的导数用差商来近似,从而得到差分方程。

改进的欧拉法通过在欧拉法的基础上引入更高阶的差商,提高了数值解的精度。

龙格-库塔法是一类经典的数值解法,通过计算多个差分方程的加权平均值来逼近微分方程的解。

三、数值解法的应用领域数值解法在科学计算中有着广泛的应用。

它在物理学、工程学、经济学等领域中发挥着重要作用。

在物理学中,微分方程广泛应用于描述运动、波动、电磁场等自然现象。

利用数值解法可以求解这些微分方程,从而得到物理系统的演化规律。

在工程学中,微分方程常用于建模和仿真。

例如,通过求解热传导方程可以分析材料的热传导性能,从而指导工程设计和优化。

在经济学中,微分方程常用于描述经济系统的动态演化。

微分方程的数值解法

微分方程的数值解法

微分方程的数值解法微分方程是自然科学和现代技术领域中一种最基本的数学描述工具,它可以描述物理世界中的各种现象。

微分方程的解析解往往很难求出,因此数值解法成为解决微分方程问题的主要手段之一。

本文将介绍几种常见的微分方程的数值解法。

一、欧拉法欧拉法是微分方程初值问题的最简单的数值方法之一,它是由欧拉提出的。

考虑一阶常微分方程:$y'=f(t,y),y(t_0)=y_0$其中,$f(t,y)$表示$y$对$t$的导数,则$y(t_{i+1})=y(t_i)+hf(t_i,y_i)$其中,$h$为步长,$t_i=t_0+ih$,$y_i$是$y(t_i)$的近似值。

欧拉法的精度较低,误差随着步长的增加而增大,因此不适用于求解精度要求较高的问题。

二、改进欧拉法改进欧拉法又称为Heun方法,它是由Heun提出的。

改进欧拉法是在欧拉法的基础上进行的改进,它在每个步长内提高求解精度。

改进欧拉法的步骤如下:1. 根据当前$t_i$和$y_i$估算$y_{i+1}$:$y^*=y_i+hf(t_i,y_i),t^*=t_i+h$2. 利用$y^*$和$t^*$估算$f(t^*,y^*)$:$f^*=f(t^*,y^*)$3. 利用$y_i$、$f(t_i,y_i)$和$f^*$估算$y_{i+1}$:$y_{i+1}=y_i+\frac{h}{2}(f(t_i,y_i)+f^*)$改进欧拉法具有比欧拉法更高的精度,但是相较于其他更高精度的数值方法,它的精度仍然较低。

三、龙格-库塔法龙格-库塔法是一种广泛使用的高精度数值方法,它不仅能够求解一阶和二阶常微分方程,还能够求解高阶常微分方程和偏微分方程。

其中,经典的四阶龙格-库塔法是最常用的数值方法之一。

四阶龙格-库塔法的步骤如下:1. 根据当前$t_i$和$y_i$估算$k_1$:$k_1=f(t_i,y_i)$2. 根据$k_1$和$y_i$估算$k_2$:$k_2=f(t_i+\frac{h}{2},y_i+\frac{h}{2}k_1)$3. 根据$k_2$和$y_i$估算$k_3$:$k_3=f(t_i+\frac{h}{2},y_i+\frac{h}{2}k_2)$4. 根据$k_3$和$y_i$估算$k_4$:$k_4=f(t_i+h,y_i+hk_3)$5. 根据$k_1$、$k_2$、$k_3$和$k_4$计算$y_{i+1}$:$y_{i+1}=y_i+\frac{h}{6}(k_1+2k_2+2k_3+k_4)$龙格-库塔法的精度较高,在求解一些对精度要求较高的问题时,龙格-库塔法是一个比较好的选择。

微分方程数值解法

微分方程数值解法

微分方程数值解法
微分方程是天文学、力学、电磁学等领域很重要的概念,这些领域的研究需要利用到微分
方程的数值解法去求解。

微分方程数值解法是一种将数学模型转换成计算机可以计算的过程,也就是将复杂的问题表达成一组导数和数值,然后利用计算机把这些数值分析和解决
出来。

微分方程数值解法的基本原理是通过二阶多项式的拟合,得出最优的近似解,这种解法是
在一维常微分方程组上应用的,由多个单个微分方程构成,所计算出来的值是多项式函数,这就是微分方程数值解法计算出来的结果。

微分方程数值解法有很多,其中最常用的有有限差分法、有限体积法、有限元法、网格化法、积分中心方法等。

有限差分方法是将问题分解成若干小的结点,然后把微分方程分割
成若干子部分,再做到多次离散估算的过程,最后可以得出拟合函数的解;有限体积方法
是通过将物理风险划分成多个单元,再用均匀的离散步长取点,最后以数值积分法解决微
分方程;有限元方法是利用有限元积分理论,将物理场定义在离散网格中,再利用数学技巧,得出最终的近似解;网格化法是把问题的空间划分成若干小的子空间,再基于某些准则利用焦点或者双精度网格单元,得出空间的分段函数;积分中心方法是把微分方程的方程组再利用积分解析的方法去求解,其中采用了梯形法或者抛物线法等数值积分方法。

最后,无论是那种方法,它们都将在一个规定的步长内对问题做出最有系统、最准确的近
似解,并且它们之间都具有某种交互性,当使用有限元方法可以基于积分中心法得出近似解,而积分中心法又可以基于有限差分方法进行改进,因此在实际领域,结合不同的数值
解法才能更好的满足需求。

微分方程的数值解法与近似求解技巧

微分方程的数值解法与近似求解技巧

微分方程的数值解法与近似求解技巧微分方程是数学中的重要概念,广泛应用于物理、工程、经济等领域。

在实际问题中,我们常常遇到无法直接求解的微分方程,这时候就需要借助数值解法和近似求解技巧来解决。

本文将介绍微分方程的数值解法和近似求解技巧,帮助读者更好地理解和应用这些方法。

一、数值解法1. 欧拉法欧拉法是最基础的数值解法之一,通过离散化微分方程,将其转化为差分方程,从而得到近似解。

欧拉法的基本思想是将微分方程中的导数用差商代替,然后通过迭代逼近真实解。

以一阶常微分方程为例,欧拉法的迭代公式如下:\[y_{n+1} = y_n + hf(x_n, y_n)\]其中,\(y_n\)表示第n个点的近似解,\(x_n\)表示对应的自变量的取值,h为步长,\(f(x_n, y_n)\)表示微分方程中的导数。

2. 改进的欧拉法改进的欧拉法是对欧拉法的改进,通过使用两个近似解的平均值来计算下一个点的近似解,从而提高了数值解的精度。

改进的欧拉法的迭代公式如下:\[y_{n+1} = y_n + \frac{h}{2}(f(x_n, y_n) + f(x_{n+1}, y_n + hf(x_n, y_n)))\]3. 二阶龙格-库塔法龙格-库塔法是一种常用的数值解法,通过计算多个近似解的加权平均值来提高数值解的精度。

其中,二阶龙格-库塔法是最简单的一种。

二阶龙格-库塔法的迭代公式如下:\[k_1 = hf(x_n, y_n)\]\[k_2 = hf(x_n + \frac{h}{2}, y_n + \frac{k_1}{2})\]\[y_{n+1} = y_n + k_2\]二、近似求解技巧1. 线性化方法线性化方法是一种常用的近似求解技巧,通过将非线性微分方程线性化,然后使用线性方程的求解方法来得到近似解。

以二阶线性微分方程为例,线性化方法的基本思想是将非线性项进行线性化处理,然后使用线性微分方程的求解方法来得到近似解。

微分方程的数值解法

微分方程的数值解法

微分方程的数值解法微分方程是描述自然界中众多现象和规律的重要数学工具。

然而,许多微分方程是很难或者无法直接求解的,因此需要使用数值解法来近似求解。

本文将介绍几种常见的微分方程数值解法。

1. 欧拉方法欧拉方法是最简单的数值解法之一。

它将微分方程转化为差分方程,通过计算离散点上的导数来逼近原方程的解。

欧拉方法的基本思想是利用当前点的导数值来估计下一个点的函数值。

具体步骤如下:首先,将自变量区间等分为一系列的小区间。

然后,根据微分方程的初始条件,在起始点确定初始函数值。

接下来,根据导数的定义,计算每个小区间上函数值的斜率。

最后,根据初始函数值和斜率,递推计算得到每个小区间上的函数值。

2. 龙格-库塔方法龙格-库塔方法是一种常用的高阶精度数值解法。

它通过进行多次逼近和修正来提高近似解的准确性。

相比于欧拉方法,龙格-库塔方法在同样的步长下可以获得更精确的解。

具体步骤如下:首先,确定在每个小区间上的步长。

然后,根据微分方程的初始条件,在起始点确定初始函数值。

接下来,根据当前点的导数值,使用权重系数计算多个中间点的函数值。

最后,根据所有中间点的函数值,计算出当前点的函数值。

3. 改进欧拉方法(改进的欧拉-克罗默法)改进欧拉方法是一种中阶精度数值解法,介于欧拉方法和龙格-库塔方法之间。

它通过使用两公式递推来提高精度,并减少计算量。

改进欧拉方法相对于欧拉方法而言,增加了一个估计项,从而减小了局部截断误差。

具体步骤如下:首先,确定在每个小区间上的步长。

然后,根据微分方程的初始条件,在起始点确定初始函数值。

接下来,利用欧拉方法计算出中间点的函数值。

最后,利用中间点的函数值和斜率,计算出当前点的函数值。

总结:微分方程的数值解法为我们研究和解决实际问题提供了有力的工具。

本文介绍了欧拉方法、龙格-库塔方法和改进欧拉方法这几种常见的数值解法。

选择合适的数值解法取决于微分方程的性质以及对解的精确性要求。

在实际应用中,我们应该根据具体情况选择最合适的数值解法,并注意控制步长以尽可能减小误差。

数值积分与微分方程数值解法

数值积分与微分方程数值解法

数值积分与微分方程数值解法数值积分和微分方程数值解法是数值计算中的重要组成部分,在科学计算、工程分析和实际问题求解中起着不可或缺的作用。

本文将介绍数值积分的基本概念和常用方法,以及微分方程数值解法的应用和实现过程。

一、数值积分的基本概念和常用方法数值积分是求解定积分近似值的方法,通过将连续函数的积分转化为离散形式的求和,以达到近似计算的目的。

常用的数值积分方法包括矩形法、梯形法、辛普森法等。

(1)矩形法:将积分区间等分为若干子区间,然后在每个子区间内取点,用函数在相应点处的取值近似代替该子区间内的函数值,最后将所有子区间的函数值相加得到近似积分值。

(2)梯形法:与矩形法类似,但是将每个子区间近似为一个梯形,通过计算梯形的面积来近似计算积分值。

(3)辛普森法:将积分区间等分为若干子区间,然后在每个子区间内取三个点,根据这三个点构造出一个二次函数,并用该二次函数的积分来近似计算积分值。

二、微分方程数值解法的应用和实现过程微分方程数值解法是对微分方程进行近似求解的方法,通过离散化微分方程来构造数值格式,然后通过数值计算来求解。

常用的微分方程数值解法包括常微分方程的欧拉法、改进欧拉法和龙格-库塔法,以及偏微分方程的有限差分法、有限元法等。

(1)常微分方程数值解法:- 欧拉法:根据微分方程的定义,将微分项近似为差分项,通过迭代逼近真实解。

- 改进欧拉法:在欧拉法的基础上,通过利用两个点的斜率来逼近解的变化率,提高精度。

- 龙格-库塔法:通过多次迭代,根据不同的权重系数计算不同阶数的近似解,提高精度。

(2)偏微分方程数值解法:- 有限差分法:将偏微分方程中的一阶和二阶导数近似为差分项,通过离散化区域和时间来构造矩阵方程组,然后通过求解线性方程组来获得数值解。

- 有限元法:将区域进行剖分,将偏微分方程转化为变分问题,通过选取适当的试函数和加权残差法来逼近真实解。

总结:数值积分和微分方程数值解法是数值计算中重要的工具,能够帮助我们处理实际问题和解决科学工程中的复杂计算。

微分方程数值解法及应用研究

微分方程数值解法及应用研究

微分方程数值解法及应用研究微分方程是研究自然科学和工程技术领域中各种现象和过程的基本数学模型。

然而,许多微分方程的解析解往往难以获得,因此需要借助数值解法来近似求解。

本文将介绍微分方程的数值解法及其在实际应用中的研究。

微分方程数值解法是一种通过离散化微分方程来近似求解的方法。

其中最常用的方法之一是欧拉方法。

欧拉方法通过将连续的微分方程转化为离散的差分方程,逐步逼近真实解。

具体而言,欧拉方法通过逐步迭代来计算微分方程在给定初始条件下的近似解。

假设我们需要求解的微分方程为y'(x) = f(x, y(x)),初始条件为y(x0) = y0。

利用欧拉方法,可以得到如下递推公式: yn+1 = yn + h*f(xn, yn)其中,h为步长,xn和yn分别表示第n个离散点的自变量和因变量。

通过多次迭代计算,可以得到微分方程在给定步长下的数值解。

除了欧拉方法外,还有许多其他常用的微分方程数值解法。

其中,龙格-库塔方法是最为经典和常用的高精度数值解法之一。

龙格-库塔方法通过计算不同阶级的差分公式来提高数值解的精度。

最常用的是经典的四阶龙格-库塔方法,也称为RK4方法。

与欧拉方法相比,RK4方法的精度更高,并且适用于解决更加复杂的微分方程。

此外,还有变步长的自适应数值解法,如龙格-库塔法的自适应步长版本和变步长的欧拉法,可以根据误差控制准则自动选择适当的步长,以提高数值解的精度和计算效率。

微分方程数值解法在实际应用中具有广泛的研究价值和实用意义。

在物理学中,微分方程数值解法可以用来模拟物质的运动、传热传质等过程。

例如,通过求解流体力学方程(如纳维-斯托克斯方程)的数值解,可以研究风、水、气体等流体的运动规律,从而优化工程设计和改进环境保护措施。

在工程技术领域,微分方程数值解法可以应用于信号处理、图像处理、控制系统等诸多领域。

例如,利用微分方程数值解法来优化控制系统的参数,可以提高机器人、航天器和工业自动化等领域的自动控制性能。

微分方程的数值解法

微分方程的数值解法

微分方程的数值解法微分方程(Differential Equation)是描述自然界中变化的现象的重要工具,具有广泛的应用范围。

对于一般的微分方程,往往很难找到解析解,这时候就需要使用数值解法来近似求解微分方程。

本文将介绍几种常见的微分方程数值解法及其原理。

一、欧拉方法(Euler's Method)欧拉方法是最基本也是最容易理解的数值解法之一。

它的基本思想是将微分方程转化为差分方程,通过给定的初始条件,在离散的点上逐步计算出函数的近似值。

对于一阶常微分方程dy/dx = f(x, y),利用欧拉方法可以得到近似解:y_n+1 = y_n + h * f(x_n, y_n)其中,h是步长,x_n和y_n是已知点的坐标。

欧拉方法的优点在于简单易懂,但是由于是一阶方法,误差较大,对于复杂的微分方程可能不够准确。

二、改进的欧拉方法(Improved Euler's Method)改进的欧拉方法又称为改进的欧拉-柯西方法,是对欧拉方法的一种改进。

它通过在每一步计算中利用两个不同点的斜率来更准确地逼近函数的值。

对于一阶常微分方程dy/dx = f(x, y),改进的欧拉方法的迭代公式为:y_n+1 = y_n + (h/2) * [f(x_n, y_n) + f(x_n+1, y_n + h * f(x_n, y_n))]相较于欧拉方法,改进的欧拉方法具有更高的精度,在同样的步长下得到的结果更接近真实解。

三、四阶龙格-库塔方法(Fourth-Order Runge-Kutta Method)四阶龙格-库塔方法是一种更高阶的数值解法,通过计算多个点的斜率进行加权平均,得到更为准确的解。

对于一阶常微分方程dy/dx = f(x, 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)y_n+1 = y_n + (k1 + 2k2 + 2k3 + k4)/6四阶龙格-库塔方法是数值解法中精度最高的方法之一,它的计算复杂度较高,但是能够提供更为准确的结果。

微分方程常用的两种数值解法:欧拉方法与龙格—库塔法

微分方程常用的两种数值解法:欧拉方法与龙格—库塔法

资料范本本资料为word版本,可以直接编辑和打印,感谢您的下载微分方程常用的两种数值解法:欧拉方法与龙格—库塔法地点:__________________时间:__________________说明:本资料适用于约定双方经过谈判,协商而共同承认,共同遵守的责任与义务,仅供参考,文档可直接下载或修改,不需要的部分可直接删除,使用时请详细阅读内容四川师范大学本科毕业论文四川师范大学教务处二○一○年五月微分方程常用的两种数值解法:欧拉方法与龙格—库塔法学生姓名:xxx 指导教师:xx【内容摘要】微分方程是最有生命力的数学分支,在自然科学的许多领域中,都会遇到常微分方程的求解问题。

当前计算机的发展为常微分方程的应用及理论研究提供了非常有力的工具,利用计算机解微分方程主要使用数值方法,欧拉方法和龙格——库塔方法是求解微分方程最典型常用的数值方法。

本文详细研究了这两类数值计算方法的构造过程,分析了它们的优缺点,以及它们的收敛性,相容性,及稳定性。

讨论了步长的变化对数值方法的影响和系数不同的同阶龙格—库塔方法的差别。

通过编制C程序在计算机上实现这两类方法及对一些典型算例的结果分析比较,能更深切体会它们的功能,优缺点及适用场合,从而在实际应用中能对不同类型和不同要求的常微分方程会选取适当的求解方法。

关键词:显式单步法欧拉(Euler)方法龙格—库塔(Runge—Kutta)方法截断误差收敛性Two commonly used numerical solution of differential equations:Euler method and Runge - Kutta methodStudent Name: Xiong Shiying Tutor:Zhang Li【Abstract】The differential equation is the most vitality branch in mathematics. In many domains of natural science, we can meet the ordinary differential equation solution question. Currently, the development of computer has provided the extremely powerful tool for the ordinary differential equation application and the fundamental research, the computer solving differential equation mainly uses value method. The Euler method and the Runge—Kutta method are themost typical commonly value method to solve the differential equation. This article dissects the structure process of these two kinds of values commonly value method to solve the analyses their good and bad points, to their astringency, the compatibility, and the stabilityhas made the proof. At the same time, the article discuss the lengthof stride to the numerical method changing influence and thedifference of the coefficient different same step Runge—kutta method. Through establishing C program on the computer can realize these two kind of methods, Anglicizing some models of calculate example result can sincerely realize their function, the advantage and disadvantage points and the suitable situation, thus the suitable solution method can be selected to solve the different type and the different request ordinary differential equation in the practical application .Keywords: Explicit single-step process Euler method Runge—Kutta method truncation error convergence目录微分方程常用的两种数值解法:欧拉方法与龙格—库塔法前言常微分方程的形成与发展是和力学、天文学、物理学以及其他科学技术的发展密切相关的。

微分方程数值解法

微分方程数值解法

微分方程数值解法微分方程是数学中的重要概念,它描述了物理系统中变量之间的关系。

解微分方程是许多科学领域中常见的问题,其中又可以分为解析解和数值解两种方法。

本文将重点介绍微分方程的数值解法,并详细讨论其中的常用方法和应用。

一、微分方程的数值解法概述微分方程的解析解往往较为复杂,难以直接求解。

在实际问题中,我们通常利用计算机进行数值计算,以获得方程的数值解。

数值解法的基本思想是将微分方程转化为一组离散的数值问题,通过逼近连续函数来获得数值解。

二、常见的数值解法1. 欧拉法欧拉法是最基础的数值解法之一,其核心思想是将微分方程转化为差分方程,通过逼近连续函数来获得数值解。

欧拉法的基本形式为:yn+1 = yn + h·f(xn, yn)其中,yn表示第n个时间步的数值解,h为时间步长,f为微分方程右端的函数。

欧拉法的精度较低,但计算简单,适用于初步估计或简单系统的求解。

2. 改进的欧拉法(Heun法)改进的欧拉法(Heun法)是对欧拉法的改进,其关键在于求解下一个时间步的近似值时,利用了两个斜率的平均值。

Heun法的基本形式为:yn+1 = yn + (h/2)·(k1 + k2)k1 = f(xn, yn),k2 = f(xn+h, yn+h·k1)Heun法较欧拉法的精度更高,但计算量较大。

3. 龙格-库塔法(RK方法)龙格-库塔法是一类常用的数值解法,包含了多个不同阶数的方法。

其中,最常用的是经典四阶龙格-库塔法(RK4法),其基本形式为: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/6)·(k1 + 2k2 + 2k3 + k4)RK4法实现较为复杂,但精度较高,适用于解决大多数常微分方程问题。

数学物理方程的数值解法

数学物理方程的数值解法

数学物理方程的数值解法数学物理方程是自然界和科学中描述物体运动、能量转化和相互作用的基本规律。

我们通常使用数值解法来求解这些方程,以得到近似的解析解。

数值解法既可以用于数学问题,也可以用于物理问题。

本文将介绍几种常见的数学物理方程的数值解法。

一、微分方程的数值解法微分方程是描述物体运动和变化的重要工具。

常见的微分方程有常微分方程和偏微分方程。

常见的数值解法包括:1. 欧拉法(Euler's method)欧拉法是最简单的数值解法之一,通过将微分方程离散化为差分方程,在每个小时间步长上近似计算微分方程的导数。

欧拉法易于实现,但精度相对较低。

2. 龙格-库塔法(Runge-Kutta method)龙格-库塔法是一类常用的数值解法,包括二阶、四阶等不同的步长控制方法。

龙格-库塔法通过计算多个离散点上的导数来近似微分方程,精度较高。

3. 有限差分法(Finite difference method)有限差分法是一种常用的数值解法,将微分方程转化为差分方程并在网格上逼近微分方程的导数。

有限差分法适用于边值问题和初值问题,且精度较高。

二、积分方程的数值解法积分方程描述了给定函数的积分和积分变换之间的关系。

常见的数值解法有:1. 数值积分法数值积分法是通过数值逼近求解积分方程,常用的数值积分法包括梯形法则、辛普森法则等。

数值积分法适用于求解一维和多维积分方程。

2. 蒙特卡洛法(Monte Carlo method)蒙特卡洛法通过随机采样和统计分析的方法,将积分方程转化为概率问题,并通过大量的随机样本来估计积分值。

蒙特卡洛法适用于高维空间和复杂积分方程。

三、优化问题的数值解法优化问题是寻找在给定约束条件下使目标函数取得极值的数学问题。

常见的数值解法有:1. 梯度下降法(Gradient descent method)梯度下降法是一种常用的优化算法,通过迭代和梯度方向来寻找目标函数的局部最优解。

梯度下降法适用于连续可导的优化问题。

微分方程数值解法

微分方程数值解法
对许多实际问题来说,欧拉公式与改进欧拉 公式精度还不能满足要求,为此从另一个角度来分 析这两个公式的特点,从而探索一条构造高精度方 法的途径.
路漫漫其修远兮, 吾将上下而求索
改进欧拉法
路漫漫其修远兮, 吾将上下而求索
路漫漫其修远兮, 吾将上下而求索
路漫漫其修远兮, 吾将上下而求索
路漫漫其修远兮, 吾将上下而求索
的方法称为微分方程的数值解法。 称为微分方程的数值解。
称节点间距
为步长,
通常采用等距节点,即取 hi = h (常数)。
路漫漫其修远兮, 吾将上下而求索
3、相关定义


在区域D上对 满足Lipschitz条件是指
:
路漫漫其修远兮, 吾将上下而求索
4、 迭代格式的构造
(1) 构造思想:将连续的微分方程及初值条件离散为线性方程组 加以求解。由于离散化的出发点不同,产生出各种不同的数值 方法。基本方法有:有限差分法(数值微分)、有限体积法( 数值积分)、有限元法(函数插值)等等。 (2) 一般构造方法:
计算量大
多一个初值, 可能影响精度
路漫漫其修远兮, 吾将上下而求索
改进欧拉法 /* modified Euler’s method */
Step 1: 先用显式欧拉公式作预测,算出 Step 2: 再将 y n+1 代入隐式梯形公式的右边作校正,得到
路漫漫其修远兮, 吾将上下而求索
路漫漫其修远兮, 吾将上下而求索
路漫漫其修远兮, 吾将上下而求索
中点欧拉公式 /* midpoint formula */
中心差商近似导数
x0
x1
x2
假设
, 则可以导出
即中点公式具有 2 阶精度。

微分方程的常用数值解法

微分方程的常用数值解法

微分方程的常用数值解法摘要:微分方程是数学中的一种重要的方程类型,它能描述自然现象和工程问题中的许多变化规律。

但是大多数微分方程解法是无法用解析的方式求解的,因此需要借助数值解法来近似求解。

本文将介绍微分方程的常用数值解法。

关键词:欧拉方法;龙格-库塔方法;微分方程;常用数值解法一、微分方程数值解方法微分方程数值解法是数学中的重要部分。

欧拉方法、龙格-库塔方法和二阶龙格-库塔方法是常用的微分方程数值解法,下面就分别介绍这三种方法。

(一)欧拉方法欧拉方法是解初值问题的一种简单方法,它是欧拉用的第一种数值方法,也叫向前欧拉法。

欧拉方法是利用微分方程的定义式y’=f(x, y),将它带入微分方程初值问题y(x_0)=y_0中,以y_0为初始解,在每一步上通过沿着切线的方法进行估计并推进新的解y_{i+1}:y_i+1=y_i+hf(x_i,y_i)其中,x_i和y_i是我们知道的初始条件,h是求解过程中的步长,f是微分方程右端项。

它是一种时间迭代的算法,易于实现,但存在着精度不高的缺点。

(二)龙格-库塔方法龙格-库塔方法是一种经典迭代方法,也是近代微分方程数值解法发展的里程碑之一。

龙格-库塔方法的主要思想是利用规定的阶码及阶向量,通过递推求解微分方程数值解的近似值。

龙格-库塔方法的方式不同,其步骤如下:第一步:根据微分方程,计算出在x_i和y_i的值。

第二步:在x_i处对斜率进行估计,并利用这个斜率来求解下一步所需的y_i+1值。

第三步:使用x_i和y_i+1的值来重新估计斜率。

第四步:使用这个新的斜率来更新y_i+1的值。

(三)二阶龙格-库塔方法二阶龙格-库塔方法是龙格-库塔方法的一种变体,它根据龙格-库塔方法的思想,使用更好的步长来提高数值解的精度。

二阶龙格-库塔方法的基本思路是,在第一次迭代时使用一个阶段小一半的y_i+1,然后使用这个估算值来计算接下来的斜率。

通过这种方法,可以提高解的精度。

二阶龙格-库塔方法的步骤如下:第一步:计算出初始阶段的y_i+1值。

微分方程的数值解法

微分方程的数值解法

微分方程的数值解法微分方程是数学中的一种重要的基础理论,广泛用于科学技术的研究中。

微分方程的解析解往往比较难求得,而数值解法则成为了解决微分方程的重要手段之一。

本文将阐述微分方程的数值解法,探讨一些经典的数值方法及其应用。

一、数值解法的基本思想微分方程的数值解法的基本思想是建立微分方程的差分方程,然后通过数值计算的方法求得差分方程的近似解,最终得到微分方程的数值解。

其中,差分方程是微分方程的离散化,将微分方程转化为差分方程的过程称为离散化或网格化。

离散化的目的是将连续问题转化为离散问题,使问题求解更为方便。

差分方程的计算通常需要将区间分成若干份,每一份都对应着一个节点,节点的个数与区间长度有关。

在每个节点处采集函数值,根据这些函数值计算出差分方程的值,再根据差分方程的迭代公式计算出每个节点的函数值。

因此差分方程的求解问题就转化成了求解节点函数值的问题。

二、欧拉法欧拉法是微分方程数值解法中最简单的一种方法,广泛应用于各种领域。

欧拉法的基本思想是运用泰勒公式,将函数在某一点展开成一次多项式,用两个相邻节点之间的差分来逼近导数的值,从而得到连续问题的离散解。

具体实现过程如下:1. 将微分方程的初始值问题区间[a,a]分成若干个小区间,每个小区间长度为a,共有a个节点,其中节点序列为a0,a1,a2,⋯,aa,节点之间的间隔为a。

2. 根据微分方程的迭代公式得到差分方程,即令aa+1=aa+aa(aa,aa)3. 按照差分方程的迭代公式,从初始值a0开始,逐一计算得到函数值,a1,a2,⋯,aa。

欧拉法的精度比较低,误差常常会较大,但是它运算速度快,实现简单,计算量小,因此在计算简单模型时常常使用。

三、龙格-库塔法龙格-库塔法是微分方程数值解法中精度最高的一种方法,具有比欧拉法更精确、更稳定的特点,广泛应用于各种实际问题中。

龙格-库塔法的主要思想是用多阶段逼近法估算每一步的函数值,从而提高时间的精度。

具体实现过程如下:1. 将微分方程的初始值问题区间[a,a]分成若干个小区间,每个小区间长度为a,共有a个节点,其中节点序列为a0,a1,a2,⋯,aa,节点之间的间隔为a。

微分方程数值解法概述

微分方程数值解法概述

微分方程数值解法概述微分方程是描述自然界和社会科学中许多现象的重要数学模型,它们在科学研究和工程技术中具有广泛的应用。

为了求解微分方程,人们开发了多种数值解法。

本文将对微分方程数值解法进行概述,介绍其中常用的几种方法。

一、欧拉方法欧拉方法是最简单的一种数值解法,它基于微分方程的定义。

欧拉方法将微分方程的解曲线离散化为一系列连接相邻点的线段,并通过计算斜率来近似曲线的切线。

具体步骤如下:1. 将解曲线上的点等距离地选取为x0, x1, x2, ..., xn。

2. 根据微分方程得出差分方程:y_(k+1) = y_k + h * f(x_k, y_k),其中h为步长。

3. 通过迭代计算,得到近似解的数值解。

尽管欧拉方法简单直观,但由于是一阶方法,它的精度相对较低,容易出现截断误差。

二、改进的欧拉方法为了提高数值解的精度,人们改进了欧拉方法,例如改进的欧拉方法、改进的欧拉法和四阶改进的欧拉法等。

这些方法主要通过引入更高阶的项来减小截断误差,从而提高数值解的精度。

其中最常用的是四阶改进的欧拉法,也称为四阶龙格-库塔法(RK4)。

该方法具体步骤如下:1. 根据微分方程的定义,设置初始值y0。

2. 根据微分方程,计算中间点的斜率k1,k2,k3和k4。

3. 计算步长h * (k1+2k2+2k3+k4)/6,得到下一个节点的近似解。

4. 重复步骤2和步骤3,直到得到满足要求的数值解。

三、龙格-库塔方法(RK方法)龙格-库塔方法是一类经典的数值解法,常用于求解常微分方程。

与欧拉方法和改进的欧拉方法不同,龙格-库塔方法中的每个节点都有自己的权重。

最常用的是四阶龙格-库塔方法(RK4),其步骤与上述四阶改进的欧拉法类似。

四、有限差分法有限差分法是求解微分方程的一种常见数值方法。

该方法将微分方程中的导数用差商的形式进行近似,然后通过在离散的网格点上求解代数方程组来得到数值解。

有限差分法的核心思想是使用差商来逼近导数。

微分方程数值解法

微分方程数值解法

微分方程数值解法微分方程数值解法是一种将微分方程的解转化为数值计算的方法。

常用的微分方程数值解法包括欧拉法、隐式欧拉法、龙格-库塔法等。

1. 欧拉法:欧拉法是最简单的一种数值解法,它基于微分方程的定义,在给定的初始条件下,通过不断迭代计算微分方程在给定区间上的近似解。

欧拉法的迭代公式为:y_{n+1}=y_n+h\\cdot f(t_n,y_n),其中y_n表示第n步的近似解,t_n表示第n步的时间,h表示步长,f(t_n,y_n)表示微分方程的右侧函数。

2. 隐式欧拉法:隐式欧拉法是欧拉法的改进,它在计算近似解时使用了未知公式的近似值,从而提高了精度。

隐式欧拉法的迭代公式为:y_{n+1}=y_n+h\\cdotf(t_{n+1},y_{n+1}),其中y_{n+1}表示第n+1步的近似解,t_{n+1}表示第n+1步的时间,h表示步长,f(t_{n+1},y_{n+1})表示微分方程的右侧函数。

3. 龙格-库塔法:龙格-库塔法是一种常用的高阶数值解法,它通过计算微分方程的斜率来提高精度。

最常见的是四阶龙格-库塔法,它的迭代公式为:y_{n+1}=y_n+\\frac{1}{6}(k_1+2k_2+2k_3+k_4),其中k_1=h\\cdot f(t_n,y_n),k_2=h\\cdotf(t_n+\\frac{h}{2},y_n+\\frac{1}{2}k_1),k_3=h\\cdotf(t_n+\\frac{h}{2},y_n+\\frac{1}{2}k_2),k_4=h\\cdotf(t_n+h,y_n+k_3)。

这些方法的选择取决于问题的性质和精度要求。

其中,欧拉法是最简单的方法,但精度较低,龙格-库塔法精度较高,但计算量较大。

在实际应用中需要根据问题的具体情况选择合适的数值解法。

微分方程数值解法及其误差分析

微分方程数值解法及其误差分析

微分方程数值解法及其误差分析微分方程(Differential Equations)是数学中的一个重要分支,广泛应用于物理学、工程学和其他领域。

微分方程的解析解通常很难求得,因此需要借助数值计算方法来获得近似解。

本文将介绍微分方程数值解法及其误差分析。

一、常见微分方程数值解法1. 欧拉法(Euler Method)欧拉法是最简单的一种数值解法,基于泰勒展开公式。

它将微分方程转化为差分方程,通过离散化时间和空间来逼近真实解。

欧拉法的计算步骤简单,但精度较低。

2. 改进的欧拉法(Improved Euler Method)改进的欧拉法相比于欧拉法,通过考虑两个近邻点的平均斜率,提高了数值解的准确性。

它采用两个阶段的计算来逼近真实解,精度较欧拉法更高。

3. 4阶龙格-库塔法(4th Order Runge-Kutta Method)4阶龙格-库塔法是一种常用的数值解法,通过计算四个不同位置的斜率来逼近真实解。

它的精度较高,适用范围广,并且较为稳定。

4阶龙格-库塔法是目前最常用的微分方程数值解法之一。

二、误差分析在使用微分方程数值解法时,理解误差来源是非常重要的。

主要有以下两种误差:1. 截断误差(Truncation Error)截断误差是由于采用离散化的方法而引入的误差。

数值解法中的每一步都会产生截断误差,步长越小,截断误差越小。

2. 累积误差(Cumulative Error)累积误差是由于在多个离散步骤中的小误差逐渐积累而引起的。

当数值解法步骤的误差较大时,累积误差可能会快速增加。

在选择数值解法时,需要权衡精度和计算效率。

欧拉法计算简单快速,但精度较低,适用于计算量较大的问题。

4阶龙格-库塔法精度较高,但计算步骤较多,适用于对精度要求较高的问题。

三、使用示例下面以一个具体的微分方程为例,演示如何使用数值解法求解。

考虑一阶常微分方程:dy/dx = x - y,边界条件 y(0) = 1。

1. 使用欧拉法进行数值计算:- 将求解区间 [0, 1] 分割为 n 个小区间,步长 h = 1/n。

微分方程的数值解法与误差估计

微分方程的数值解法与误差估计

微分方程的数值解法与误差估计微分方程是数学中的重要分支,广泛应用于物理、工程、经济等领域。

解微分方程的数值方法是研究微分方程的一个重要方面,它通过数值计算来近似求解微分方程,为实际问题提供了有效的数值解。

本文将介绍微分方程的数值解法以及误差估计的相关内容。

一、欧拉方法欧拉方法是一种常见的数值解微分方程的方法。

它基于微分方程的定义,将微分方程转化为差分方程。

具体而言,对于一阶常微分方程dy/dx=f(x,y),我们可以将其转化为差分方程(y_(i+1)-y_i)/(x_(i+1)-x_i)=f(x_i,y_i),其中x_i和y_i分别表示第i个点的x坐标和y坐标。

然后,通过给定的初始条件y_0,可以使用迭代公式y_(i+1)=y_i+(x_(i+1)-x_i)f(x_i,y_i)来逐步计算出近似解。

然而,欧拉方法存在一定的误差。

首先,它是基于线性逼近的,因此在非线性问题上可能会产生较大的误差。

其次,由于每次迭代的误差会累积,欧拉方法的误差随着步长的增加而增加。

因此,在使用欧拉方法时需要注意选择合适的步长,以保证结果的准确性。

二、改进的欧拉方法为了克服欧拉方法的缺点,人们提出了改进的欧拉方法,如改进的欧拉法和改进的欧拉-克罗默法。

这些方法通过引入更高阶的近似公式来减小误差,并提高数值解的精度。

改进的欧拉法是通过使用中点来近似解的方法,即在每个小区间上使用中点的斜率来计算近似解。

这样做可以减小误差,并提高数值解的精度。

改进的欧拉-克罗默法是通过使用梯形法则来近似解的方法,即在每个小区间上使用梯形的斜率来计算近似解。

这种方法比改进的欧拉法更精确,但计算量也更大。

三、龙格-库塔方法龙格-库塔方法是一种常用的数值解微分方程的方法,它通过使用不同阶数的近似公式来计算近似解,并通过比较不同阶数的结果来估计误差。

其中最常用的是四阶龙格-库塔方法,也称为RK4方法。

RK4方法通过计算不同阶数的斜率来逐步逼近真实解。

微分方程常用的两种数值解法欧拉方法和龙格库塔法

微分方程常用的两种数值解法欧拉方法和龙格库塔法

微分方程常用的两种数值解法欧拉方法和龙格库塔法微分方程是数学中重要的概念之一,用于描述变化率的关系。

通常情况下,微分方程很难通过解析方法求解,因此需要借助于数值解法。

欧拉方法和龙格库塔法是常用的数值解微分方程的方法。

欧拉方法(Euler's method)是数值解微分方程的最简单的方法之一、通过将微分方程转化为差分方程来求得数值解。

欧拉方法的基本思想是将微分方程的导数近似为取定步长的差商,从而得到离散的逼近解。

具体步骤如下:1.确定微分方程和初始条件。

2.设定步长h,确定求解的区间。

3.将微分方程转化为差分方程,即利用导数的定义将微分项近似为差商。

4.使用迭代公式进行计算,得到逼近解。

欧拉方法的基本迭代公式为:yn+1 = yn + h * f(xn, yn)其中,xn和yn分别代表当前的自变量和因变量的值,h为步长,f(xn, yn)为微分方程右端项关于自变量和因变量的函数,yn+1为逼近解的新值。

欧拉方法的优点是简单易懂,易于实现;缺点是由于使用一阶近似,误差较大,尤其在步长较大时会造成较大的误差。

龙格库塔法(Runge-Kutta method)是一种更高阶的数值解微分方程的方法。

与欧拉方法不同,龙格库塔法使用多次逼近的方式,从而得到更精确的数值解。

具体步骤如下:1.确定微分方程和初始条件。

2.设定步长h,确定求解的区间。

3.根据龙格库塔法的具体阶数,确定迭代公式。

4.使用迭代公式进行计算,得到逼近解。

龙格库塔法的基本迭代公式为:yn+1 = yn + (1/6) * (k1 + 2 * k2 + 2 * k3 + k4)其中,k1 = h * f(xn, yn)k2 = h * f(xn + (h/2), yn + (k1/2))k3 = h * f(xn + (h/2), yn + (k2/2))k4 = h * f(xn + h, yn + k3)龙格库塔法通过多次迭代计算,利用更高阶的近似方式,可以得到较高精度的数值解。

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

《微分方程数值解法》【摘要】自然界与工程技术中的很多现象,可以归结为微分方程定解问题。

其中,常微分方程求解是微分方程的重要基础内容。

但是,对于许多的微分方程,往往很难得到甚至不存在精确的解析表达式,这时候,数值解提供了一个很好的解决思路。

,针对于此,本文对常微分方程数值解法进行了简单研究,主要讨论了一些常用的数值解法,如欧拉法、改进的欧拉法、Runge —Kutta 方法、Adams 预估校正法以及勒让德谱方法等,通过具体的算例,结合MA TLAB 求解画图,初步给出了一般常微分方程数值解法的求解过程。

同时,通过对各种方法的误差分析,让大家对各种方法的特点和适用范围有一个直观的感受。

【关键词】 常微分方程 数值解法 MA TLAB 误差分析引言在我国高校,《微分方程数值解法》作为对数学基础知识要求较高且应用非常广泛的一门课程,不仅在数学专业,其他的理工科专业的本科及研究生教育中开设这门课程.近四十年来,《微分方程数值解法》不论在理论上还是在方法上都获得了很大的发展.同时,由于微分方程是描述物理、化学和生物现象的数学模型基础,且它的一些最新应用已经扩展到经济、金融预测、图像处理及其他领域 在实际应用中,通过相应的微分方程模型解决具体问题,采用数值方法求得方程的近似解,使具体问题迎刃而解。

2 欧拉法和改进的欧拉法2.1 欧拉法2.1.1 欧拉法介绍首先,我们考虑如下的一阶常微分方程初值问题 ⎩⎨⎧==00)(),('y x y y x f y(2--1)事实上,对于更复杂的常微分方程组或者高阶常微分方程,只需要将x 看做向量,(2--1)就成了一个一阶常微分方程组,而高阶常微分方程也可以通过降阶化成一个一阶常微分方程组。

欧拉方法是解常微分方程初值问题最简单最古老的一种数值方法,其基本思路就是把(2--1)中的导数项'y 用差商逼近,从而将一个微分方程转化为一个代数方程,以便求解。

设在[]b a ,中取等距节点h ,因为在节点n x 点上,由(2--1)可得:))(()(',n n n x y x f x y =,(2--2)又由差商的定义可得:hx y x y x y n n n )()(('1-≈+)(2--3) 所以有 ))(,()()(1n n n n x y x hf x y x y +≈+ (2--4)用)(k x y 的近似值k y )1,(+=n n k 代入(2--4),则有计算1+n y 的欧拉公式))(,(1n n n n x y x hf y y +=+ (2--5)2.1.2欧拉法误差分析从欧拉公式中可以看出,右端的n y 都是近似的,所以用它计算出来的1+n y 会有累计误差,累计误差比较复杂,为简化分析,我们考虑局部截断误差,即认为n y 是精确的前提下来估计11)(++-n n y x y ,记为1+n ε,泰勒展开有)()()(''2)(')()(1321++<<+++=n n n n n x x h O y h x hy x y x y ξξ(2--6)联立(2--5),(2--6)即得1+n ε=)(''22ξy h +)(3h O =)(2h O ,根据数值算法精度的定义,如果一个数值方法的局部截断误差1+n ε=)(1+p h O 则称这个算法具有P 阶精度,所以,欧拉方法具有一阶精度或者称欧拉方法为一阶方法。

2.2 改进的欧拉方法2.2.1 改进的欧拉法介绍用数值积分离散化问题(1),两边做积分有: dx x y x f x y x y n nx x n n ⎰+=-+1))(,()()(1(2--7)对右端积分使用梯形积分公式可得:[]))(,())(,(2))(,(111+++≈⎰+n n n n x x x y x f x y x f hdx x y x f n n(2--8)同欧拉方法,用)(k x y 的近似值k y )1,(+=n n k 代入(2--7),联立(2--8)得到改进的欧拉方法计算公式: ),(),((2111+++++=n n n n n n y x f y x f hy y (2--9)一般来说,如果求解1+n y 时,算法右端不包含1+n y ,称为显性计算公式,如果包含,则求解时还需要解方程,这种称为隐式计算公式。

显然公式(2--9)是一个隐式计算公式,事实上,改进的欧拉方法是用欧拉方法先求一个预测值1+n y ,再用这个预测值来计算1+n y ,即:⎪⎩⎪⎨⎧++=+=++++),(),((2),(1111n n n n n n n n n n y x f y x f hy y y x hf y y (2--10)2.2.2改进的欧拉法误差分析同欧拉法误差分析类似,用泰勒展开容易知道改进的欧拉方法具有二阶精度,证明略。

2.3 算例2.3.1(一阶常微分方程)求解初值问题⎪⎩⎪⎨⎧∈-==]1,0[21)0('x yx y y y解析:在MATLAB 中求解这个方程y=dsolve('Dy=y-2*x/y','y(0)=1','x') 得y =(2*x+1)^(1/2)它的解析解为x y 21+=,下面我们分别用欧拉方法和改进的欧拉方法来求其数值解。

欧拉方法:创建M 文件euler1.m,内容如下: function [x,y]=euler1(fun,x0,xfinal,y0,n) if nargin<5,n=50; endh=(xfinal-x0)/n; x(1)=x0;y(1)=y0;for i=1:nx(i+1)=x(i)+h;y(i+1)=y(i)+h*feval(fun,x(i),y(i));End再定义函数方程组中的函数f1,创建f1.m文件,内容如下:function f=f1(x,y)f=y-2*x/y在MATLAB中输入:[x,y]=euler1('f1',0,1,1,20)输出f,[x,y]的值,将数值解跟精确解画图表示,输入:plot(x,y,'r*-',x,sqrt(1+2*x),'g+--');xlabel('x');ylabel('y');title('y‘=y-2x/y');legend('数值解','精确解')得到图形,保存为euler1.fig,图形如下:改进的欧拉方法:创建M文件eulerprove1.m,内容如下:function [x,y]=eulerprove1(fun,x0,xfinal,y0,n)if nargin<5,n=50;endh=(xfinal-x0)/n;y(1)=y0,x(1)=x0;for i=1:nx(i+1)=x(i)+h;y1=y(i)+h*feval(fun,x(i),y(i))/2;y2=h*feval(fun,x(i+1),y1)/2;y(i+1)=y1+y2End在MATLAB的command窗口输入: [x,y1]=eulerprove1('f1',0,1,1,20)返回f,x1,y1的值,作图,输入:plot(x,y1,'r*-',x,sqrt(1+2*x),'g+--');xlabel('x');ylabel('y');title('y‘=y-2x/y');legend('数值解','精确解'),将图片保存为eulerprove1.fig,图形如下:为了便于比较两种方法的误差,将两者的误差作到同一个图上,继续输入:plot(x,abs(y-sqrt(1+2*x)),'y*-',x,abs(y1-sqrt(1+2*x)),'g+--');xlabel('x');ylabel('y');title('误差曲线');legend('欧拉方法','改进的欧拉方法')将图片保存为error1.fig,图形如下:从该图形来看,改进的欧拉方法与欧拉方法误差接近,欧拉方法误差稍微大些,将x 的取值扩宽,n 取值增大时,可以发现改进的欧拉方法相比欧拉方法有更高的精度。

2.3.2(高阶微分方程)对于二阶常微分方程)(]1,0[1)0(2)0('''∈⎩⎨⎧==-=x x x xx ,求数值解 解析:先算出其解析解,在MATLAB 中输入:y=dsolve('D2x=-x','x(0)=1','Dx(0)=2')得到解为:Y=2*sin(t)+cos(t),前面已经分别给出过欧拉方法和改进的欧拉方法的算例跟误差比较,这里我们就用精度更高的改进欧拉法进行数值求解。

改进的欧拉方法:先换元,令y x =',则原方程可以转化为])1,0[(2)0(1)0(''∈⎪⎩⎪⎨⎧===-=x y x yx xy ,现在,二阶常微分方程转化为了一个一阶常微分方程组,同2.3.2的方法,建立M 文件eulerprove3.m,内容如下:function [t,x,y]=eulerprove2(t0,tfinal,x0,y0,n) f1=inline('y'); f2=inline('-x') if nargin<5,n=50; endh=(tfinal-t0)/n; t(1)=t0,x(1)=x0;y(1)=y0; for i=1:n t(i+1)=t(i)+h;x1=x(i)+h*feval(f1,y(i)); y1=y(i)+h*feval(f2,x(i)); x2=x(i)+h*feval(f1,y1); y2=y(i)+h*feval(f2,x1); x(i+1)=(x1+x2)/2; y(i+1)=(y1+y2)/2;end在command窗口输入[t,x,y]=eulerprove3(0,1,1,2,10),得到t,x,y的值,其中x就是我们要求的数值解,作图,输入:plot(t,x,'r*-',t,2*sin(t)+cos(t),'b+-');xlabel('x');ylabel('y‘);legend('数值解','精确解'),将图形保存为eulerprove3.fig,图形如下:上面,我们已经通过例子看出,改进的欧拉法相比于欧拉法,在每一个节点处的误差值更下,下面,我们来讨论节点的多少(步长大小)对误差的影响,创建erro3r.m文件,内容如下:function [N,Y]=error3(n0,nfinal)N(1)=n0,m=fix((nfinal-n0)/4);for i=1:mN(i+1)=N(i)+4;[t,x1,y1]=eulerprove3(0,1,1,2,N(i));Y(i)=log10(max(x1-2*sin(t)-cos(t)));[t,x2,y1]=eulerprove3(0,1,1,2,N(i));Y(i+1)=log10(max(x2-2*sin(t)-cos(t)));end输入[N,Y]=error3(4,100),返回节点个数值和Y值,Y代表在N个节点时,数值解与精确解差的绝对值的最大值的对数(10为底)。

相关文档
最新文档