大二下-數(shù)值分析_第1頁
大二下-數(shù)值分析_第2頁
大二下-數(shù)值分析_第3頁
大二下-數(shù)值分析_第4頁
大二下-數(shù)值分析_第5頁
已閱讀5頁,還剩104頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

數(shù)值分析計算機科學與技術系所EDAcaiy

:

62785564東主摟8區(qū)407第九章

常微分方程初值問題數(shù)值解法§9.1

引言一、背景常微分方程有著廣泛的應用,比如:火箭、的飛行控制;機器人控制;某些化學反應過程的描述與控制。又比如:對一個復雜的集成電路,可根據定律列出一組關于節(jié)點電壓及支路電流的常微分方程。求解這組常微初值問題即可詳細分析電路的瞬態(tài)特性。但實際當中,只有極少數(shù)常微分方程具有解析解,大多需借助數(shù)值方法。常微分方程分兩大類:初值問題和邊值問題,本章僅 前者。二、常微初值問題在初值問題里,集中 由單個的一階方程構成的初值問題:(1.1)(1.2)

y

'(x)(

f

(x,

y(x))

f

(x,

y)

y(x

)

y

o

o定義:存在常數(shù)L>0,使x

[a,

b],

y1,

y2

R,有:

f

(x,

y1)

f

(x,

y2

)

L

y1

y2

,

f

滿足對y的Lipschitz()條件,L稱Lipschitz常數(shù)。f

滿足條件還可用更強的條件保證。如

f

連續(xù)有界f對y滿

y足Lipshitz條件。這概念在第七章非線性方程求解中提到過。明確一下本章對象:a

x

b,定理1:D

x,

y

y

R連續(xù);(1)

f

(

x,

y)(2)f對y滿足Lipschitz條件,則初值問題:

y

f

(x,

y)

o

0

o

o

y(

x

)

y

,

x

[a,

b],y

R存在唯一解。定理2:設f在區(qū)域D(如定理1所定義)上連續(xù),且關于y滿足條件,設初值問題:y’(x)=f(x,y),y(x0)=s的解為y(x,

s),則:

f

(x,

s1)

f

(x,

s2

)

eL

x

x0

s1

s2該定理表明解對初值的敏感性,當f

的L比較小時,不敏感;L大時為

問題?!?/p>

…在帶形區(qū)域D內存在唯一解,或稱積分曲線y(x),滿足微分方程及初值條件。三、數(shù)值解法基本思想數(shù)值方法的思想是將問題的求解要求降低為只求一系列離散點的函數(shù)值。具體地說,是將積分區(qū)間離散化,并對離散點函數(shù)值的近似值:x0

x1

xn

xn1

yn1y0

y1yn的差分方程。所謂差分方程構成形如:yn1

G(yn1,ynynk)是“若干鄰近節(jié)點函值應滿足的關系(方程)”?;蛘哒f是

“節(jié)點函數(shù)值的某種遞推關系”。比如從y(x0

)

y0

及其它可,

yk提供的初值

y1,

y2

,

出發(fā),經差分方程步進地求出

yn1

。yn

yn

1

G

(

yn

1

,

ynk

)概括地說是“將連續(xù)問題離散化”,差分方程可分類如下:G

0k

0單步法

不含yn

1

顯式多步法yn

1

構造差分方程的基本方法有三種:1、基于數(shù)值微分的方法(9.2.1)2、基于數(shù)值積分的方法(9.2.2,9.3,9.5.2)3、基于Taylor展開的方法

(9.3,9.5)重要介紹方法2、3的全部差分方程,且著重于方法3。因為原則上,方法3可以導出方法1與方法2的全差方,但方法1、2

有直觀性,將比較全面地加以介紹。第九章課后練習(20)作業(yè):九3、4、6、7預習:9.4、9.5§9.2簡單的數(shù)值方法本節(jié)介紹四種簡單的差分方程構造方法,事實上,它們可以由以上三種構造方法的任一種推導得到。但為了大家對差分方程的構造方法有較全面、完整的了解,第1小節(jié)的向前Euler方法與后退Euler方法重點從基于數(shù)值微分的方法去推導。9.2.1

(向前)Euler與后退(向后)Euler法一、基于數(shù)值微分推導向前Euler公式基于數(shù)值微分構造差分方程,有兩個重要事實要經常用到:(1)積分曲線上任—點(x,y(x)),滿足微分方程,即:y(x)

f

(x,

y(x)),x

[a,

b](2)節(jié)點導數(shù)節(jié)點數(shù)值導數(shù)下面推導Euler向前公式:對初值問題,起始點x0的函數(shù)值y(x0)已知,那么對一個選定的h:x1

x0

h步長 ,如何構造聯(lián)系x0與x1兩個節(jié)點函數(shù)值的關系式,即關于節(jié)點函數(shù)值的差分方程呢?積分曲線在x0滿足的微分方程,即以x0代入微方程:y(xo

)

f

