龙格-库塔方法基本原理.PPT_第1页
龙格-库塔方法基本原理.PPT_第2页
龙格-库塔方法基本原理.PPT_第3页
龙格-库塔方法基本原理.PPT_第4页
龙格-库塔方法基本原理.PPT_第5页
已阅读5页,还剩49页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、1在连续系统的仿真中,主要的计算工作是求解一阶微分方程在连续系统的仿真中,主要的计算工作是求解一阶微分方程 y =f(x,y)y( x0) = y0解析法只能用来求解一些特殊类型的方程,实际仿真问题中归解析法只能用来求解一些特殊类型的方程,实际仿真问题中归结出来的微分方程主要靠数值解法。结出来的微分方程主要靠数值解法。2由于实际运算只能完成有限项或有限步运算,因此要将有些需用极限或无穷过程进行的运算有限化,对无穷过程进行截断,这样产生的误差成为截断误差。根据实际情况建立的数学模型往往难以求解。通常需要通过近似替代,将所求解的数学模型简化为易求解的数值计算问题后再进行求解。数学模型的理论解与数值

2、计算问题的精确解之间的误差称为截断误差。这是计算方法本身带来的误差,所以也成为方法误差。2021-12-83得到高精度方法的一个直接想法是利用Taylor展开假设式 y =f(x,y) (axb) 中的 f(x,y) 充分光滑,将y(xi+1)在x i点作Taylor展开,若取右端不同的有限项作为y(xi+1)的近似值,就可得到计算y(xi+1)的各种不同截断误差的数值公式。例如:取前两项可得到例如:取前两项可得到)()()()(21hOxyhxyxyiii)(),()()(,()(22hOyxhfyhOxyxhfxyiiiiii3.2 龙格库塔方法龙格库塔方法2021-12-84)(21!

3、2PiPiiiiyPhyhyhyy 其中ffffffffff ffyf ffyxfyfyyyxyyxyxxxyxiyxxiiii22)(2)(),(, P阶泰勒方法若取前三项,可得到截断误差为若取前三项,可得到截断误差为O(h3)的公式的公式 )()(2)()()(321hOxyhxyhxyxyiiii )(),(),(),(2),(32hOyxfyxfyxfhyxhfyiiyiiiixiii类似地,若取前类似地,若取前P+1项作为项作为y(xi+1)的近似值,便得到的近似值,便得到2021-12-85显然p=1时, y i+1=y i+hf(xi,y i)它即为我们熟悉的Euler方法。当p

4、2时,要利用泰勒方法就需要计算f(x,y)的高阶微商。这个计算量是很大的,尤其当f(x,y)较复杂时,其高阶导数会很复杂。因此,利用泰勒公式构造高阶公式是不实用的。但是泰勒级数展开法的基本思想是许多数值方法的基础。R-K方法不是直接使用Taylor级数,而是利用它的思想2021-12-86龙格龙格- -库塔库塔( (R-K) )法的基本思想法的基本思想Euler公式可改写成 ),(1iiiiyxhfKKyy则yi+1的表达式与y(xi+1)的Taylor展开式的前两项完全相同,即局部截断误差局部截断误差为O(h2)。Runge-Kutta 方法是一种高精度的单步法方法是一种高精度的单步法, ,

5、简称简称R-K法法2021-12-87同理,改进Euler公式可改写成 ),(),(2121121211KyhxhfKyxhfKKKyyiiiiii 上述两组公式在形式上共同点:都是用f(x,y)在某些点上值的线性组合得出y(xi+1)的近似值yi+1, 且增加计算的次数f(x,y)的次数,可提高截断误差的阶。如欧拉法:每步计算一次f(x,y)的值,为一阶方法。改进欧拉法需计算两次f(x,y)的值,为二阶方法。局部截断误差局部截断误差为O(h3)2021-12-88 于是可考虑用函数f(x,y)在若干点上的函数值的线性组合来构造近似公式,构造时要求近似公式在(xi,yi)处的Taylor展开式

6、与解y(x)在xi处的Taylor展开式的前面几项重合,从而使近似公式达到所需要的阶数。既避免求高阶导数,又提高了计算方法精度的阶数。或者说,在xi,xi+1这一步内多计算几个点的斜率值,然后将其进行加权平均作为平均斜率,则可构造出更高精度的计算格式,这就是龙格龙格库塔库塔(Runge-Kutta)法的基本思想法的基本思想。 9),(),(),(11,1112122122111ppppipipiiiippiiKbKbyhaxhfK KbyhaxhfKyxhfKKcKcKcyy一般龙格库塔方法的形式为2021-12-89其中ai,bij,ci为待定参数,要求上式yi+1在点(xi,yi)处作Ta

7、ilor展开,通过相同项的系数确定参数。称为P阶龙格库塔方法。2021-12-810Runge-Kutta方法的推导思想0)(),(yaybxayxfy对于常微分方程的初值问题的解y=y(x),在区间xi, xi+1上使用微分中值定理,有)()()(1iiiyhxyxy即)()()(11iiiiixxyxyxy),(1iiixx其中2021-12-811上的平均斜率在区间可以认为是,)(1iixxxyyKKxyxyii)()(1引入记号)(,)(iiiyhfyhKKxxxyii上平均斜率的近似值间在区出只要使用适当的方法求,)(1就可得到相应的Runge-Kutta方法ix1ixxy)(xyy

8、 Kyyii1K2021-12-812ix1ixxy)(xyy 如下图Kxxxyxxyiii上的平均斜率在处的斜率作为在如果以,)()(1即则上式化为),(1iiiiyxhfyy)(ixyhK)(,iixyxhf),(iiyxhf即Euler方法Euler方法也称为一阶一阶Runge-Kutta方法方法KK2021-12-813二阶龙格二阶龙格库塔法库塔法 在xi, xi+1上取两点xi和xi+a2= xi +a2h,以该两点处的斜率值K1和K2的加权平均(或称为线性组合)来求取平均斜率k*的近似值K,即 2211KcKcK式中:K1 1为xi点处的切线斜率值 K1 =hf(xi, yi)=h

9、y(xi) K2 2为xi +a2h点处的切线斜率值,比照改进的欧拉法,将xi+a2视为xi+1,即可得 ),(12122KbyhaxhfKii确定系数 c1、c2、a2、b21 ,可得到有2阶精度的算法格式2021-12-814因此 Kxyxyii)()(1)()(2211KcKcxyi将y(xi+1)在x=xi处进行Taylor展开: )()(! 2)()()(321hOxyhxyhxyxyiiii )(! 2),()(32hOf ffhyxhfxyyxiii将 在x=xi处进行Taylor展开: ),()(121222KbyhaxhfhaxyhKiii152021-12-815)(),(

10、212122hOfKbf hayxfhKyxiiK1 =hf(xi, yi)(),(3212hOfhfbf hayxfhyxii)(22111KcKcyyii)(),(32122hOfhfbf hayxfhcyxii),()(1iiiyxhfcxy),()()(21iiiyxhfccxy)(32221222hOf fhcbfhcayx2021-12-81621,21,12212221cbcacc这里有这里有 4 个未知个未知数,数,3 个方程。个方程。存在无穷多个解无穷多个解。所有满足上式的格式统称为2阶阶龙格龙格 - - 库塔格式库塔格式。令 11)(iiyxy对应项的系数相等,得到 202

11、1-12-817注意到,注意到, 就是二阶就是二阶龙格龙格 - - 库塔库塔公式,也就是公式,也就是改进的欧拉法。改进的欧拉法。 21, 121212ccba),(),(21121211KyhxhfKyxhfKKKyyiiiiiiix1ixxy)(xyyK1K2K 因此,凡满足条件式有一簇形如上式的计算格式,这些格式统称为二阶龙格库塔格式。因此改进的欧拉格式是众多的二阶龙格库塔法中的一种特殊格式。 2021-12-818若取若取 ,就是另一种形式的二,就是另一种形式的二阶阶龙格龙格 - - 库塔公式库塔公式。 1, 0,2121212ccba)21,21(),(12121KyhxhfKyxhf

12、KKyyiiiiii此计算公式称为变形的二阶龙格库塔法。式中 为区间 的中点。也称中点公式也称中点公式。 hxi211,iixxQ:为获得更高的精度,应该如何进一步推广?为获得更高的精度,应该如何进一步推广?2021-12-819 二级R-K方法是显式单步式,每前进一步需要计算两个函数值。由上面的讨论可知,适当选择四个参数c1,c2,a2, b21,可使每步计算两次函数值的二阶R-K方法达到二阶精度。能否在计算函数值次数不变的情况下,通过选择不同的参数值,使得二阶R-K方法的精度再提高呢? 答案是否定的!无论四个参数怎样选择,都不能使公式的局部截断误差提高到三阶。 这说明每一步计算两个函数值的

13、二阶R-K方法最高阶为二阶。若要获得更高阶得数值方法若要获得更高阶得数值方法, ,就必须增加计算函就必须增加计算函数值的次数。数值的次数。20),(),(),(232131331212213322111KbKbyhaxhfKKbyhaxhfKyxhfKKcKcKcyyiiiiiiii三阶龙格三阶龙格库塔法库塔法2021-12-820 为进一步提高精度,在区间xi, xi+1上除两点xi和xi+a2= xi +a2h,以外,再增加一点xi+a3= xi +a3h ,用这三点处的斜率值K1、K2和K3的加权平均得出平均斜率K*的近似值K,这时计算格式具有形式: ix3aix2aixxy)(xyy

14、K1K2K3K2021-12-821 同理推导二阶公式,将y(xi+1)和yi+1在x=xi处进行Taylor展开,使局部截断误差达到O(h4),使对应项的系数相等,得到系数方程组:61,6131)(31)(,3121)(,21133221232232323122213231332212323222332312213322321cbbcbacbbcbbbcacbacacacbbcbcacaccc2021-12-822参数的选择不唯一,从而构成一类不同的三阶R-K公式,下面给出一种常用的三阶R-K公式,形似simpson公式:)2,()21,2(),()4(612131213211KKyhxhf

15、KKyhxhfKyxhfKKKKyyiiiiiiii2021-12-823四阶四阶( (经典经典) )龙格龙格库塔法库塔法 如果需要再提高精度,用类似上述的处理方法,只需在区间xi,xi+1上用四个点处的斜率加权平均作为平均斜率K*的近似值,构成一系列四阶龙格库塔公式。具有四阶精度,即局部截断误差是O(h5)。 推导过程与前面类似,由于过程复杂,这里从略,只介绍最常用的一种四阶经典龙格四阶经典龙格库塔公式库塔公式。 2021-12-824 K1=hf (xi, yi) K2=hf (xi+a2h, yi+b21K1) K3=hf (xi+a3h, yi+b31K1+b32K2) K4=hf (

16、xi+a4h, yi+b41K1+b42K2+b43K3) 其中c1、c2、c3、c4、a2、a3、a4、b21、b31、b32、b41、b42、b43均为待定系数。这里K1、K2、K3、K4为四个不同点上的函数值,分别设其为 设yi+1=yi+c1K1+c2K2+c3K3+c4K42021-12-825 类似于前面的讨论,把K2、K3、K4分别在xi点展成h的幂级数,代入线性组合式中,将得到的公式与y(xi+1)在xi点上的泰勒展开式比较,使其两式右端直到h4的系数相等,经过较复杂的解方程过程便可得到关于ci,ai,bij的一组特解 a2=a3=b21=b32=1/2 b31=b41=b42

17、=0 a4=b43=1 c1=c4=1/6 c2=c3=1/3 2021-12-826 四阶(经典)Runge-Kutta方法),()21,2()21,2(),()22(61342312143211KyhxhfKKyhxhfKKyhxhfKyxhfKKKKKyyiiiiiiiiii2021-12-827例1. 使用高阶R-K方法计算初值问题1)0(5 . 002yxyy. 1 . 0h取解:(1) 使用三阶R-K方法时0i1 . 0201 hyK1103. 0)21(2102KyhK1256. 0)2(22103KKyhK1111. 1)4(6132101KKKyy28其余结果如下:(2) 如

18、果使用四阶R-K方法时0i1 . 0201 hyK1103. 0)21(2102KyhK i xi k1 k2 k3 yi 1.0000 0.1000 0.1000 0.1103 0.1256 1.1111 2.0000 0.2000 0.1235 0.1376 0.1595 1.2499 3.0000 0.3000 0.1562 0.1764 0.2092 1.4284 4.0000 0.4000 0.2040 0.2342 0.2866 1.6664 5.0000 0.5000 0.2777 0.3259 0.4163 1.99932021-12-8291113. 0)21(2203Kyh

19、K1235. 0)(2304KyhK)22(61 . 0432101KKKKyy1111. 1其余结果如下: i xi k1 k2 k3 k4 yi 1.0000 0.1000 0.1000 0.1103 0.1113 0.1235 1.1111 2.0000 0.2000 0.1235 0.1376 0.1392 0.1563 1.2500 3.0000 0.3000 0.1562 0.1764 0.1791 0.2042 1.4286 4.0000 0.4000 0.2040 0.2342 0.2389 0.2781 1.6667 5.0000 0.5000 0.2777 0.3259 0

20、.3348 0.4006 2.00002021-12-830【例】 已知一阶系统的微分方程为: ,初始条件 ,取仿真步长h=0.1,分别用欧拉法、梯形法和龙格库塔法计算该系统仿真第一步的值。102ydtdy1)(00 yty解:原方程可变为: ),(210kkytfydtdy即 1210),(0yyytfkkk数值积分公式应用数值积分公式应用 31 (1)用欧拉法计算 根据欧拉公式,将函数表达式及其初始值代入后,可得该系统仿真第一步的值:8 .1)1210(1 .01),(0001ythfyy数值积分公式应用数值积分公式应用 ),(1kkkkythfyy32(2)用梯形法计算: 根据预报校正公

21、式,将函数表达式及其初始值代入后,可得仿真第一步的值。 用预报公式求起始值:8 . 1) 1210(1 . 01),(0001)0(ythfyy数值积分公式应用数值积分公式应用 ),(),(21),(1)0(111)0(kkkkkkkkkkytfytfhyyythfyy33再用校正公式得到系统仿真第一步的值:72. 1)8 . 1210() 1210(1 . 0211),(),(211)0(10001ytfytfhyy数值积分公式应用数值积分公式应用 34二阶龙格二阶龙格-库塔公式库塔公式)(2)(2111kkhyytynnn),(),(121hkyhtfkytfknnnn35(3)用二阶龙格

22、库塔法计算 根据公式先计算出两个系数,再计算仿真第一步的值: 812100),(001yytfk4 . 6)81 . 01 (210)(210),(101002hkyhkyhtfk数值积分公式应用数值积分公式应用 36则系统仿真第一步的值为:72. 1)4 . 68(1 . 0211)(22101kkhyy数值积分公式应用数值积分公式应用 37),()2,2()2,2(),()22(6342312143211hkyhtfkkhyhtfkkhyhtfkytfkkkkkhyykkkkkkkkkk四阶龙格四阶龙格库塔(库塔(RungeKutta)法)法5h38(4)用四阶龙格库塔公式计算根据公式先计

23、算出4个系数,再计算仿真第一步的值: 81210210),(0001yytfk2 . 7)81 . 0211 (210)2(210)2,2(101002khykhyhtfk数值积分公式应用数值积分公式应用 3928. 7)2 . 71 . 0211 (210)2(210)2,2(202003khykhyhtfk544. 6)28. 71 . 01 (210)(210),(303004hkyhkyhtfk数值积分公式应用数值积分公式应用 40则系统仿真第一步的值为:725067. 1)544. 628. 722 . 728(1 . 0611)22(6432101kkkkhyy数值积分公式应用数值

24、积分公式应用 41从上述结果可以看出从上述结果可以看出: 对于同一个系统进行仿真计算时,其值的精度是随对于同一个系统进行仿真计算时,其值的精度是随着数值积分公式的变化而改变的,其中欧拉法计算精着数值积分公式的变化而改变的,其中欧拉法计算精度最低,其次为梯形法和二阶龙格度最低,其次为梯形法和二阶龙格库塔法,四阶龙库塔法,四阶龙格格库塔法计算精度最高。库塔法计算精度最高。数值积分公式应用数值积分公式应用 例例2:用:用matlab演示演示42龙格龙格-库塔法的误差估计库塔法的误差估计 一个高精度的仿真方法必须将步长控制作为手段。一个高精度的仿真方法必须将步长控制作为手段。实现步长控制涉及局部误差估

25、计和步长控制策略两实现步长控制涉及局部误差估计和步长控制策略两方面的问题。方面的问题。 43龙格龙格-库塔法的误差估计库塔法的误差估计 RK方法的误差估计通常是设法找一个低一阶的方法的误差估计通常是设法找一个低一阶的RK公式,将公式,将两个公式计算结果之差作为估计误差。例如两个公式计算结果之差作为估计误差。例如Runge-Kutta-Fehlberg法的计算公式是法的计算公式是 RKF1-2公式公式 用另一个一阶公式用另一个一阶公式 来估计误差来估计误差)k(k512hyyE)255k(k256hyy)255k(k256hyh,ftk)k2hy,2hf(tk)y,f(tk)k510k(k512

26、hyy311n1nk21k1n21nn31nn2nn1321n1n44龙格龙格-库塔法的误差估计库塔法的误差估计 RKM3-4公式:误差估计式用公式:误差估计式用3 阶,计算公式为阶,计算公式为4 阶。阶。 RKM3-4公式公式 误差估计公式误差估计公式)k8k9k(2k6hE)3k4k(k2hyh,ftk)3k(k8hy,2hftk)k(k6hy,3hftk)k3hy,3hf(tk)y,f(tk)k4k(k6hyy5431n341nn531nn421nn31nn2nn1541k1n45龙格龙格-库塔法的步长控制库塔法的步长控制 龙格龙格-库塔法的误差估计和步长控制策略的基本思想库塔法的误差估

27、计和步长控制策略的基本思想是:每积分一步都设法估计出本步的积分误差是:每积分一步都设法估计出本步的积分误差en,然后判断是否满足允许误差然后判断是否满足允许误差E,据此选择相应的步,据此选择相应的步长控制策略。长控制策略。 每一步的局部误差通常取以下形式每一步的局部误差通常取以下形式 en=En/(|yn|+1) 其中其中|yn|是利用误差估计式计算出的本步的估计误是利用误差估计式计算出的本步的估计误差。当差。当|yn|较大时,较大时, en是相对误差,当是相对误差,当|yn|较小时,较小时, en 是绝对误差。这样作的目的是避免当是绝对误差。这样作的目的是避免当y 的值很小的值很小时,时,

28、en变得过大。变得过大。46仿真模型的运行速度与实际系统运行速度一致,称为实时仿真。一般方法难以满足实时仿真的需要:所得模型的执行速度较慢;机理也不符合实时仿真的需要。假设对一般形式的系统进行仿真: 以RK-2为例进行分析,其公式为 )(,(tuyfdtdy),(),()(211121211hkyutfkyutfkkkhyynnnnnnnn实时仿真47 假定在h/2的时间内计算机刚好计算一次右端函数f,则计算分为两步: 1 在tk时刻利用当前的un、yn计算K1; 2 在tn+h/2时刻计算K2,此时un+1无法得到,但实时仿真除了要满足执行速度的要求外,还要求实时接收外部输入,并实时得到输出

29、。1nu采入2k计算1k计算nt2htn1nntht21htn21nntht?48 此种情况下,解决的方法有两个:对un+1进行预报(增大仿真误差)或仿真延迟半个计算步距。后者的计算流程如下 可见,后种方法的输出也会延迟半个计算步距,为了克服这个缺陷,人们提出了如下形式的实时二阶RK法图图 RK-2 2的计算流程的计算流程nt2htn1nu采入并输出计算1ny1k计算下一个2k计算1k计算1nntht21htn21nntht49 实时RK-2公式:)2,(),(12/12/12121khyutfkyutfkhkyynnnnnnnn 其计算流程:假定在h/2的时间内计算机也刚好计算一次右端函数f,则计算也分

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论