常微分方程初值问题数值解法

上传人:pu****.1 文档编号:567688705 上传时间:2024-07-22 格式:PPT 页数:83 大小:929KB
返回 下载 相关 举报
常微分方程初值问题数值解法_第1页
第1页 / 共83页
常微分方程初值问题数值解法_第2页
第2页 / 共83页
常微分方程初值问题数值解法_第3页
第3页 / 共83页
常微分方程初值问题数值解法_第4页
第4页 / 共83页
常微分方程初值问题数值解法_第5页
第5页 / 共83页
点击查看更多>>
资源描述

《常微分方程初值问题数值解法》由会员分享,可在线阅读,更多相关《常微分方程初值问题数值解法(83页珍藏版)》请在金锄头文库上搜索。

1、第第9章章常微分方程初值问题数值解法常微分方程初值问题数值解法9.1 9.1 引言引言 包含自变量、未知函数及未知函数的导数或微包含自变量、未知函数及未知函数的导数或微分的方程称为微分方程。在微分方程中分的方程称为微分方程。在微分方程中, , 自变量的自变量的个数只有一个个数只有一个, , 称为常微分方程称为常微分方程. .。自变量的个数。自变量的个数为两个或两个以上的微分方程叫偏微分方程。微分为两个或两个以上的微分方程叫偏微分方程。微分方程中出现的未知函数最高阶导数的阶数称为微分方程中出现的未知函数最高阶导数的阶数称为微分方程的阶数。如果未知函数方程的阶数。如果未知函数y y及其各阶导数及其

2、各阶导数都是一次的都是一次的, ,则称它是线性的则称它是线性的, ,否则称为非线性的。否则称为非线性的。 2021/6/41 在高等数学中,对于常微分方程的求解,给出在高等数学中,对于常微分方程的求解,给出了一些典型方程求解析解的基本方法,如可分离变了一些典型方程求解析解的基本方法,如可分离变量法、常系数齐次线性方程的解法、常系数非齐次量法、常系数齐次线性方程的解法、常系数非齐次线性方程的解法等。线性方程的解法等。但能求解的常微分方程仍然是但能求解的常微分方程仍然是有限的,大多数的常微分方程是不可能给出解析解。有限的,大多数的常微分方程是不可能给出解析解。 譬如譬如 这个一阶微分方程就不能用初

3、等函数及其积分这个一阶微分方程就不能用初等函数及其积分来表达它的解。来表达它的解。 2021/6/42再如,方程再如,方程 的解的解 , ,虽然有表可查虽然有表可查, ,但对于表但对于表上没有给出上没有给出 的值的值, ,仍需插值方法来仍需插值方法来计算计算2021/6/43从实际问题当中归纳出来的微分方程,通常主要依从实际问题当中归纳出来的微分方程,通常主要依靠数值解法来解决。本章主要讨论一阶常微分方程靠数值解法来解决。本章主要讨论一阶常微分方程初值问题初值问题 (9.1) 在区间在区间a x ba x b上的数值解法上的数值解法。 可以证明可以证明, ,如果函数在带形区域如果函数在带形区域