(xo

,

y(xo

))左端是x0的節(jié)點導數(shù)??蛇x用最簡單的數(shù)值微分公式:P131,第5行的兩點公式近似它:0

10(x

)

1

[

x

x

]

h

h

2只要將其中的符號作相應修改:

f

y

即可。0

10

0

0h

2y(x

)

1

[

y(x

)

y(x

)]

h

y

()

f

(x

,

y(x

))即:1

0

0

0h

21

[

y(x

)

y(x

)]

h

y

(

)

f

(x

,

y(x

))h

y()若設:y(x)C[a,b](連續(xù))且積分步長h足夠小,可將余2略去,則有:y(x1

)

y(x0

)

hf

(x0

,y(x0

))這樣,即建立起y(x0)與y(x1

)的遞推關系式,由已知初始值y(x0)即可經由差分方程導出

y(x1

),

y(x2

)

,可得一般遞推公式:y(xn1

)

y(xn

)

hf

(xn

,

y(xn

))不過仔細檢查上面的推導過程會發(fā)現(xiàn),在符號使用不上夠嚴格,這是因為前面已約定:y(x)——積分曲線,是方程的準確解,那么,y(xn

)——

y(x)

在xn

的準確解。但是,上述遞推關系式是積分步長足夠小,以致數(shù)值導數(shù)誤差可以忽略的條件下得到的。因此,即使

y(x0

)

完全準確,而經過遞推公式計算的號使用上的

,y(x1

)

一般就不再準確了。為了消除這種符引入以下記號加以區(qū)別:yn——差分方程在xn

的準確值。上述遞推 系應 寫為:yn1

yn

hf

(xn

,

yn

)——向前Euler公式這是形如yn1

G(yn

)的差分方程。由于yn+1僅依賴于前面一個函數(shù)值yn,故稱單步法。而且,一旦有了yn,yn+1就可算出,又稱顯式公式,因此,向前Euler公式為:顯式、單步的積分公式。小結:基于數(shù)值微分構造求積公式可概括為:“將微分方程離散化,以數(shù)值導數(shù)近似節(jié)點導數(shù),從而構造差分方程。”二、基于數(shù)值微分推導向后Euler公式同樣是基于數(shù)值微分方法推導,與向前Euler構造相似,y(x0)已知,對選定的離散化步長h,有x1

x0

h

,要建立聯(lián)系x1,x0函數(shù)值關系的差分方程。積分方程在x1滿足的微分方程:y(x1

)

f

(x1

,

y(x1

))左端的一階節(jié)點導數(shù),可選用P131第6行的兩點公式:1

1oh

2f

(x

)

1

[

f

(x

)

f

(x

)]

h

f

()類似地,將符號做相應改變,即

f

y

,有:1

1o

1h

2y(x

)

1

[

y(x

)

y(x

)]

h

y

(

)

f

(x,

y(x

))略去數(shù)值導數(shù)的誤差,又用y1~

y(x1

),有:y1

yo

hf

(x1

,

y1)得到的非線性代數(shù)方程。求出y1后,又可求出y2,y3,……一般地有:yn1

yn

hf

(xn1,

yn1

)——向后Euler公式向后Eluer公式為:隱式、單步法。小結:向前與向后Euler的推導區(qū)別僅在于:y

'(xn1

)

f

(xn1

,

y(xn1

))y

'(xn)

f

(xn,

y(xn))——向后Euler——向前Euler即向后Euler是 微分方程在離散點:xn+1的關系。而向前Euler是微分方程在離散點:xn

的關系。三、向后Euler公式的計算向后Euler公式是一個隱式公式,就是說一般從yn計算yn+1時不能像顯式公式那樣直接計算得到,而需求解一個關于yn+1的非線性代數(shù)方程。第七章已經初步介紹求解單變量非線性代數(shù)方程的方法,著重在于通過不動點迭代求解??吹?,向后Euler公式本身恰好是以某個函數(shù)的不動點形式表現(xiàn)的,因為:yn1

yn

hf

(xn1,

yn1

)

(

yn1

)即yn1

(yn1

)的不動點表達形式,并可立即得到相應的不動點迭代格式:(0)n

n,

y(k

)

)(

k

1)n1n

n1

n1

y

y

hf

(xy

y

hf

(x

,

y

)

n1nk

0,1,

(x)

C[a,

b]定理1,

設 滿足以下兩個條件:復習第七章定理有1、對任意

x

[a,

b]

a

(x)

b2、存在正常數(shù)L<1,使對任意x,y

[a,b],(x)

(

y)

L

(x

y)*則

(x)在[a,

b]上存在唯一不動點x*

。定理2,設(x)

C[a,b]滿足定理1兩個條件,則對任意初值

xo

[a,

b]

,由

xk

1

(xk

)

得到的迭代序列

xk

收斂到

(x)

的Lk(2.5)

。不動點x*,并有誤差估計:xk

x

1

L

x1

x0,

y

(

k

)

)y

(

k

1)n

1

yn

hf

(

xn

1設f(x,y)對y滿足Lipschitz條件:f(x,y)

f

(x,y)

L

y

y

yn1存在唯一(y(x)存在唯一)利用第七章定理2:(1)

y

R,(2)

Lh

1

y

時,…n

1yn

1

yn

hf

(

xn

1

,

yn

1

)y(

k

1)n1n1n1

n1

y

h f

(x,

y(k

)

)

f

(x

,

y

)n1

n1

hL y(

k

)

yn1n1只要h足夠小,使hL<1成立,即可保證迭代法收斂。9.2.2

梯形方法一、基于數(shù)值積分的推導:積分:對微分方程y(x)

f

(x,

y(x)),在區(qū)間[xn

,xn1

]xxxnxnf

(t,

y(t))dtn1n1y(x)dx

n1ny(xx)

y(

)

xn1f

(t,

y(t))dtxn這里要把積分作近似處理:

ft可利用遞形公式計算右端積分即有:2n1

nn

n

n1n1y(x

)

y(x

)

h

[

f

(x

,

y(x

))

f

(x

,

y(x

))]考慮到數(shù)值積分不可避免地存在誤差,可轉化為差分方程形式:2n1

n

n

nn1

,

yn1

)]y

y

h

[

f

(x

,

y

)

f

(x——梯形公式梯形公式為:隱式、單步法。注意:積分區(qū)間的取法以及積分 的數(shù)值積分處理方法不同,可得到更一般的基于數(shù)值積分方法推導的差分格式。比如:仍取積分區(qū)間

[xn,

xn1]

,但積分

以左端點的左矩形公式近似,則有:向前Eulery(xn1

)

y(xn

)

hf

(xn

,

y(xn

))

yn1

yn

hf

(xn

,

yn

)f同理,可推出向后Euler公式。yn1

yn

hf

(xn1,

yn1

)t二、梯形公式的計算P283,式(2.8)已構造了一個不動點迭代格式,也做了收斂性分析。n1n

hf

(xn

,

yn

)

y(0)

y(2.8)n

nn1n1

ny

y

h

f

(x

,

y

)

f

(x2

n1

(k+1),

y(k))(k

0,1,

2,

)

9.2.3

改進的Euler公式

y梯形公式:n1n

n

n

n1

n1

y

h

[

f(x

, )

(x

,

)]2是一個隱式公式,前面已經,給出初值y(0)后不動點迭代n12nn

n1n1n

n1y(k

1)

y

h

[

f

(x

,

y

)

f

(x

,

y(

k

)

)]給出序列

(

k

)yn1

只要h足夠小,有:y(

k

)n1n1k

yyn1

是梯形差分公式精確解。但上述迭代過程一般是個計算量很大的過程,而且從另一角度看,即使準確的

yn1

,也僅是y(xn1

)

的近似值

yn1

y(xn1

)

。因此,耗費大量機時去獲得一個不一定很準的函數(shù)近似值并不值得,常常采用如下計算過程:n1

y(0)

yn

hf

(xn

,

yn

)2nn

n,y(k

)

)]n1

n1

h