4、 R=axb, R=axb,-y y内连续,且关于内连续,且关于y y满足李普希兹满足李普希兹(Lipschitz)(Lipschitz)条件,即存在常数条件,即存在常数L(L(它与它与x,yx,y无关无关) )使使对对R内任意两个内任意两个 都成立都成立, ,则方程则方程(9.1)的解的解 在在 a,b 上存在且唯一。上存在且唯一。 2021/6/44数值方法的基本思想数值方法的基本思想 对常微分方程初值问题对常微分方程初值问题( (9.1)式的数值解法,就式的数值解法,就是要算出精确解是要算出精确解y(x)y(x)在区间在区间 a,b 上的一系列离散节上的一系列离散节点点 处的函数值处的函

5、数值 的近似值的近似值。相邻两个节点的间距。相邻两个节点的间距 称为步长,步称为步长,步长可以相等,也可以不等。本章总是假定长可以相等,也可以不等。本章总是假定h为定数,为定数,称为称为定步长定步长,这时节点可表示为,这时节点可表示为数值解法需要把连续性的问题加以离散化,从而求数值解法需要把连续性的问题加以离散化,从而求出离散节点的数值解。出离散节点的数值解。2021/6/45 对常微分方程数值解法的对常微分方程数值解法的基本出发点就是离散基本出发点就是离散化。其数值解法有两个基本特点,它们都采用化。其数值解法有两个基本特点,它们都采用“步步进式进式”,即求解过程顺着节点排列的次序一步一步,即

6、求解过程顺着节点排列的次序一步一步地向前推进,描述这类算法,要求给出用已知信息地向前推进,描述这类算法,要求给出用已知信息 计算计算 的递推公式的递推公式。建立。建立这类递推公式的基本方法是在这些节点上用这类递推公式的基本方法是在这些节点上用数值积数值积分、数值微分、泰勒展开等离散化方法分、数值微分、泰勒展开等离散化方法,对初值问,对初值问题题中的导数中的导数 进行不同的离散化处理进行不同的离散化处理。 2021/6/46对于初值问题对于初值问题的数值解法,首先要解决的问题就是的数值解法,首先要解决的问题就是如何如何对微分方程对微分方程进行离散化,建立求数值解的递推公式。递推公式通进行离散化,

7、建立求数值解的递推公式。递推公式通常有两类,一类是计算常有两类,一类是计算yi+1时只用到时只用到xi+1,xi和和yi,即前,即前一步的值,因此有了初值以后就可以逐步往下计算,一步的值,因此有了初值以后就可以逐步往下计算,此类方法称为此类方法称为单步法单步法;其代表是;其代表是龙格龙格库塔库塔法。另一法。另一类是计算类是计算y yi+1i+1时,除用到时,除用到x xi+1i+1,x,xi i和和y yi i以外,还要用到以外,还要用到 ,即前面,即前面k步的值,此类方法称为步的值,此类方法称为多步法多步法;其代表是亚当斯法。;其代表是亚当斯法。2021/6/479.2简单的数值方法与基本概

8、念简单的数值方法与基本概念Euler公式公式 欧拉(欧拉(Euler)方法是解初值问题的最简)方法是解初值问题的最简单的数值方法。初值问题单的数值方法。初值问题的解的解y=y(x)y=y(x)代表通过点代表通过点 的一条称之为的一条称之为微分方程的积分曲线。积分曲线上每一点微分方程的积分曲线。积分曲线上每一点 的切线的斜率的切线的斜率 等于函数等于函数 在在这点的值。这点的值。 2021/6/48Euler法的求解过程是法的求解过程是: :从初从初始点始点P0(即点即点(x(x0 0,y,y0 0)出发出发, ,作积分曲线作积分曲线y=y(x)y=y(x)在在P0点上点上切线切线 ( (其斜率

9、为其斜率为 ), ),与与x=xx=x1 1直线直线相交于相交于P1点点( (即点即点(x(x1 1,y,y1 1),),得到得到y y1 1作为作为y(xy(x1 1) )的近似值的近似值, ,如上图所示。过点如上图所示。过点(x(x0 0,y,y0 0),),以以f(xf(x0 0,y,y0 0) )为斜率的切线为斜率的切线方程为方程为 当当 时时, ,得得 这样就获得了这样就获得了P P1 1点的坐标。点的坐标。 2021/6/49同样同样,过过点点P1(x x1 1,y,y1 1),),作积分曲线作积分曲线y=y(x)y=y(x)的切线的切线交直线交直线x=xx=x2 2于于P2点点,

10、 ,切线切线 的斜率的斜率 = =直线方程为直线方程为当当 时时, ,得得 2021/6/410当当 时时, ,得得由此获得了由此获得了P P2 2的坐标。重复以上过程的坐标。重复以上过程, ,就可获得一系就可获得一系列的点列的点: :P P1 1, ,P P1 1,P Pn n。对已求得点。对已求得点以以 = = 为斜率作直线为斜率作直线 取取2021/6/411 从图形上看从图形上看, ,就获得了一条近似于曲线就获得了一条近似于曲线y=y(x)y=y(x)的折线的折线 。这样这样, ,从从x x0 0逐个算出逐个算出对应的数值解对应的数值解 2021/6/412通常取通常取 ( (常数常数

11、),),则则Euler法的计算格式法的计算格式 i=0,1,n(9.2)还可用还可用数值微分数值微分、数值积分法数值积分法和和泰勒展开法泰勒展开法推导推导EulerEuler格式。以数值积分为例进行推导。格式。以数值积分为例进行推导。将方程将方程 的两端在区间的两端在区间 上积分得,上积分得, 选择不同的计算方法计算上式的积分项选择不同的计算方法计算上式的积分项 , ,就会得到不同的计算公式。就会得到不同的计算公式。 (9.3)2021/6/413 用左矩形方法计算积分项用左矩形方法计算积分项 代入代入(9.3)(9.3)式式, ,并用并用y yi i近似代替式中近似代替式中y(xy(xi i

12、) )即可得到即可得到向前欧拉(向前欧拉(EulerEuler)公式)公式 由于数值积分的矩形方法精度很低,所以由于数值积分的矩形方法精度很低,所以欧拉(欧拉(EulerEuler)公式当然很粗糙。)公式当然很粗糙。 2021/6/414例例9.1用欧拉法解初值问题用欧拉法解初值问题取步长取步长h=0.2 ,h=0.2 ,计算过程保留计算过程保留4 4位小数位小数 解解: h=0.2, : h=0.2, 欧拉迭代格式欧拉迭代格式 当当k=0,x1=0.2时,已知时,已知x0=0,y0=1,有,有y(0.2) y1=0.21(401)0.8当当k=1,x2=0.4时,已知时,已知x1=0.2,y

13、1=0.8,有,有y(0.4) y2=0.20.8(40.20.8)0.6144当当k=2,x3=0.6时,已知时,已知x2=0.4,y2=0.6144,有,有y(0.6) y3=0.20.6144(4-0.40.6144)=0.46132021/6/415clear; y=1, x=0, %初始化for n=1:10 y=1.1*y-0.2*x/y, x=x+0.1,endy = 1 x = 0 y = 1.1000 x = 0.1000y = 1.1918 x = 0.2000y = 1.2774 x = 0.3000y = 1.3582 x = 0.4000y = 1.4351 x =

14、0.5000y = 1.5090 x = 0.6000y = 1.5803 x = 0.7000y = 1.6498 x = 0.8000y = 1.7178 x = 0.9000y = 1.7848 x = 1.00002021/6/4169.2.2梯形公式梯形公式为了提高精度为了提高精度, ,对方程对方程 的两端在区间上的两端在区间上 积分得,积分得,改用梯形方法计算其积分项,即改用梯形方法计算其积分项,即 (9.4) 代入代入(7.4)(7.4)式式, ,并用近似代替式中即可得到梯形公式并用近似代替式中即可得到梯形公式 (9.5) 由由于于数数值值积积分分的的梯梯形形公公式式比比矩矩形形

15、公公式式的的精精度度高高,因因此此梯梯形形公公式式(9.59.5)比比欧欧拉拉公公式式( ( 9.2 9.2 ) )的的精精度度高高一一个数值方法。个数值方法。 2021/6/417(9.5) ( (9.5)式的右端含有未知的式的右端含有未知的y yi+1i+1, ,它是一个关于它是一个关于y yi+1i+1的函数方程的函数方程, ,这类数值方法称为这类数值方法称为隐式方法隐式方法。相。相反地反地, ,欧拉法是关于欧拉法是关于y yi+1i+1的一个直接的计算公式,的一个直接的计算公式, 这类数值方法称为这类数值方法称为显式方法。显式方法。 2021/6/4189.2.3两步欧拉公式两步欧拉公

16、式对方程对方程 的两端在区间上的两端在区间上 积分得积分得 (9.6) 改用中矩形公式计算其积分项,即改用中矩形公式计算其积分项,即 代入上式代入上式, ,并用并用y yi i近似代替式中近似代替式中y(xy(xi i) )即可得到两步即可得到两步欧拉公式欧拉公式 (9.7)2021/6/419 前面介绍过的数值方法前面介绍过的数值方法, ,无论是欧拉方无论是欧拉方法法, ,还是梯形方法,它们都是单步法还是梯形方法,它们都是单步法, ,其特点其特点是在计算是在计算y yi+1i+1时只用到前一步的信息时只用到前一步的信息y yi i; ;可是可是公式公式( (7.7)中除了中除了y yi i外

17、外, ,还用到更前一步的信还用到更前一步的信息息y yi-1i-1, ,即调用了前两步的信息即调用了前两步的信息, ,故称其为两故称其为两步欧拉公式步欧拉公式2021/6/4209.2.4欧拉法的局部截断误差欧拉法的局部截断误差衡衡量量求求解解公公式式好好坏坏的的一一个个主主要要标标准准是是求求解解公公式式的的精度精度,因此引入局部截断误差和阶数的概念。因此引入局部截断误差和阶数的概念。定定义义9.1在在yi准准确确的的前前提提下下,即即时时,用用数数值值方方法法计计算算yi+1的的误误差差,称称为为该该数数值值方方法法计算时计算时yi+1的局部截断误差。的局部截断误差。对于欧拉公式,假定对于

18、欧拉公式,假定,则有,则有而将真解而将真解y(x)在在xi处按二阶泰勒展开处按二阶泰勒展开 因此有因此有 2021/6/421定定义义9.2数数值值方方法法的的局局部部截截断断误误差差为为,则则称称这这种种数数值值方方法法的的阶阶数数是是P。步步长长(hN结束。结束。2021/6/426( 2 )改改进进欧欧拉拉法法的的流流程程图图 2021/6/427( (3)3)程序实现程序实现( (改进欧拉法计算常微改进欧拉法计算常微 分方程初值问题分方程初值问题)例例9.2 9.2 用改进欧拉法解初值问题用改进欧拉法解初值问题 区间为区间为 0,10,1 , ,取步长取步长h=0.1h=0.1 解解:

19、 : 改进欧拉法的具体形式改进欧拉法的具体形式 本题的精确解为本题的精确解为 , ,2021/6/428clearx=0,yn=1 %初始化for n=1:10yp=yn+0.1*(yn-2*x/yn); %预测x=x+0.1;yc=yn+0.1*(yp-2*x/yp) ;yn=(yp+yc)/2 %校正end2021/6/429例例9.3对初值问题对初值问题 证明用梯形公式求得的近似解为证明用梯形公式求得的近似解为并证明当步长并证明当步长h h0 0时时,y,yn n收敛于精确解收敛于精确解证明证明: : 解初值问题的梯形公式为解初值问题的梯形公式为 整理成显式整理成显式 反复迭代反复迭代,

20、 ,得到得到 2021/6/430由于由于 ,有,有 证毕证毕 2021/6/4319.3 9.3 龙格龙格- -库塔(库塔(Runge-KuttaRunge-Kutta)法)法9.3.1 9.3.1 龙格龙格- -库塔库塔(Runge-Kutta)(Runge-Kutta)法的基本思想法的基本思想 Euler Euler公式可改写成公式可改写成 则则yi+1i+1的的表表达达式式y( (xi+1i+1) )与与的的TaylorTaylor展展开开式式的的前前两两项项完完全相同全相同, ,即局部截断误差为即局部截断误差为 。 改进的改进的EulerEuler公式又可改写成公式又可改写成 202

21、1/6/432 上述两组公式在形式上有一个共同点上述两组公式在形式上有一个共同点: :都是用都是用f(x,y)f(x,y)在某些点上值的线性组合得出在某些点上值的线性组合得出y(xy(xi+1i+1) )的近似的近似值值y yi+1i+1, ,而且增加计算的次数而且增加计算的次数f f( (x x, ,y y) )的次数的次数, ,可提高截可提高截断误差的阶。如欧拉公式断误差的阶。如欧拉公式: :每步计算一次每步计算一次f f( (x x, ,y y) )的值的值, ,为一阶方法。改进欧拉公式需计算两次为一阶方法。改进欧拉公式需计算两次f f( (x x, ,y y) )的值,的值,它是二阶方

22、法。它的局部截断误差为它是二阶方法。它的局部截断误差为 。2021/6/433 于是可考虑用函数于是可考虑用函数f( (x, ,y) )在若干点上的函在若干点上的函数值的线性组合来构造近似公式,构造时要求数值的线性组合来构造近似公式,构造时要求近似公式在近似公式在( (xi i, ,yi i) )处的处的Taylor展开式与解展开式与解y( (x) )在在xi i处的处的Taylor展开式的前面几项重合,从而展开式的前面几项重合,从而使近似公式达到所需要的阶数。既避免求偏导使近似公式达到所需要的阶数。既避免求偏导, ,又提高了计算方法精度的阶数。或者说又提高了计算方法精度的阶数。或者说, ,在

23、在 这一步内多这一步内多预报几个点的斜率值,然后预报几个点的斜率值,然后将其加权平均作为平均斜率将其加权平均作为平均斜率,则可构造出更高,则可构造出更高精度的计算格式,这就是龙格精度的计算格式,这就是龙格库塔(库塔(Runge-Kutta)法的基本思想。)法的基本思想。2021/6/4349.3.2二阶龙格二阶龙格库塔法库塔法 在在 上取两点上取两点xi i和和 , ,以该两点处的以该两点处的斜率值斜率值k1 1和和k2 2的加权平均的加权平均( (或称为线性组合或称为线性组合) )来求取平来求取平均斜率均斜率k* *的近似值的近似值K,即,即式中式中: :k1 1为为xi i点处的切线斜率值

24、,点处的切线斜率值, k2 2为为 点处的切线斜率值点处的切线斜率值, ,比照改进的欧拉比照改进的欧拉法法, ,将将 视为视为 ,即可得,即可得 对常微分方程初值问题对常微分方程初值问题(9.1)(9.1)式的解式的解 y= =y( (x),),根据微分根据微分中值定理,存在点中值定理,存在点 ,使得,使得 2021/6/435式中式中 K K可看作是可看作是y=y(x)y=y(x)在区间在区间 上的平均斜率。上的平均斜率。所以可得计算公式为:所以可得计算公式为: (9.14) 将将y(xy(xi i) )在在x=xx=xi i处进行二阶处进行二阶TaylorTaylor展开:展开: (9 9

25、.15) 也即也即 (9.13)2021/6/436将将 在在x=xx=xi i处进行一阶处进行一阶TaylorTaylor展开:展开: 将以上结果代入(将以上结果代入(9.149.14)得:)得: (9.16) 对式对式(9.15)(9.15)和和(9.16)(9.16)进行比较系数后可知进行比较系数后可知, ,只要只要 (9.17) 成立成立, ,格式格式(9.14)(9.14)的局部截断误差就等于的局部截断误差就等于有有2 2阶阶精度精度2021/6/437式式(9.17)(9.17)中具有三个未知量中具有三个未知量, ,但只有两个方程但只有两个方程, ,因而有因而有无穷多解。若取无穷多

26、解。若取 , ,则则p p=1=1,这是无穷多解中的,这是无穷多解中的一个解,将以上所解的值代入式一个解,将以上所解的值代入式(9.14)(9.14)并改写可得并改写可得 不难发现,上面的格式就是改进的欧拉格式。不难发现,上面的格式就是改进的欧拉格式。凡满足条件式(凡满足条件式(9.179.17)有一簇形如上式的计算格式,)有一簇形如上式的计算格式,这些格式统称为二阶龙格这些格式统称为二阶龙格库塔格式。因此改进的库塔格式。因此改进的欧拉格式是众多的二阶龙格欧拉格式是众多的二阶龙格库塔法中的一种特殊库塔法中的一种特殊格式。格式。 2021/6/438若取若取 , ,则则 ,此时二阶龙格,此时二阶

27、龙格- -库塔库塔法的计算公式为法的计算公式为 此计算公式称为变形的二阶龙格此计算公式称为变形的二阶龙格库塔法。式中库塔法。式中 为区间为区间 的中点。的中点。 2021/6/4399.3.3三阶龙格三阶龙格- -库塔法库塔法 为了进一步提高精度,设除为了进一步提高精度,设除 外再增加一点外再增加一点 并用三个点并用三个点 , , , , 的斜率的斜率k1 1, ,k2 2, ,k3 3加权平均加权平均得出平均斜率得出平均斜率k* *的近似值,这时计算格式具有形式的近似值,这时计算格式具有形式: : (9.18) 为了预报点为了预报点 的斜率值的斜率值k3 3, ,在区间在区间 内有两内有两个

28、斜率值个斜率值k1 1和和k2 2可以用可以用, ,可将可将k1 1, ,k2 2加权平均得出加权平均得出 上的平均斜率上的平均斜率, ,从而得到从而得到 的预报值的预报值 2021/6/440于是可得于是可得运用运用Taylor展开方法选择参数展开方法选择参数 , ,可以使可以使格式格式( (9.18)的局部截断误差为的局部截断误差为 , ,即具有三阶精度,即具有三阶精度,这类格式统称为这类格式统称为三阶龙格三阶龙格库塔方法库塔方法。下列是其中。下列是其中的一种,称为的一种,称为库塔(库塔(Kutta)公式。)公式。 (9.19) 2021/6/4412021/6/4429.3.4四阶龙格四

29、阶龙格库塔法库塔法如如果果需需要要再再提提高高精精度度,用用类类似似上上述述的的处处理理方方法法,只只需需在在区区间间上上用用四四个个点点处处的的斜斜率率加加权权平平均均作作为为平平均均斜斜率率k*的的近近似似值值,构构成成一一系系列列四四阶阶龙龙格格库库塔塔公公式式。具有四阶精度,即局部截断误差是具有四阶精度,即局部截断误差是。 由于推导复杂,这里从略,只介绍最常用的一种由于推导复杂,这里从略,只介绍最常用的一种四阶经典龙格四阶经典龙格库塔公式库塔公式。 (9.20) 2021/6/4439.3.5 9.3.5 四阶龙格四阶龙格库塔法算法实现库塔法算法实现(1)(1)计算步骤计算步骤 输入输

30、入 , ,h,Nh,N 使用龙格使用龙格库塔公式(库塔公式(9.209.20)计算出)计算出y y1 1 输出输出 ,并使,并使 转到转到 直至直至n n N N 结束。结束。 2021/6/444( (2 2) ) 四四阶阶龙龙格格库库塔塔算算法法流流程程图图2021/6/445(3)(3) 程序实现程序实现( (四阶龙格四阶龙格- -库塔法计库塔法计(4)(4) 算常微分方程初值问题算常微分方程初值问题) )例例9.4 9.4 取步长取步长h=0.2h=0.2,用经典格式求解初值问题,用经典格式求解初值问题 解解: : 由四阶龙格由四阶龙格- -库塔公式可得库塔公式可得 2021/6/44

31、6可同样进行其余可同样进行其余y yi i的计算。本例方程的解为的计算。本例方程的解为,从表中看到所求的数值解具有,从表中看到所求的数值解具有4位有效数字。位有效数字。 龙格龙格库塔方法的库塔方法的推导基于推导基于Taylor展开方法,展开方法,因而它要求所求的解具有较好的光滑性。如果解的因而它要求所求的解具有较好的光滑性。如果解的光滑性差,那么,使用四阶龙格光滑性差,那么,使用四阶龙格库塔方法求得的库塔方法求得的数值解,其精度可能反而不如改进的欧拉方法数值解,其精度可能反而不如改进的欧拉方法。在。在实际计算时,应当针对问题的具体特点选择合适的实际计算时,应当针对问题的具体特点选择合适的算法。

32、算法。2021/6/4479.3.6变步长的龙格变步长的龙格-库塔法库塔法在在微微分分方方程程的的数数值值解解中中,选选择择适适当当的的步步长长是是非非常常重重要要的的。单单从从每每一一步步看看,步步长长越越小小,截截断断误误差差就就越越小小;但但随随着着步步长长的的缩缩小小,在在一一定定的的求求解解区区间间内内所所要要完完成成的的步步数数就就增增加加了了。这这样样会会引引起起计计算算量量的的增增大大,并并且且会会引引起起舍舍入入误误差差的的大大量量积积累累与与传传播播。因因此此微微分分方程数值解法也有选择步长的问题。方程数值解法也有选择步长的问题。 以经典的四阶龙格以经典的四阶龙格- -库塔

33、法库塔法( (9.20)为例。从节点为例。从节点x xi i出发,先以出发,先以h为步长求出一个近似值,记为为步长求出一个近似值,记为 ,由于局部截断误差为由于局部截断误差为 ,故有,故有当h h值不大时,式中的系数值不大时,式中的系数c c可近似地看作为常数。可近似地看作为常数。2021/6/448然后将步长折半然后将步长折半, ,即以为即以为 步长步长, ,从节点从节点x xi i出发出发, ,跨跨两步到节点两步到节点x xi+1i+1, ,再求得一个近似值再求得一个近似值 , ,每跨一步的每跨一步的截断误差是截断误差是 , ,因此有因此有这样这样 由此可得由此可得 这表明以这表明以 作为

34、作为 的近似值,其误差可用步的近似值,其误差可用步长折半前后两次计算结果的偏差长折半前后两次计算结果的偏差 来判断所选步长是否适当来判断所选步长是否适当2021/6/449当要求的数值精度为当要求的数值精度为时:时: (1 1)如如果果,反反复复将将步步长长折折半半进进行行计计算算,直直至至为止为止, ,并取其最后一次步长的计算结果作为并取其最后一次步长的计算结果作为 (2 2)如如果果为止,并以上一次步长的计算结果作为为止,并以上一次步长的计算结果作为 。 这这种种通通过过步步长长加加倍倍或或折折半半来来处处理理步步长长的的方方法法称称为为变变步步长长法法。表表面面上上看看,为为了了选选择择

35、步步长长,每每一一步步都都要要反反复复判判断断,增增加加了了计计算算工工作作量量,但但在在方方程程的的解解y(x)y(x)变变化化剧剧烈烈的的情情况况下下,总总的的计计算算工工作作量量得得到到减减少少,结果还是合算的。结果还是合算的。2021/6/4509.4算法的稳定性及收敛性算法的稳定性及收敛性9.4.1稳定性稳定性稳稳定定性性在在微微分分方方程程的的数数值值解解法法中中是是一一个个非非常常重重要要的的问问题题。因因为为微微分分方方程程初初值值问问题题的的数数值值方方法法是是用用差差分分格格式式进进行行计计算算的的,而而在在差差分分方方程程的的求求解解过过程程中中,存存在在着着各各种种计计

36、算算误误差差,这这些些计计算算误误差差如如舍舍入入误误差差等等引引起起的的扰扰动动,在在传传播播过过程程中中,可可能能会会大大量量积积累累,对对计计算算结结果果的的准准确确性性将将产产生生影影响响。这这就就涉涉及及到到算算法法稳定性问题。稳定性问题。 2021/6/451 当当在在某某节节点点上上x xi i的的y yi i值值有有大大小小为为的的扰扰动动时时,如如果果在在其其后后的的各各节节点点 上上的的值值y yi i产产生生的的偏偏差差都都不大于不大于,则称这种方法是稳定的。,则称这种方法是稳定的。 稳定性不仅与算法有关,而且与方程中函数稳定性不仅与算法有关,而且与方程中函数f(x,y)

37、f(x,y)也有关,讨论起来比较复杂。也有关,讨论起来比较复杂。为简单起见,为简单起见,通常只针对模型方程通常只针对模型方程来来讨讨论论。一一般般方方程程若若局局部部线线性性化化,也也可可化化为为上上述述形形式式。模模型型方方程程相相对对比比较较简简单单,若若一一个个数数值值方方法法对对模模型型方方程程是是稳稳定定的的,并并不不能能保保证证该该方方法法对对任任何何方方程程都都稳稳定定,但但若若某某方方法法对对模模型型方方程程都都不不稳稳定定,也也就就很很难难用于其他方程的求解。用于其他方程的求解。2021/6/452先考察显式先考察显式EulerEuler方法的稳定性。模型方程方法的稳定性。模

38、型方程的的EulerEuler公式为公式为 将上式反复递推后,可得将上式反复递推后,可得 或或式中式中2021/6/453 要使要使y yi i有界,其充要条件为有界,其充要条件为 即即 由于由于 ,故有,故有 (9.269.26) 可见,如欲保证算法的稳定,显式可见,如欲保证算法的稳定,显式EulerEuler格式的格式的步长步长h h的选取要受到式(的选取要受到式(9.269.26)的限制。)的限制。 的绝对的绝对值越大,则限制的值越大,则限制的h h值就越小。值就越小。 用隐式用隐式EulerEuler格式,对模型方程格式,对模型方程 的计算公式为,可化为的计算公式为,可化为2021/6

39、/454由于由于 , ,则恒有则恒有 , ,故恒有故恒有 因此,隐式因此,隐式EulerEuler格式是绝对稳定的(无条件稳定)格式是绝对稳定的(无条件稳定)的(对任何的(对任何h0h0)。)。 9.4.2 9.4.2 收敛性收敛性 常常微微分分方方程程初初值值问问题题的的求求解解,是是将将微微分分方方程程转转化化为为差差分分方方程程来来求求解解,并并用用计计算算值值y yi i来来近近似似替替代代y(xy(xi i) ),这这种种近近似似替替代代是是否否合合理理,还还须须看看分分割割区区间间 的的长长度度h h越越来来越越小小时时,即即 时时, 是是否否成成立立。若若成立,则称该方法是收敛的

40、,否则称为不收敛。成立,则称该方法是收敛的,否则称为不收敛。 这里仍以这里仍以EulerEuler方法为例,来分析其收敛性。方法为例,来分析其收敛性。EulerEuler格式格式2021/6/455设设表示取表示取时时,按按Euler公式的计算结果公式的计算结果,即即Euler方法局部截断误差为:方法局部截断误差为:设有常数设有常数 ,则,则 (9.27)总体截断误差总体截断误差 (9.28)又又 由于由于f(x,y)f(x,y)关于关于y y满足李普希茨条件满足李普希茨条件, ,即即 2021/6/456代入代入(9.28)上式,有上式,有再利用式(再利用式(9.27),式(),式(9.28

41、)即即上式反复递推后,可得上式反复递推后,可得(9.29) 2021/6/457设设 (T T为常数)为常数) 因为因为 所以所以 把上式代入式(把上式代入式(9.299.29),得),得 若不计初值误差,即若不计初值误差,即 ,则有,则有 (9.30)式式(9.30)(9.30)说明说明, ,当时当时 , , , ,即即 , ,所以所以EulerEuler方法是收敛的,且其收敛速度为方法是收敛的,且其收敛速度为 ,即具,即具有一阶收敛速度。同时还说明有一阶收敛速度。同时还说明EulerEuler方法的整体截断方法的整体截断误差为误差为 ,因此算法的精度为一阶。,因此算法的精度为一阶。 202

42、1/6/4589.5亚当姆斯方法亚当姆斯方法9.5.1亚当姆斯格式亚当姆斯格式龙龙格格-库库塔塔方方法法是是一一类类重重要要算算法法,但但这这类类算算法法在在每每一一步步都都需需要要先先预预报报几几个个点点上上的的斜斜率率值值,计计算算量量比比较较大大。考考虑虑到到计计算算yi+1之之前前已已得得出出一一系系列列节节点点上上的的斜斜率率值值,能能否否利用这些已知值来减少计算量呢?利用这些已知值来减少计算量呢?这这就就是是亚亚当当姆姆斯斯(Adams)方方法法的的设设计计思思想。想。 2021/6/459 设用设用x xi i,x,xi+1i+1两点的斜率值加权平均作为区间两点的斜率值加权平均作

43、为区间 上的平均斜率,有计算格式上的平均斜率,有计算格式 (9.21) 选取参数选取参数,使格式(,使格式(9.219.21)具有二阶精度。)具有二阶精度。 2021/6/460将将 在在x xi i处处Taylor展开展开 代入计算格式代入计算格式(9.21)(9.21)化简化简, ,并假设并假设, , 因此有因此有 与与y(xi+1)在在xi处的处的Taylor展开式展开式相比较相比较,需取需取 才使格式才使格式(9.21)具有二阶精度。这样导出的计算格式具有二阶精度。这样导出的计算格式称之为二阶亚当姆斯格式。类似地可以导出三阶亚称之为二阶亚当姆斯格式。类似地可以导出三阶亚当姆斯格式当姆斯

44、格式。 2021/6/461和和四阶亚当姆斯格式。四阶亚当姆斯格式。 ( (9.22)这里和下面均记这里和下面均记上述几种亚当姆斯格式都是显式的,算法比较上述几种亚当姆斯格式都是显式的,算法比较简单,但用节点简单,但用节点的斜率值来预报的斜率值来预报区间区间上的平均斜率是个上的平均斜率是个外推过程,外推过程,效果不够效果不够理想。为了进一步改善精度,变外推为理想。为了进一步改善精度,变外推为内插内插,即增,即增加节点加节点xi+1的斜率值来得出的斜率值来得出上的平均斜率。上的平均斜率。譬如考察形如譬如考察形如2021/6/462(9.23) 的隐式格式的隐式格式, ,设设( (9.23)右端的

45、右端的Taylor展开有展开有 可见要使格式可见要使格式(9.23)(9.23)具有二阶精度具有二阶精度, ,需令需令 , ,这样就可构造二阶隐式亚当姆斯格式这样就可构造二阶隐式亚当姆斯格式 其实是梯形格式。类似可导出三阶隐式亚当姆斯格式其实是梯形格式。类似可导出三阶隐式亚当姆斯格式 2021/6/463和四阶隐式亚当姆斯格式和四阶隐式亚当姆斯格式 (9.249.24) 9.5.2亚当姆斯预报亚当姆斯预报-校正格式校正格式参照改进的欧拉格式的构造方法,以四阶亚当参照改进的欧拉格式的构造方法,以四阶亚当姆斯为例,将显式(姆斯为例,将显式(9.22)和隐式()和隐式(9.24)相结合,)相结合,用

46、显式公式做预报,再用隐式公式做校正,可构成用显式公式做预报,再用隐式公式做校正,可构成亚当姆斯预报亚当姆斯预报-校正格式校正格式(9.259.25) 预报:预报: 校正:校正: 2021/6/464 这种预报这种预报- -校正格式是四步法,它在计校正格式是四步法,它在计算算y yi+1i+1时不但用到前一步的信息时不但用到前一步的信息 ,而且,而且要用到再前面三步的信息要用到再前面三步的信息 ,因此,因此它不能自行启动。在实际计算时,可借助于它不能自行启动。在实际计算时,可借助于某种单步法,譬如四阶龙格某种单步法,譬如四阶龙格库塔法提供开库塔法提供开始值始值 。 2021/6/465例例9.5

47、取步长取步长h=0.1,h=0.1,用亚当姆斯预报用亚当姆斯预报- -校正公式求解校正公式求解 初值问题初值问题的数值解。的数值解。 解解: : 用四阶龙格用四阶龙格- -库塔公式求出发值库塔公式求出发值 , ,计算得:计算得:表中的表中的 ,y ,yi i和和y(xy(xi i) )分别为预报值、校正值和准确分别为预报值、校正值和准确解解( ),( ),以比较计算结果的精度。以比较计算结果的精度。 再使用亚当姆斯预报再使用亚当姆斯预报- -校正公式校正公式(9.25),(9.25),2021/6/4669.6一阶常微分方程组与高阶方程一阶常微分方程组与高阶方程我我们们已已介介绍绍了了一一阶阶

48、常常微微分分方方程程初初值值问问题题的的各各种种数数值值解解法法,对对于于一一阶阶常常微微分分方方程程组组,可可类类似似得得到到各各种种解解法法,而而高高阶阶常常微微分分方方程程可可转转化化为为一一阶阶常常微微分分方方程组来求解。程组来求解。9.6.1一阶常微分方程组一阶常微分方程组对于一阶常微分方程组的初值问题对于一阶常微分方程组的初值问题(9.31) 可以把单个方程可以把单个方程中的中的f和和y看作向量看作向量来处理,这样就可把前面介绍的各种差分算法推广来处理,这样就可把前面介绍的各种差分算法推广到求一阶方程组初值问题中来。到求一阶方程组初值问题中来。2021/6/467设设 为节点上的近

49、似解,为节点上的近似解,则有改进的则有改进的EulerEuler格式为格式为 预报:预报:校正:校正: (9.32) 又,相应的四阶龙格又,相应的四阶龙格库塔格式(经典格式)为库塔格式(经典格式)为 (9.33) 2021/6/468式中式中 (9.34) 2021/6/469把节点把节点xi上的上的yi和和zi值代入式值代入式(7.34),依次算出依次算出,然然后后把把它它们们代代入入式式(7.33),算算出节点出节点xi+1上的上的yi+1和和zi+1值。值。 对于具有三个或三个以上方程的方程组的初值问对于具有三个或三个以上方程的方程组的初值问题题, ,也可用类似方法处理也可用类似方法处理

50、, ,只是更复杂一些而已。此外只是更复杂一些而已。此外, ,多步方法也同样可以应用于求解方程组初值问题。多步方法也同样可以应用于求解方程组初值问题。例例7.6 7.6 用改进的用改进的EulerEuler法求解初值问题法求解初值问题 取步长取步长h=0.1h=0.1,保留六位小数。,保留六位小数。 解解: : 改进的改进的EulerEuler法公式为法公式为预报:预报: 校正:校正: 将将 及及h=0.1h=0.1代入上式代入上式, ,得得 2021/6/470由初值由初值 , ,计算得计算得2021/6/4719.6.2高阶方程组高阶方程组 高阶微分方程高阶微分方程( (或方程组或方程组)

51、)的初值问题的初值问题, ,原则上都原则上都可以归结为一阶方程组来求解。例如可以归结为一阶方程组来求解。例如, ,有二阶微分方有二阶微分方程的初值问题程的初值问题(9.359.35) 在引入新的变量在引入新的变量 后后, ,即化为一阶方程组初值问题即化为一阶方程组初值问题: :(9.369.36) 式(式(9.369.36)为一个一阶方程组的初值问题,对此可)为一个一阶方程组的初值问题,对此可用前面中介绍的方法来求解。例如应用四阶龙格用前面中介绍的方法来求解。例如应用四阶龙格- -库塔公式得库塔公式得 2021/6/472(9.379.37) (9.389.38) 2021/6/473消去消去

52、 ,上式简化为:,上式简化为:(9.399.39) (9.409.40) 上述方法同样可以用来处理三阶或更高阶的微分方上述方法同样可以用来处理三阶或更高阶的微分方程(或方程组)的初值问题程(或方程组)的初值问题 2021/6/474例例9.7 9.7 求解下列二阶微分方程的初值问题求解下列二阶微分方程的初值问题 取步长取步长h=0.1 h=0.1 解解: :先作变换:令先作变换:令 ,代入上式,得一阶方程组,代入上式,得一阶方程组 用用四四阶阶龙龙格格- -库库塔塔方方法法求求解解, ,按按式式(9.37)(9.37)及及(9.38)(9.38)进行计算:进行计算:取步长取步长 , , , ,

53、 , ,时时 2021/6/4752021/6/476然后计算然后计算 时的时的y y2 2和和z z2 2;依此类推,直到;依此类推,直到i=9i=9时的时的y y1010和和z z1010,即可得到,即可得到其数值解。其数值解。2021/6/477本章小结本章小结 本本章章介介绍绍了了常常微微分分方方程程初初值值问问题题的的基基本本数数值值解解法法。包包括括单单步步法法和和多多步步法法。单单步步法法主主要要有有欧欧拉拉法法、改改进进欧欧拉拉法法和和龙龙格格库库塔塔方方法法。多多步步法法是是亚亚当当姆姆斯斯法法。它它们们都都是是基基于于把把一一个个连连续续的的定定解解问问题题离离散散化化为为

54、一一个个差差分分方方程程来来求求解解,是是一一种种步步进进式式的的方方法法。用用多多步步法法求常微分方程的数值解可获得较高的精度。求常微分方程的数值解可获得较高的精度。 实际应用时,选择合适的算法有一定的难度,实际应用时,选择合适的算法有一定的难度,既要考虑算法的简易性和计算量,又要考虑截断误既要考虑算法的简易性和计算量,又要考虑截断误差和收敛性、稳定性。差和收敛性、稳定性。2021/6/478龙龙格格-库库塔塔法法较较为为常常用用,适适用用于于多多步步方方法法中中作作初初值值计计算算和和函函数数f(x,y)较较为为简简单单的的场场合合。四四阶阶标标准准龙龙格格库库塔塔法法精精度度高高,程程序

55、序简简单单,易易于于改改变变步步长长,比比较较稳稳定定,也也是是一一个个常常用用的的方方法法,但但计计算算量量较较大大。当当函函数数f(x,y)较较为为复复杂杂,可可用用显显式式亚亚当当姆姆斯斯方方法法或或亚亚当当姆姆斯斯预预测测校校正正方方法法,不不仅仅计计算算量量较较小小,稳稳定定性性也也比比较好,但不易改变步长。较好,但不易改变步长。一一般般采采用用龙龙格格库库塔塔法法提提供供初初值值y1,y2,y3,然然后后用用亚亚当当姆姆斯斯外外推推公公式式求求得得预预测测值值,再再由由亚亚当当姆姆斯斯内内插插值值求求得得校校正正值值yi+1,如如此此求求得得的的值值近近似似程程度度好好且且节省计算量,是一种较好的方法。节省计算量,是一种较好的方法。2021/6/479作业作业习题九习题九P3161、2、5(1)2021/6/480Thank you very much!2021/6/481部分资料从网络收集整理而来,供大家参考,感谢您的关注!

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 其它相关文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号