[

f

(x

,

y

)

f

(x(k

0,1,

2,)y(k

1)

y

n1即僅作少量的幾步迭代,稱為“預報-校正”格式,甚至往往更加簡單,只取k=0,即:n1

y(0)nn

n

y

hf

(x

,

y

)2(0)n1

n1h

yn1

yn [

f

(xn

,

yn

)

f

(x

,

y

)]——改進Euler公式(P283

(2.13))也可改寫為一個的顯式單步公式:2n

n

n

nn

nyn1

yn

h

[

f

(x

,

y

)

f

(x

h

,

y

hf

(x

,

y

))]還可以改寫成與R-K公式更相近的表達形式:2

k1

y

n

h

f

(

x

n

,

y

n

)

k

y

n

h

f

(

x

n

1

,

k

1

)y

n

1

1

(

k

k

)2

1

29.2.4

單步法局部截斷誤差與階單步法的一般形式:yn1

yn

h(xn

,

yn

,

yn1,

h)(2.11)

h

(xn

,

yn

,

h)顯示單步法:yn1

yn與f(x,y)有關,比如:(xn

,

yn

,

h)

f

(xn

,

yn

)向前Euler:梯形公式:2n

n

n1

n

nn1

n1(x

,

y

,

y

,

h)

1

[

f

(x

,

y

)

f

(x

,

y

)]下面引出局部截斷誤差概念,用于判斷一個差分公式的精度,是常微數(shù)值解的一

的 念。Tn1

y(xn1

)

y(xn

)

h(xn

,

y(xn

),

h)定義1,設y(x)是初值問題(1.1),(1.2)的精確解,稱為顯式單步法:yn1

yn

h(xn

,yn

,h)的局部截斷誤差。1、向前Euler局部截斷誤差yn1

yn

hf

(xn

,

yn

)yn1

y(xn

)

hf

(xn

,

y(xn

))向前Euler:若令:則不難看出,二者是有區(qū)別的:yn+1表示從y(x0

)出發(fā)應用向前Euler差分格式,從yn求出yn+1。一般來:yn

y(xn

)

。而

yn1表示從xn求yn+1

時,使用了積分曲線在xn的準確值y(xn),并應用向前Euler差分方程得到的xn+1的函數(shù)近似值

yn1

。那么,局部截斷誤差正是

:Tn1

y(xn1

)

yn1

y(xn1

)

y(xn

)

hf

(xn

,

y(xn

))應如何比較右端各量,以便將右端簡化呢?基本方法是將各量在xn作Taylor展開。一般都取在xn作Taylor展開,即:y(xn1

)

y(xn

h)

y(x

n)

hy

(x

n)

y

(xn

)

h

22又注意到:Tn1y(xn1

)

yn1

y(xn1

)

y(xn

)

hf

(xn

,

y

xn(xn

, (xn

))

(xn

)y

(xn

)

y(xn

)

hy(xn

)h

2代入上式,有:Tn1

y(xn1

)

yn1

y(xn

)

hy(xn

)

2n

h

2

y(x

)

2

h

2

y(x

)2n——向前Euler局部截斷誤差首P=1,一階顯示公式定義2,設

y(x)

是(

.

)(.

)的準確解,若存在最大整數(shù)P使顯式單步法的局部誤差滿足:Tn1

y(x

h)

y(x)

h(x,

y,

h)

O(hp1

)具有P階精度。(2.10)稱方法yn1

yn

h(xn

,

yn

,

h)n1

(x

p1

p2n

,

y(xn

))h

O(h

)若:T

(xn

,

y(xn

))hp1稱:為局部截斷誤差主首。2、向后Euler局部截斷誤差向后Euler公式:yn1

yn

hf

(xn1,

yn1

)yn1

y(xn

)

hf

(xn1,

yn1

)記:表示,在xn時,取y(xn)為準確值遞推得到的xn+1的差分方程。與推導向前Euler公式局部截斷誤差相似,應?。簲?shù)值yn1Tn1

y(xn1

)

yn1

y(xn1

)

y(xn

)

hf

(xn1

,

yn1

)作為向后Euler局部截斷誤差。一般來說但書上(P285)為了推導局部截斷誤差主yn1

y(xn1

)比較方便以y(xn1

)得到:代替yn1(xn1

)

(xn

)

h

(xn1, (xn1

))Tn1

從微方程可知:f

(xn1,

y(xn1

))

y(xn1

)

y(xn

h)h

2則有:h

232Tn1

y(xn

)

hy(xn

)

2

y

(xn

)

y(xn

))

O(h

)h[

y(xn

)

hy(xn

)

y

(xn

)]

h

2

y

(x2nP=1,是一階隱式公式。3、

形公式局部截斷誤差2,

y

)]n1

nn

nn1

n1y

y

h

[

f

(x

,

y

)

f(x梯形公式:主的方法定義梯形P285仍取便于推導局部截斷誤差首公式局部截斷誤差:2,

y(x

))]n1

n1

nn

nn1n1T

y(x

)

y(x

)

h

[

f

(x

,

y(x

))

f

(xh

3y(xn

)首

為:

12P=2

,是二階隱式公式。§9.3

Runge-Kutta方法本節(jié)介紹基于Tayler展開方法推導Runge-Kutta公式為了便于理解,從簡單的2階公式的構造入于,因此,1、2兩小節(jié)對—

。9.3.2

二階顯式R-K方法一、一般二階公式約定梯形公式的推導, 是通過與微分方程等價的積分方程:nxf

(t,

y(t))dtxn1y(xn1

)

y(xn

)

還利用積分方程形式去理解如何約定一般給出的。下面的二階R-K公式。通過等價積分方程構造差分格式,關鍵是用不同方法對積分做數(shù)值積分:ynk1通過兩種簡單的顯式單步公式去理解一般二階R-K公式。1、向前Euler公式n

nyn1

yn

hf

(x

,

y

)ynk1令:

k1

f(xn

,

yn

)yn1

yn

hk1則:K1是函數(shù)f(x,y)在左端點xn的函數(shù)近似值。向前Euler可看作用左矩形公式處理積分 得到的最簡單的差分公式。2、改進Euler公式2n

nnnn

nn1

ny

y

h

[

f

(x

,

y

)

f

(x

h,

y

hf

(x

,

y

))]若令:k1

f

(xn

,

yn

)

hk1

)k2

f

(xn

h,

ynynk11

1

yn1

yn

h[

k1

k2

]

2

2容易看出,K1仍是f(x,y)在左端點xn的函數(shù)近似值,以紅點為標識;而K2則可看作f(x,y)在右端點xn+1的函數(shù)近似值。因此,改進Euler公式可以看作用梯形積分方法近似處理積分而左、右點函數(shù)近似值為K1與K2所給出。將上述數(shù)值積分處理積分方程中積分 的思想一般化可在以下兩方面加以推廣,從而給出一般二階公式的約定:

h(C1K1

C2

K2

)

yn1

yn1

n

nn2

n

21

1K

2K

f

(x

,y

)

f

(x

h,y

hk

)2n1

n

y

y

h[

1

k

1

k

]12

2k1

f

(xn

,

yn

)12C1

C2

2k

f

(xn

h,

yn

hk1)221

1

h(C1K1

C2

K2

)

yn1

yn

1n

n

2

nK

f

(x

,y

),K

f

(x

h,y

hk

)2

n

21

1與前面向前Euler與改進Euler公式相比,所作兩點擴展表現(xiàn)在:(1)K2的擴展從圖中看出:22

h

(xn

,

xn1

],

0

1K2可以取

(xn

,

xn1

]

中任一點:

xn(2)K1與K2的線性組合,(或理解為數(shù)值積分公式的擴展,不僅局限于左矩陣或梯形積分模式)。引入線性組合系數(shù)C1與C2,在一般二階R-K公式中含2

,21

,C1,C24個待定常數(shù)。二、由Tayler展開定

2

,21

,C1,C2目標是適當選擇四個待定參數(shù),使yn+1在xn的Taylor展開,具有與y(xn+1)在xn的直接Taylor展開有盡可能高的相同的階,也就是使yn+1的階數(shù)盡可能高。為 推導時

寫 ,令:yn

y(xn

),fn

f

(xn

,

y(xn

))

f

(xn

,

yn

)局部截斷誤差可以寫為:nnTn1

(xn1

)

h[C1

(xn

,

n

)

C2(xn

2h,

21h

n

)]f(x,y)作二元函數(shù)在局部截斷誤差表達式中,先看最后一Taylor展開:(xn

2h,

h

n

h

)

'

x

'

xn

h

O

h2n

21

n

n

x

n

n

2

y

21

n三那么,局部截斷誤差展開式前出現(xiàn)

fn,fx

'

h,fy

'

fnh三

應表達為:C2

f

xn

2h,

yn

21hfnTn1y(xn1

)

yn

h[C1

f

(xn

,

ynh

2h

3Tn1

yn

hyn

2yn

y3!

n

yn

O

h2

C1hfn

C2h fn

fx

'2h

fy

'

21hfny

'n

fn其中:dxy

d

f

(x

,

y(x

))

f'

(x

,

y

)

f

'

(x

,

y

)

y(x

)n

nn

x

n

n

y

n

n

n

f

'

(x

,

y

)

f

'

(x

,

y

)

fx

n

n

y

n

n

n

f

'x

f

'y

fn(P287,(3.8))合并:fn,fx

'h,fy

'fnh

三f

y

'

fn

代入Tn+1表達式,依h

2

h

2Tn1

hfn

2

fx

'

2C1hfnx2

21

y

nh2C2h

n

C22'

h2

C'

212

22

2

x2

21

y

n)

f

'

f

h2

(1

C1

C2

)

fnh

(

C

)

f

'

h

(

1

C

O(h3

)2

2要使Runge-Kutta公式具有2階精度,應有:1

C1

C2

01

C

0

2(3.9)2

211

C

02三個方程定4個未知數(shù),解不唯一,可以得到一族二階R-K公式,比如:改進Euler公式是當:2

21

11

22C

C

1—

R-K公式,類似可以構造許多其它二階R-K公式。.

.

顯式Runge-Kutta

一回到微分方程的等價積分方程形式:nxf

(t,y(t))dtxn1y(xn1

)

y(xn

)

構造相應差分格式:ri1yn1

yn

h

Ci

Ki

yn

h(C1K1

C

r

Kr)其中:K1

f

xn

,

yni1i

2,

rKi

f

(xn

ih,yn

h

ijk

j

)j

1稱為r階Runge-Kutta法一般形式。從以下的略圖理解R-K公式一般形式的構造思想:…通過f(x,y)在r個點上函數(shù)近似值做數(shù)值積分,而數(shù)值積分公式的系數(shù)是待定的:C1,……,Cr。括,用數(shù)值積分近似積分xnf(t,

y(t))dtxn11

1

2

2

r

rh[C

k

C

K

C

K

]其中,兩個因素是待定的:i1j

1yn

h

ijk

jxn

ih,(1)ki

fi即所取作數(shù)值積分的函數(shù)值為待定。(2)C1,……,Cr,即數(shù)值積分公式待定。通過引入大量待定常數(shù),使之達到盡可能高的階數(shù)。類似二階顯式R-K公式的構造與推導,可以構造高階R-K公式。9.3.3

三階與四階R-K公式(了解公式即可)從P288~289看到,在使用三階、四階R-K公式時,

一所需計算

f(x,

y)

函數(shù)值的次數(shù)分別為3次及4次,下面有關于R-K公式階數(shù)與函數(shù)值計算的表:R-K階數(shù)≤45計算次數(shù)≤4697…….因此,一般取R-K公式≤6階。第9

章課后練習(21)作業(yè):九8、11、12§

.

單步法的收斂性與穩(wěn)定性9.4.1

收斂性與相容性一、單步法的收斂性先通過一個簡單例子,直觀了解一下收斂性的概念。例:用逐次二分積分步長的向前Euler法求解。

y

'

y

0

x

T

y(0)

y0其準確解為:y

y(x)

e

xo相應圖形如下:積分區(qū)間內任一固定點C:0≤c≤Tc那么,積分曲線在這點的值為:y(c)

y0e下面 使用逐次二分積分步長的向前Euler公式積分上述初值問題時,當積分步長越來越小時,c點處函數(shù)近似值的變化情況:(1)將[0,c]分作n等分,則積分步長n

nh

c

0

c(2)取—定n值,從x0出發(fā),用向前Euler一步一步積到c,可得C點近似的函數(shù)值yn。yn1

yn

hf

(xn

,

yn

)如,n=1n=2n=4y1y2y4……可得y(c)的近似值序列

yn,n

2

,k為整數(shù)。kn

on

k

lim

y

y(c)

y

ec從圖上看出題收斂。稱向前Euler式積分上述初值問強調一點:在收斂性概念里,c是積分區(qū)間任一相對固定的:

x0

c

T

,它不隨積分步數(shù)或積分步長的變化而變化。這點十分重要,下面給出收斂性定義。n

,

h)定義3,若一種數(shù)值方法(如單步法

yn1

yn

h(xn

,

),

k

時,yn

y(c)

稱該方對于固定的xn

xo

nh

c法是收斂的。這里對書上定義作兩點修改和說明,以避

上。

nh(1)xn

x0改為xn

xo

nh

c

,強調是固定點c。(2)ynn

y(x

)h0

n改為

n

h0

,會更確切些。y

n

y(c)書上的表述不很嚴格,h~n是存在關系的,當h0時,應

n

。但一方面

n

,另一方面極限結果仍含n,不夠嚴格。下面顯式單步法的收斂性。有P階精度,且增定理3,設顯式單步法yn1

yn

hxn

,

yn

,

h量函數(shù),關于y滿足Lipshitz條件:(x,

y,

h)

(x,

y,

h)

L

y

y

y(x0

)又設初值y0是準確的,即

yo

,由其整體截斷誤差為:py(xn

)

yn

O(h

)一下。在證明前,將一些相關概念及定理結論、條件1、局部截斷誤差與整體截斷誤差有幾個相關符號再明確一下:y(xn1

)——積分曲線

y(x)

xn1

準確值。yn1——

yn1

y(xn

)

h(xn

,

y(xn

),

h),即設:yn

y(xn

)準確,顯式單步法積分一步至的準確值。xn1,從x0出發(fā),顯式單

h

xn

,

yn

,

h——

yn1

ynyn1步公式逐步積分至xn+1

的準確值。這里注意:yn1

與yn1

的不同含義,因此,——局部截斷誤差,前進一步誤差。y(xn1

)

yn1en1

y(xn1

)

yn1——整體截斷誤差,各步誤差的積累??梢詮膱D上理解這兩種截斷誤差的含義以及它們之間的關系:y=Tn+1y(xn)ynn12、證

思再把定理條件與結論強調一下:條件:(a)

y(xn1

)

yn1

O(hp1

),P階精度。,即增量函數(shù)關于y(b)(x,

y,

h)

(x,

y,

h)L

y

y滿足Lipschitz條件。(c)

yo

y(x0

)

,即y0準確。即整體截斷誤差不超過h的P階小y(x

)

y

O(hp

)n1

n1量。結論:概括地說,定理給出局部截斷誤差的條件以及其它有關條件,而結論是要求整體截斷誤差應當滿足的關系。因此,應當將整體截斷誤差與局部截斷誤差聯(lián)系起來:y(xn1

)

yn1

y(xn1

)

yn1

yn1

yn1

y(xn1

)

yn1

yn1

yn1其中,第一 為局部截斷誤差,其誤差界是清楚的,問題在第二 的估計。3、證明分別對一、二兩 估計:ny(xn1

)

yn1

Chp1yn1

yn1(xn

),

h

n

,

h

y(xn

)

h(xn

,

h

xn

,

y(xn

)

yn

h

(xn

,

y(xn

),

h)

(xn

,

yn

,

h)y(xn

)

yn

L

y(xn

)

yn

(1

hL

)

y(xn

)

yn使用前面引入的整體截斷誤差記號,有n1e

(1

hL

)

en

chp1是整全截斷誤差的遞推公式,反復遞推:n

n

1e

1

hL

e

chp1

(1

hL

)[(1

hL

)+

en

2

chp1

]

chp1=(1

hL)2

en

2

chp1[1+(1+hL

)]nnchp

(1

hL

)ne

chp1[1

(1

hL

)++

1

+

hLn-1)]o

(1

hL

)

eo [(1

hL

)

1]L請看P292推導:(1

hL

)n

(ehL

)n

eTL其中,T為積分區(qū)間總長度。因此,整體截斷誤差上界為:n0Le

e eTL

ch

p

(eTL1)nnnLe

y(x

)

y

ch

p

(eTL1)

O(h

p

)如何應用定理1

一個顯式單步法積分一個具體問題的收斂性,必須對方法的階、以及增量函數(shù)是否對y滿足Lipschiz條件加以分析。P292以改進Euler

法為例對其改斂性作了分析,希望大家掌握它,再給一個思考題:思考:

y

'

f

(x,

y)

y(x

)

y

0設f

(x,y)對y滿足Lipschiz條件,y=y(xo

)準確,證明:用P289(3.

)公式做數(shù)值積分時收斂。二、相容性定義4,若單步法yn1

yn

h(xn

,yn

,h)的增量函數(shù)滿足:(x,y,0)

f

(x,y)

,則稱單步法與初值問題:

y

'(x)

f

(x,y)

相容

y(x

)

y

o

oP291從顯式單步法局部截斷誤差關于積分步長h的Taylor展開引出相容性概念。

也可以從另一個角度理解相容性含義。設顯式單步法:

h(xn

,

yn

,

h)yn1

yn與初值問題:

y

'(x)

f

(x,

y)

y(x

)

y

o

o相容

Tn1

O(hp1

),

p

1若把單步法改寫為:

yn1

ynn

n

(x

,

y

,

h)h兩邊取極限

h

0

有:

y

'(xn

)

(xn

,

yn

,

0)

f

(xn

,

yn

)這表明:h

0

時,顯式單步法格式趨于微分方程本身。這是相容性的直觀意義。(1.1)和(1.2)相容的充分必要條件是P1。定理4,p

階方法

yn1

yn

h

xn

,

yn

,

h

(4.1)與初值問題9.4.2

絕對穩(wěn)定性與絕對穩(wěn)定域穩(wěn)定性是差分方程求解常微分方程另一個重要理論問題,它研究差分方程對誤差的性質。它的含義是在積分步長相對固定的條件下,若在某一步引入誤差,在繼續(xù)遞推過程中,這個引入的誤差會如何?它的性質與什么因素有關?如何防止和控制誤差的惡性增長?這些都是穩(wěn)定性所關心的問題。絕對穩(wěn)定性是穩(wěn)定性概念中比較常用、比較基本和經典的。一、例

及通過一個例子,了解穩(wěn)定性概念和它的基本含義。例4

初值問題:y

100

yy(0)

0為了使問題更直接、更簡單,這里把例中初值1改為

o

,即初值本身就表現(xiàn)為引入的某種誤差。 分別后Euler

求解這初值問題時表現(xiàn)的不同現(xiàn)象。向前與向積分曲線,即準確解是:y(x)

oe

100

x(1)向前Euleryn1

yn

h(100

yn

)

1.5yn因此,當

yo

o

,h=0.025時y1

1.5oy2

2.25o己放大到P294

表9-4列出向前Euler積分至0.1時,初值的

05.0625

,即放大了5倍多。0h

0.0254-4(2)向后Euleryn1

yn

h(100

yn1

)

yn

2.5

yn113.5nyn1y

看P394:表9-4第3例數(shù)據,給出了向后Euler以0.025步長積分同一問題的數(shù)值結果,在圖上可以看出,初值時引入的誤差

0

,在隨后各步遞推計算過程中,逐漸而這于0,說明初始誤差受到控制。這個例子表現(xiàn)了向前Euler

與向后Euler不同的誤差

性質,下面給出定義。法是穩(wěn)定的。用符號表示為定義5,

若一種數(shù)值方法在節(jié)點值yn上有大小為

的擾動,于以后各節(jié)點值ym

(m

n)

上產生的偏差均不超過

,則稱該方m

n(m

n)有很大,通常要簡化對象,穩(wěn)定性問題的一般性并稱之為模型問題。二、模型方程y

y,

C,稱

Re()

0

為模型方程。在模型方程中,假設

Re()

0

是為了使模型問題y

yy(xo

)

yo穩(wěn)定準 為:

(x)

(

x

)0e

x0模型問題的初值受到擾動時,對模型問題的解產生影響:如果初值擾動產生的影響能逐漸是穩(wěn)定的,反之是不穩(wěn)定的。下面說明Re

()

0

保證模型問題穩(wěn)定。設,有一初值受到擾動的模型問題:y

yy(xo

)

yo

o是與前面給出的模型問題完全相同的系統(tǒng),區(qū)別僅在于后,其準確解為:者在初值帶有誤差0y

(x)

(

yo

(

x

x

)

o

)e

o那么:e

(

x

xo

)(x)

(x)

oeRe(

)(

x

xo

)

oy(x)

y(x)

當:Re()

oRe()

o穩(wěn)定不穩(wěn)定y(x)

y(x)

三、顯式單步法公式穩(wěn)定性1

、向前Euler公式模型方程的向前Euler公式為:yn1

yn

h

yn

(1

h)

yn記第n步,帶有誤差的解為:yn

*

ynnnnn1遞推一步有:y

(x

h)

y

(1

h)(

y

)n

yn1

(1

h)n

(1

h)

n即遞推一步的誤差為:n1n1n1

y

yn1

1

h

n即:這是向前Euller

公式對誤差或擾動的遞推關系式,而且可以看出,誤差 的關系式與原來的差分格式完全相同。若要求誤差不增長,即1

h

1

n1

yn1

n

yn稱

1

h

1

為向前Euler的絕對穩(wěn)定域。=h平面定義6,單步法

yn1

yn

h(xn

,

yn

,

h)

用于的模型方程y

y

(Re()

o)

1

,則稱單步法是絕對穩(wěn)定稱為絕對穩(wěn)定域,它與實軸的滿足

E

hE(h)

1若得到的解yn1

E(h)yn的。在h

平面上,區(qū)域交稱絕對穩(wěn)定區(qū)間。所以,對向Euler公式,絕對穩(wěn)定區(qū)間是:2

h

Re()

0

0

h

2

o

R回到例4

100,

2

100h

0應有

0

h

2

0.02100是其絕對穩(wěn)定區(qū)間。因此,當取0.025時是不穩(wěn)定的。2、二階R-K公式(

.

)關鍵是推導模型方程下的二階R-K公式:K1

yn

h2

h

y

)

y2K2

(

yn2nnyn(h)22

hk

h2nnn那么:n1y

yn)

ynh

2

(1

h

2h

2

E(h)

1

h

2因此,絕對穩(wěn)定區(qū)域為:2h

21

h

1三、四階R-K方法自己推導一下相應的表達式四、隱式單步法穩(wěn)定性1.向后Euler公式模型方程的向后Euler公式為:yn1

yn

h

yn1因此,1nyn1y

1

h=h11

h即,

E(h)

1絕對穩(wěn)定域為:1

h

1絕對穩(wěn)定區(qū)間:

h

Re()

00

h

,

0

R即對任意積分步長,向后Euler公式穩(wěn)定(無條件穩(wěn)定)2.

(P296,

)同樣地,

0

R

其絕對穩(wěn)定區(qū)間為:

o

h

,

0

Rh

Re(h)

0定義7

,如果數(shù)值方法的絕對穩(wěn)定域包含了那么稱此方法是A-穩(wěn)定的。由定義可知,A-隱定的方法對步長h

沒有限制。小結:一般而言,隱式公式的穩(wěn)定性優(yōu)于顯式公式,對單步法或多步法都是成立的。這是選擇數(shù)值積分公式時應當考慮的因一?!?/p>

.

線性與步法前面己比較詳細地介紹了多種單步法:顯式、隱式。他們都有廣泛的應用,主要的優(yōu)缺點是:優(yōu)點:1、自啟動,或稱自開始。只要給出初值y0按差分公式即可一步一步遞推地計算。逐次地求出y1,y22、易于改變步長缺點:1、低階公式精度低,而高階公式計算量大。上節(jié)課曾 ,以計算

f

(x,

y)

函數(shù)值次數(shù)作為計算一個衡量標準時,5階R-K

有6次計算量,6階R-K公式有7次計算量。為了克服單步法存在的上述缺點,希望能構造出精度高,計算量小的誤差公式。它的基本思想是:“求yn+1時,充分利用如下信息:y

,

y

,ynn n

1

kf

n

,

f

n

1

,以構造線性多步積分f

n

公k

式,其中,k>0,即為k步法。”線性多步公式的構造方法同樣有三種:基于數(shù)值微分、數(shù)值積分以及Taylor

展開的方法。本書僅介紹基于Taylor

展開方法,下面著重介紹基于Taylor展開法。對基于數(shù)值積分構造方法略做介紹。9.5.1

線性多步法的一般公式概括地說,基于Taylor展開構造線性多步公式是一種“待定常數(shù)法”。與R-K公式的構造原理、方法完全相同。可分兩步:第一步是設定帶若干待定常數(shù)的線性多步公式的一般形式,第二步可由Taylor展開定出特定常數(shù),具體實現(xiàn)如下。一、一般線性多步法公式的約定時,利用計算ynk,

ynfnfnk

,ynk

1,fnk

1,ynk

2

,fnk

2,其中,yni

y(xni),fni

f

(xni

,ni

)xni

xn

ih做線性組合可構造出如下帶待定常數(shù)的一般線性多步公式:(P360,

5.1)k

1

kyn

k

i

yn

i

h

i

fn

ii

0

i

0k

0

顯式

k步法

0

隱式k步法二、由Taylor展開定義首先介紹線性多步法局部截斷誤差及階的定義。y

f

(x,

y)定義8,y(x)設是初值問題的準確解,線性多步上的局部截斷誤差為:y(x0

)

y0公式(5.1)在xnkTnkk

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論