赞
踩
本文着重讨论一阶常微分方程初值问题:
{
y
′
=
f
(
x
,
y
)
y
(
x
0
)
=
y
0
的数值解法。
初值问题简介:一阶常微方程初值问题:
{
d
y
d
x
=
f
(
x
,
y
)
,
x
∈
[
a
,
b
]
y
(
a
)
=
y
0
解的存在唯一性问题:设
x
0
∈
[
a
,
b
]
,
f
(
x
,
y
)
x_0\in[a,b],f(x,y)
x0∈[a,b],f(x,y) 对
x
x
x 连续且关于
y
y
y 满足利普希茨条件:存在常数
L
L
L,使
∀
x
∈
[
a
,
b
]
\forall x\in[a,b]
∀x∈[a,b] 及任何实数
y
1
,
y
2
y_1,y_2
y1,y2,有
∣
f
(
x
,
y
1
)
−
f
(
x
,
y
2
)
∣
≤
L
∣
y
1
−
y
2
∣
|f(x,y_1)-f(x,y_2)|\leq L|y_1-y_2|
∣f(x,y1)−f(x,y2)∣≤L∣y1−y2∣
则上述初值问题在
[
a
,
b
]
[a,b]
[a,b] 上存在唯一解。
解的适定性问题:
定义:称上述初值问题对初始值 y 0 y_0 y0 和函数 f ( x , y ) f(x,y) f(x,y) 是适定的,如果存在常数 K > 0 , η > 0 K>0,\eta>0 K>0,η>0,对任意 0 < ε < η 0<\varepsilon<\eta 0<ε<η,当
∣ y 0 − y ~ 0 ∣ < ε ∣ f ( x , y ) − f ~ ( x , y ) ∣ < ε ∀ ( x , y ) ∈ [ x 0 , b ] × ( − ∞ , ∞ ) |y_0-\tilde y_0|<\varepsilon\\|f(x,y)-\tilde f(x,y)|<\varepsilon\\\forall(x,y)\in[x_0,b]\times(-\infin,\infin) ∣y0−y~0∣<ε∣f(x,y)−f~(x,y)∣<ε∀(x,y)∈[x0,b]×(−∞,∞)
时,初值问题
{ z ′ = f ~ ( x , z ) , x 0 ≤ x ≤ b z ( x 0 ) = y ~ 0{z′=f~(x,z),x0≤x≤bz(x0)=y~0{z′=f~(x,z),x0≤x≤bz(x0)=y~0
的解存在,且
∣ y ( x ) − z ( x ) ∣ ≤ K ε |y(x)-z(x)|\leq K\varepsilon ∣y(x)−z(x)∣≤Kε
定理:假设 f ( x , y ) f(x,y) f(x,y) 在 [ x 0 , b ] × ( − ∞ , ∞ ) [x_0,b]\times(-\infin,\infin) [x0,b]×(−∞,∞) 上对 y y y 满足利普希茨条件,则初值问题是适定的。
初值问题:
{
y
′
=
f
(
x
,
y
)
y
(
x
0
)
=
y
0
的解
y
=
y
(
x
)
y=y(x)
y=y(x) 代表通过点
(
x
0
,
y
0
)
(x_0,y_0)
(x0,y0) 的一条曲线,称为微分方程的积分曲线。积分曲线上每一点
(
x
,
y
)
(x,y)
(x,y) 的切线的斜率
y
′
(
x
)
y'(x)
y′(x) 等于函数
f
(
x
,
y
)
f(x,y)
f(x,y) 在这点的值。
几何意义:欧拉法是过点 ( x 0 , y 0 ) (x_0,y_0) (x0,y0) 作曲线的切线与 x 1 x_1 x1 交于点 ( x 1 , y 1 ) (x_1,y_1) (x1,y1),用 y 1 y_1 y1 作为曲线 y ( x ) y(x) y(x) 上的点 ( x 1 , y ( x 1 ) ) (x_1,y(x_1)) (x1,y(x1)) 的纵坐标 y ( x 1 ) y(x_1) y(x1) 的近似值。
过
(
x
0
,
y
0
)
(x_0,y_0)
(x0,y0) 以
f
(
x
0
,
y
0
)
f(x_0,y_0)
f(x0,y0) 为斜率的切线方程:
y
−
y
0
=
f
(
x
0
,
y
0
)
(
x
−
x
0
)
y-y_0=f(x_0,y_0)(x-x_0)
y−y0=f(x0,y0)(x−x0)
当
x
=
x
1
x=x_1
x=x1 时,得
y
1
=
y
0
+
f
(
x
0
,
y
0
)
(
x
1
−
x
0
)
y_1=y_0+f(x_0,y_0)(x_1-x_0)
y1=y0+f(x0,y0)(x1−x0)
取
y
1
y_1
y1 作为解
y
(
x
1
)
y(x_1)
y(x1) 的近似值,之后再过点
(
x
1
,
y
1
)
(x_1,y_1)
(x1,y1) 以
f
(
x
1
,
y
1
)
f(x_1,y_1)
f(x1,y1) 为斜率作直线
y
−
y
1
=
f
(
x
1
,
y
1
)
(
x
−
x
1
)
y-y_1=f(x_1,y_1)(x-x_1)
y−y1=f(x1,y1)(x−x1)
以此类推,一般地,已求得点
(
x
i
,
y
i
)
(x_i,y_i)
(xi,yi),以
f
(
x
i
,
y
i
)
f(x_i,y_i)
f(xi,yi) 为斜率作直线
y
−
y
i
=
f
(
x
i
,
y
i
)
(
x
−
x
i
)
y-y_i=f(x_i,y_i)(x-x_i)
y−yi=f(xi,yi)(x−xi)
当
x
=
x
i
+
1
x=x_{i+1}
x=xi+1 时,得
y
i
+
1
=
y
i
+
f
(
x
i
,
y
i
)
(
x
i
+
1
−
x
i
)
y_{i+1}=y_i+f(x_i,y_i)(x_{i+1}-x_i)
yi+1=yi+f(xi,yi)(xi+1−xi)
取
y
(
x
i
+
1
)
≈
y
i
+
1
y(x_{i+1})\approx y_{i+1}
y(xi+1)≈yi+1,这样就可算出一系列数值解
y
1
,
y
2
,
⋯
,
y
n
y_1,y_2,\cdots,y_n
y1,y2,⋯,yn。
通常取
x
i
+
1
−
x
i
=
h
i
=
h
x_{i+1}-x_i=h_i=h
xi+1−xi=hi=h,则计算格式为:
{
y
i
+
1
=
y
i
+
h
f
(
x
i
,
y
i
)
x
i
=
x
0
+
i
h
,
i
=
0
,
1
,
2
,
⋯
数值微分和数值积分等的角度:在
x
i
x_i
xi 点微分方程:
y
′
(
x
i
)
=
f
(
x
i
,
y
(
x
i
)
)
y'(x_i)=f(x_i,y(x_i))
y′(xi)=f(xi,y(xi))
用差商
y
(
x
i
+
1
)
−
y
(
x
i
)
h
\frac{y(x_{i+1})-y(x_i)}{h}
hy(xi+1)−y(xi) 代替其中的导数项
y
′
(
x
i
)
y'(x_i)
y′(xi),即
y
′
(
x
i
)
≈
y
(
x
i
+
1
)
−
y
(
x
i
)
h
y
(
x
i
+
1
)
≈
y
(
x
i
)
+
h
y
′
(
x
i
)
=
y
(
x
i
)
+
h
f
(
x
i
,
y
(
x
i
)
)
y'(x_i)\approx\frac{y(x_{i+1})-y(x_i)}{h}\\y(x_{i+1})\approx y(x_i)+hy'(x_i)=y(x_i)+hf(x_i,y(x_i))
y′(xi)≈hy(xi+1)−y(xi)y(xi+1)≈y(xi)+hy′(xi)=y(xi)+hf(xi,y(xi))
用
y
=
y
(
x
i
)
y=y(x_i)
y=y(xi) 的近似值
y
i
y_i
yi 代入上式右端,记所得结果为
y
i
+
1
y_{i+1}
yi+1,就有:
y
i
+
1
=
y
i
+
h
f
(
x
i
,
y
i
)
,
i
=
0
,
1
,
⋯
,
n
−
1
y_{i+1}=y_i+hf(x_i,y_i),i=0,1,\cdots,n-1
yi+1=yi+hf(xi,yi),i=0,1,⋯,n−1
上述也称显式欧拉公式或向前欧拉公式。
若将方程
y
′
=
f
(
x
,
y
)
y'=f(x,y)
y′=f(x,y) 的两端从
x
n
x_n
xn 到
x
n
+
1
x_{n+1}
xn+1 求积分
∫
x
n
x
n
+
1
y
′
d
x
=
∫
x
n
x
n
+
1
f
(
x
,
y
(
x
)
)
d
x
y
(
x
n
+
1
)
=
y
(
x
n
)
+
∫
x
n
x
n
+
1
f
(
x
,
y
(
x
)
)
d
x
\int_{x_n}^{x_{n+1}}y'dx=\int_{x_n}^{x_{n+1}}f(x,y(x))dx\\y(x_{n+1})=y(x_n)+\int_{x_n}^{x_{n+1}}f(x,y(x))dx
∫xnxn+1y′dx=∫xnxn+1f(x,y(x))dxy(xn+1)=y(xn)+∫xnxn+1f(x,y(x))dx
用左矩形计算积分项:
∫
x
n
x
n
+
1
f
(
x
,
y
(
x
)
)
d
x
≈
h
f
(
x
n
,
y
(
x
n
)
)
\int_{x_n}^{x_{n+1}}f(x,y(x))dx\approx hf(x_n,y(x_n))
∫xnxn+1f(x,y(x))dx≈hf(xn,y(xn)),代入上式得
y
(
x
n
+
1
)
≈
y
(
x
n
)
+
h
f
(
x
n
,
y
(
x
n
)
)
y(x_{n+1})\approx y(x_n)+hf(x_n,y(x_n))
y(xn+1)≈y(xn)+hf(xn,y(xn))
泰勒展开:对
y
(
x
n
+
1
)
y(x_{n+1})
y(xn+1) 在
x
n
x_n
xn 处按二阶泰勒展开有
y
(
x
n
+
1
)
=
y
(
x
n
+
h
)
=
y
(
x
n
)
+
h
y
′
(
x
n
)
+
1
2
!
h
2
y
′
′
(
ε
n
)
,
x
n
≤
ε
n
≤
x
n
+
1
y
(
x
n
+
1
)
≈
y
(
x
n
)
+
h
y
′
(
x
n
)
=
y
(
x
n
)
+
h
f
(
x
n
,
y
(
x
n
)
)
y(x_{n+1})=y(x_n+h)=y(x_n)+hy'(x_n)+\frac{1}{2!}h^2y''(\varepsilon_n),x_n\leq\varepsilon_n\leq x_{n+1}\\y(x_{n+1})\approx y(x_n)+hy'(x_n)=y(x_n)+hf(x_n,y(x_n))
y(xn+1)=y(xn+h)=y(xn)+hy′(xn)+2!1h2y′′(εn),xn≤εn≤xn+1y(xn+1)≈y(xn)+hy′(xn)=y(xn)+hf(xn,y(xn))
用近似值
y
n
y_n
yn 代替
y
(
x
n
)
y(x_n)
y(xn),有
y
n
+
1
=
y
n
+
h
f
(
x
n
,
y
n
)
y_{n+1}=y_n+hf(x_n,y_n)
yn+1=yn+hf(xn,yn)
定义1:在 y i y_i yi 准确的前提下,即 y j = y ( x j ) ( j ≤ i ) y_j=y(x_j)(j\leq i) yj=y(xj)(j≤i) 时,用数值方法计算 y i + 1 y_{i+1} yi+1 误差
R i + 1 = y ( x i + 1 ) − y i + 1 R_{i+1}=y(x_{i+1})-y_{i+1} Ri+1=y(xi+1)−yi+1
称为该数值方法计算 y i + 1 y_{i+1} yi+1 时的局部截断误差。
定义2:若一个数值方法的局部截断误差为 O ( h p + 1 ) O(h^{p+1}) O(hp+1),则称这种数值方法的阶数是 p p p。显然,步长 h ( < 1 ) h(<1) h(<1) 越小, p p p 值越高,则局部截断误差越小,计算精度越高。
欧拉法的局部截断误差:假定
y
i
=
y
(
x
i
)
y_i=y(x_i)
yi=y(xi),则有
y
i
+
1
=
y
(
x
i
)
+
h
f
(
x
i
,
y
(
x
i
)
)
=
y
(
x
i
)
+
h
y
′
(
x
i
)
y_{i+1}=y(x_i)+hf(x_i,y(x_i))=y(x_i)+hy'(x_i)
yi+1=y(xi)+hf(xi,y(xi))=y(xi)+hy′(xi)
二阶泰勒公式:
y
(
x
i
+
1
)
=
y
(
x
i
+
h
)
=
y
(
x
i
)
+
h
y
′
(
x
i
)
+
h
2
2
y
′
′
(
ζ
i
)
,
x
i
<
ζ
i
<
x
i
+
1
R
i
+
1
=
y
(
x
i
+
1
)
−
y
i
+
1
=
h
2
2
y
′
′
(
ζ
i
)
y(x_{i+1})=y(x_i+h)=y(x_i)+hy'(x_i)+\frac{h^2}{2}y''(\zeta_i),x_i<\zeta_i<x_{i+1}\\R_{i+1}=y(x_{i+1})-y_{i+1}=\frac{h^2}{2}y''(\zeta_i)
y(xi+1)=y(xi+h)=y(xi)+hy′(xi)+2h2y′′(ζi),xi<ζi<xi+1Ri+1=y(xi+1)−yi+1=2h2y′′(ζi)
如果
y
(
x
)
y(x)
y(x) 有三阶导数,则:
R
i
+
1
=
y
(
x
i
+
1
)
−
y
i
+
1
=
h
2
2
y
′
′
(
x
i
)
+
h
3
6
y
′
′
′
(
ζ
i
)
R_{i+1}=y(x_{i+1})-y_{i+1}=\frac{h^2}{2}y''(x_i)+\frac{h^3}{6}y'''(\zeta_i)
Ri+1=y(xi+1)−yi+1=2h2y′′(xi)+6h3y′′′(ζi)
欧拉法的局部截断误差为
O
(
h
2
)
O(h^2)
O(h2),欧拉方法为一阶方法。
设改用向后差商
1
h
(
y
(
x
i
+
1
)
−
y
(
x
i
)
)
\frac{1}{h}(y(x_{i+1})-y(x_i))
h1(y(xi+1)−y(xi)) 替代方程
y
′
(
x
i
+
1
)
=
f
(
x
i
+
1
,
y
(
x
i
+
1
)
)
y'(x_{i+1})=f(x_{i+1},y(x_{i+1}))
y′(xi+1)=f(xi+1,y(xi+1)) 中的导数项
y
′
(
x
i
+
1
)
y'(x_{i+1})
y′(xi+1),再离散化,可得:
y
i
+
1
=
y
i
+
h
f
(
x
i
+
1
,
y
i
+
1
)
y_{i+1}=y_i+hf(x_{i+1},y_{i+1})
yi+1=yi+hf(xi+1,yi+1)
称为向后欧拉公式(又称隐式欧拉公式)。
向后欧拉公式的显式化(迭代):
y
i
+
1
(
k
+
1
)
=
y
i
+
h
f
(
x
i
+
1
,
y
i
+
1
(
k
)
)
,
k
=
0
,
1
,
2
,
⋯
y_{i+1}^{(k+1)}=y_i+hf(x_{i+1},y_{i+1}^{(k)}),k=0,1,2,\cdots
yi+1(k+1)=yi+hf(xi+1,yi+1(k)),k=0,1,2,⋯
隐式欧拉公式的局部截断误差:
R
i
+
1
=
−
h
2
2
y
′
′
(
x
i
)
+
O
(
h
3
)
R_{i+1}=-\frac{h^2}{2}y''(x_i)+O(h^3)
Ri+1=−2h2y′′(xi)+O(h3)
两步欧拉格式:为了改善精度,改用中心差商
1
2
h
(
y
(
x
i
+
1
)
−
y
(
x
i
−
1
)
)
\frac{1}{2h}(y(x_{i+1})-y(x_{i-1}))
2h1(y(xi+1)−y(xi−1)) 替代方程
y
′
(
x
i
)
=
f
(
x
i
,
y
(
x
i
)
)
y'(x_i)=f(x_i,y(x_i))
y′(xi)=f(xi,y(xi)) 中的导数项,并取离散化得:
y
i
+
1
=
y
i
−
1
+
2
h
f
(
x
i
,
y
i
)
y_{i+1}=y_{i-1}+2hf(x_i,y_i)
yi+1=yi−1+2hf(xi,yi)
设
y
i
=
y
(
x
i
)
,
y
i
−
1
=
y
(
x
i
−
1
)
y_i=y(x_i),y_{i-1}=y(x_{i-1})
yi=y(xi),yi−1=y(xi−1),前两步准确,则对两步欧拉格式,有
y
i
+
1
=
y
(
x
i
−
1
)
+
2
h
f
(
x
i
,
y
(
x
i
)
)
y_{i+1}=y(x_{i-1})+2hf(x_i,y(x_i))
yi+1=y(xi−1)+2hf(xi,y(xi))
将
y
(
x
i
+
1
)
y(x_{i+1})
y(xi+1) 泰勒展开:
y
(
x
i
+
1
)
=
y
(
x
i
)
+
h
y
′
(
x
i
)
+
h
2
2
y
′
′
(
x
i
)
+
h
3
6
y
′
′
′
(
ζ
i
)
y
(
x
i
−
1
)
=
y
(
x
i
)
−
h
y
′
(
x
i
)
+
h
2
2
y
′
′
(
x
i
)
−
h
3
6
y
′
′
′
(
ζ
i
)
y
(
x
i
+
1
)
−
y
(
x
i
−
1
)
=
2
h
y
′
(
x
i
)
+
h
3
3
y
′
′
′
(
ζ
i
)
,
x
i
−
1
<
ζ
i
<
x
i
+
1
y(x_{i+1})=y(x_i)+hy'(x_i)+\frac{h^2}{2}y''(x_i)+\frac{h^3}{6}y'''(\zeta_i)\\y(x_{i-1})=y(x_i)-hy'(x_i)+\frac{h^2}{2}y''(x_i)-\frac{h^3}{6}y'''(\zeta_i)\\y(x_{i+1})-y(x_{i-1})=2hy'(x_i)+\frac{h^3}{3}y'''(\zeta_i),x_{i-1}<\zeta_i<x_{i+1}
y(xi+1)=y(xi)+hy′(xi)+2h2y′′(xi)+6h3y′′′(ζi)y(xi−1)=y(xi)−hy′(xi)+2h2y′′(xi)−6h3y′′′(ζi)y(xi+1)−y(xi−1)=2hy′(xi)+3h3y′′′(ζi),xi−1<ζi<xi+1
所以有
R
i
+
1
=
y
(
x
i
+
1
)
−
y
i
+
1
=
h
3
3
y
′
′
′
(
ζ
i
)
=
O
(
h
3
)
R_{i+1}=y(x_{i+1})-y_{i+1}=\frac{h^3}{3}y'''(\zeta_i)=O(h^3)
Ri+1=y(xi+1)−yi+1=3h3y′′′(ζi)=O(h3)
所以这是一种二阶方法。
梯形公式和改进的欧拉方法:将方程
y
′
=
f
(
x
,
y
)
y'=f(x,y)
y′=f(x,y) 的两端从
x
i
,
x
i
+
1
x_i,x_{i+1}
xi,xi+1,求积分得
y
(
x
i
+
1
)
=
y
(
x
i
)
+
∫
x
i
x
i
+
1
f
(
x
,
y
(
x
)
)
d
x
y(x_{i+1})=y(x_i)+\int_{x_i}^{x_{i+1}}f(x,y(x))dx
y(xi+1)=y(xi)+∫xixi+1f(x,y(x))dx
用梯形方法代替矩形方法:
∫
x
i
x
i
+
1
f
(
x
,
y
(
x
)
)
d
x
≈
h
2
[
f
(
x
i
,
y
(
x
i
)
)
+
f
(
x
i
+
1
,
y
(
x
i
+
1
)
)
]
\int_{x_i}^{x_{i+1}}f(x,y(x))dx\approx\frac{h}{2}[f(x_i,y(x_i))+f(x_{i+1},y(x_{i+1}))]
∫xixi+1f(x,y(x))dx≈2h[f(xi,y(xi))+f(xi+1,y(xi+1))]
离散化之后的结果为:
y
i
+
1
=
y
i
+
h
2
[
f
(
x
i
,
y
i
)
+
f
(
x
i
+
1
,
y
i
+
1
)
]
y_{i+1}=y_i+\frac{h}{2}[f(x_i,y_i)+f(x_{i+1},y_{i+1})]
yi+1=yi+2h[f(xi,yi)+f(xi+1,yi+1)]
梯形公式显式化:
{
y
i
+
1
(
0
)
=
y
i
+
h
f
(
x
i
,
y
i
)
y
i
+
1
(
k
+
1
)
=
y
i
+
h
2
[
f
(
x
i
,
y
i
)
+
f
(
x
i
+
1
,
y
i
+
1
(
k
)
)
]
,
k
=
0
,
1
,
2
,
⋯
用
∣
y
i
+
1
(
k
+
1
)
−
y
i
+
1
(
k
)
∣
≤
ε
|y_{i+1}^{(k+1)}-y_{i+1}^{(k)}|\leq\varepsilon
∣yi+1(k+1)−yi+1(k)∣≤ε 控制迭代次数,其中
ε
\varepsilon
ε 为允许误差,把满足误差要求的
y
i
+
1
(
k
+
1
)
y_{i+1}^{(k+1)}
yi+1(k+1) 作为
y
(
x
i
+
1
)
y(x_{i+1})
y(xi+1) 的近似值
y
i
+
1
y_{i+1}
yi+1。
在实用上,当
h
h
h 取值较小,先用欧拉格式得一个初步近似值
y
i
+
1
(
0
)
y_{i+1}^{(0)}
yi+1(0),称之为预估值,预估值的精度不高,用它替代梯形法右端的
y
i
+
1
y_{i+1}
yi+1,再直接计算出
y
i
+
1
y_{i+1}
yi+1,并称之为校正值,得到改进的欧拉方法(预估—校正公式):
{
预
估
:
y
i
+
1
(
0
)
=
y
i
+
h
f
(
x
i
,
y
i
)
校
正
:
y
i
+
1
=
y
i
+
h
2
[
f
(
x
i
,
y
i
)
+
f
(
x
i
+
1
,
y
i
+
1
(
0
)
)
]
上式可以表示为嵌套形式:
y
i
+
1
=
y
i
+
h
2
[
f
(
x
i
,
y
i
)
+
f
(
x
i
+
1
,
y
i
+
h
f
(
x
i
,
y
i
)
)
]
y_{i+1}=y_i+\frac{h}{2}[f(x_i,y_i)+f(x_{i+1},y_i+hf(x_i,y_i))]
yi+1=yi+2h[f(xi,yi)+f(xi+1,yi+hf(xi,yi))]
或者表示成下列平均化形式:
{
y
p
=
y
i
+
h
f
(
x
i
,
y
i
)
y
c
=
y
i
+
h
f
(
x
i
+
1
,
y
p
)
y
i
+
1
=
1
2
(
y
p
+
y
c
)
改进的欧拉方法是二阶方法。
设
y
i
=
y
(
x
i
)
y_i=y(x_i)
yi=y(xi),将
y
(
x
i
+
1
)
y(x_{i+1})
y(xi+1) 在
x
i
x_i
xi 处展开:
y
(
x
i
+
1
)
=
y
(
x
i
+
h
)
=
y
(
x
i
)
+
h
y
′
(
x
i
)
+
h
2
2
y
′
′
(
x
i
)
+
h
3
3
!
y
′
′
′
(
x
i
)
+
.
.
.
y(x_{i+1})=y(x_i+h)=y(x_i)+hy'(x_i)+\frac{h^2}{2}y''(x_i)+\frac{h^3}{3!}y'''(x_i)+...
y(xi+1)=y(xi+h)=y(xi)+hy′(xi)+2h2y′′(xi)+3!h3y′′′(xi)+...
取上式前两项就是局部截断误差为
O
(
h
2
)
O(h^2)
O(h2) 的欧拉格式。
取前三项,可得局部截断误差为
O
(
h
3
)
O(h^3)
O(h3) 的公式:
y
(
x
i
+
1
)
≈
y
(
x
i
)
+
h
y
′
(
x
i
)
+
h
2
2
y
′
′
(
x
i
)
=
y
(
x
i
)
+
h
f
(
x
i
,
y
(
x
i
)
)
+
h
2
2
[
f
x
(
x
i
,
y
(
x
i
)
)
+
f
(
x
i
,
y
(
x
i
)
)
⋅
f
y
(
x
i
,
y
(
x
i
)
)
]
y(x_{i+1})\approx y(x_i)+hy'(x_i)+\frac{h^2}{2}y''(x_i)\\=y(x_i)+hf(x_i,y(x_i))+\frac{h^2}{2}[f_x(x_i,y(x_i))+f(x_i,y(x_i))·f_y(x_i,y(x_i))]
y(xi+1)≈y(xi)+hy′(xi)+2h2y′′(xi)=y(xi)+hf(xi,y(xi))+2h2[fx(xi,y(xi))+f(xi,y(xi))⋅fy(xi,y(xi))]
可以构造:
y
i
+
1
=
y
i
+
h
f
(
x
i
,
y
i
)
+
h
2
2
[
f
x
(
x
i
,
y
i
)
+
f
(
x
i
,
y
i
)
f
y
(
x
i
,
y
i
)
]
y_{i+1}=y_i+hf(x_i,y_i)+\frac{h^2}{2}[f_x(x_i,y_i)+f(x_i,y_i)f_y(x_i,y_i)]
yi+1=yi+hf(xi,yi)+2h2[fx(xi,yi)+f(xi,yi)fy(xi,yi)]
类似的,若取前
p
+
1
p+1
p+1 项,可得到局部截断误差为
O
(
h
p
+
1
)
O(h^{p+1})
O(hp+1) 的数值计算公式。
基本思路:用复合函数的计算来代替各阶偏导数,通过不同点的函数值组合间接使用泰勒展开来达到高阶局部截断误差的目的。
设
m
m
m 为一个正整数,称方程:
{
y
i
+
1
=
y
i
+
h
(
a
1
K
1
+
a
2
K
2
+
⋯
+
a
m
K
m
)
K
1
=
f
(
x
i
,
y
i
)
K
2
=
f
(
x
i
+
λ
2
h
,
y
i
+
μ
2
h
K
1
)
⋯
⋯
K
m
=
f
(
x
i
+
λ
m
h
,
y
i
+
μ
m
h
K
m
−
1
)
为
m
m
m 级龙格-库塔法,其中
0
≤
λ
j
≤
1
,
a
j
,
μ
j
0\leq\lambda_j\leq1,a_j,\mu_j
0≤λj≤1,aj,μj 是待定常数,由局部截断误差阶等来确定。
基本选取原则:
y
n
+
1
y_{n+1}
yn+1 的展开表达式:
y
i
+
1
=
y
i
+
a
1
h
+
1
2
!
a
2
h
2
+
1
3
!
a
3
h
3
+
⋯
y_{i+1}=y_i+a_1h+\frac{1}{2!}a_2h^2+\frac{1}{3!}a_3h^3+\cdots
yi+1=yi+a1h+2!1a2h2+3!1a3h3+⋯
y
(
x
i
+
1
)
y(x_{i+1})
y(xi+1) 在
(
x
i
,
y
i
)
(x_i,y_i)
(xi,yi) 处的泰勒展开式:
y
(
x
i
+
1
)
=
y
(
x
i
)
+
h
y
′
(
x
i
)
+
h
2
2
!
y
′
′
(
x
i
)
+
h
3
3
!
y
′
′
′
(
x
i
)
+
⋯
y(x_{i+1})=y(x_i)+hy'(x_i)+\frac{h^2}{2!}y''(x_i)+\frac{h^3}{3!}y'''(x_i)+\cdots
y(xi+1)=y(xi)+hy′(xi)+2!h2y′′(xi)+3!h3y′′′(xi)+⋯
上述两式要有尽可能多的项重合,以减小局部截断误差。
以 m = 2 m=2 m=2 为例:
{ y i + 1 = y i + h ( a 1 K 1 + a 2 K 2 ) K 1 = f ( x i , y i ) K 2 = f ( x i + λ 2 h , y i + μ 2 h K 1 )⎩⎪⎨⎪⎧yi+1=yi+h(a1K1+a2K2)K1=f(xi,yi)K2=f(xi+λ2h,yi+μ2hK1)⎧⎩⎨yi+1=yi+h(a1K1+a2K2)K1=f(xi,yi)K2=f(xi+λ2h,yi+μ2hK1)
将 K 2 K_2 K2 在 ( x i , y i ) (x_i,y_i) (xi,yi) 处泰勒展开,且 y i = y ( x i ) y_i=y(x_i) yi=y(xi),有:
y i + 1 = y i + h ( a 1 K 1 + a 2 K 2 ) = y i + a 1 h f ( x i , y i ) + a 2 h f ( x i + λ 2 h , y i + μ 2 h K 1 ) = y i + a 1 h f ( x i , y i ) + a 2 h [ f ( x i , y i ) + λ 2 h f x ( x i , y i ) + μ 2 h K 1 f y ( x i , y i ) + O ( h 2 ) ] = y i + ( a 1 + a 2 ) f ( x i , y i ) h + a 2 [ λ 2 f x ( x i , y i ) + μ 2 f ( x i , y i ) f y ( x i , y i ) ] h 2 + O ( h 3 ) y_{i+1}=y_i+h(a_1K_1+a_2K_2)\\=y_i+a_1hf(x_i,y_i)+a_2hf(x_i+\lambda_2h,y_i+\mu_2hK_1)\\=y_i+a_1hf(x_i,y_i)+a_2h[f(x_i,y_i)+\lambda_2hf_x(x_i,y_i)+\mu_2hK_1f_y(x_i,y_i)+O(h^2)]\\=y_i+(a_1+a_2)f(x_i,y_i)h+a_2[\lambda_2f_x(x_i,y_i)+\mu_2f(x_i,y_i)f_y(x_i,y_i)]h^2+O(h^3) yi+1=yi+h(a1K1+a2K2)=yi+a1hf(xi,yi)+a2hf(xi+λ2h,yi+μ2hK1)=yi+a1hf(xi,yi)+a2h[f(xi,yi)+λ2hfx(xi,yi)+μ2hK1fy(xi,yi)+O(h2)]=yi+(a1+a2)f(xi,yi)h+a2[λ2fx(xi,yi)+μ2f(xi,yi)fy(xi,yi)]h2+O(h3)
又:
y ( x i + 1 ) = y ( x i + h ) = y ( x i ) + h y ′ ( x i ) + h 2 2 y ′ ′ ( x i ) + O ( h 3 ) = y i + f ( x i , y i ) h + 1 2 [ f x ( x i , y i ) + f ( x i , y i ) f y ( x i , y i ) ] h 2 + O ( h 3 ) y(x_{i+1})=y(x_i+h)=y(x_i)+hy'(x_i)+\frac{h^2}{2}y''(x_i)+O(h^3)\\=y_i+f(x_i,y_i)h+\frac{1}{2}[f_x(x_i,y_i)+f(x_i,y_i)f_y(x_i,y_i)]h^2+O(h^3) y(xi+1)=y(xi+h)=y(xi)+hy′(xi)+2h2y′′(xi)+O(h3)=yi+f(xi,yi)h+21[fx(xi,yi)+f(xi,yi)fy(xi,yi)]h2+O(h3)
比较 y i + 1 、 y ( x i + 1 ) y_{i+1}、y(x_{i+1}) yi+1、y(xi+1) 的表达式,选取:
{ a 1 + a 2 = 1 a 2 λ 2 = 1 2 a 2 μ 2 = 1 2⎩⎪⎪⎪⎨⎪⎪⎪⎧a1+a2=1a2λ2=21a2μ2=21⎧⎩⎨⎪⎪⎪⎪⎪⎪⎪⎪a1+a2=1a2λ2=12a2μ2=12
得到一族二阶龙格-库塔法。取 a 1 = 0 , a 2 = 1 , λ 2 = μ 2 = 1 2 a_1=0,a_2=1,\lambda_2=\mu_2=\dfrac{1}{2} a1=0,a2=1,λ2=μ2=21,得到中点公式:
y i + 1 = y i + h f ( x i + 1 2 h , y i + h 2 f ( x i , y i ) ) y_{i+1}=y_i+hf(x_i+\dfrac{1}{2}h,y_i+\dfrac{h}{2}f(x_i,y_i)) yi+1=yi+hf(xi+21h,yi+2hf(xi,yi))
取 a 1 = 1 4 , a 2 = 3 4 , λ 2 = μ 2 = 2 3 a_1=\dfrac{1}{4},a_2=\dfrac{3}{4},\lambda_2=\mu_2=\dfrac{2}{3} a1=41,a2=43,λ2=μ2=32,得到休恩公式:
y i + 1 = y i + 1 4 h [ f ( x i , y i ) + 3 f ( x i + 2 3 h , y i + 2 3 h f ( x i , y i ) ) ] y_{i+1}=y_i+\frac{1}{4}h[f(x_i,y_i)+3f(x_i+\frac{2}{3}h,y_i+\frac{2}{3}hf(x_i,y_i))] yi+1=yi+41h[f(xi,yi)+3f(xi+32h,yi+32hf(xi,yi))]
取 a 1 = 1 2 , a 2 = 1 2 , λ 2 = μ 2 = 1 a_1=\dfrac{1}{2},a_2=\dfrac{1}{2},\lambda_2=\mu_2=1 a1=21,a2=21,λ2=μ2=1,得到改进欧拉公式:
y i + 1 = y i + h 2 [ f ( x i , y i ) + f ( x i + 1 , y + h f ( x i , y i ) ) ] y_{i+1}=y_i+\frac{h}{2}[f(x_i,y_i)+f(x_{i+1},y+hf(x_i,y_i))] yi+1=yi+2h[f(xi,yi)+f(xi+1,y+hf(xi,yi))]
当
m
=
4
m=4
m=4 时,可得到四阶经典龙格-库塔法:
{
y
i
+
1
=
y
i
+
h
6
(
K
1
+
2
K
2
+
2
K
3
+
K
4
)
K
1
=
f
(
x
i
,
y
i
)
K
2
=
f
(
x
i
+
h
2
,
y
i
+
h
2
K
1
)
K
3
=
f
(
x
i
+
h
2
,
y
i
+
h
2
K
2
)
K
4
=
f
(
x
i
+
h
,
y
i
+
h
K
3
)
具有四阶精度,即局部截断误差为
O
(
h
5
)
O(h^5)
O(h5)。
一般地, m m m 级龙格-库塔法所能达到的最大阶 p p p 的关系如下:
以四阶经典龙格-库塔法为例。从结点
x
i
x_i
xi 出发,以
h
h
h 为步长求一个近似值记为
y
i
+
1
(
h
)
y_{i+1}^{(h)}
yi+1(h),由于局部截断误差为
O
(
h
5
)
O(h^5)
O(h5) ,所以有
y
(
x
i
+
1
)
−
y
i
+
1
(
h
)
≈
c
h
5
y(x_{i+1})-y_{i+1}^{(h)}\approx ch^5
y(xi+1)−yi+1(h)≈ch5
假定系数
c
c
c 变化很慢,近似常数,并且在
h
h
h 很小时,
c
c
c 与
h
h
h 无关。然后将步长折半,即取
h
2
\dfrac{h}{2}
2h 为步长,从
x
i
x_i
xi 跨两步到
x
i
+
1
x_{i+1}
xi+1,求得一个近似值
y
i
+
1
(
h
2
)
y_{i+1}^{(\frac{h}{2})}
yi+1(2h),每跨一步的截断误差是
c
(
h
2
)
5
c(\dfrac{h}{2})^5
c(2h)5,因此有
y
(
x
i
+
1
)
−
y
i
+
1
(
h
2
)
≈
2
c
(
h
2
)
5
y(x_{i+1})-y_{i+1}^{(\frac{h}{2})}\approx 2c(\dfrac{h}{2})^5
y(xi+1)−yi+1(2h)≈2c(2h)5
步长折半后,误差大约减少了
1
16
\dfrac{1}{16}
161,即
y
(
x
i
+
1
)
−
y
i
+
1
(
h
2
)
y
(
x
i
+
1
)
−
y
i
+
1
(
h
)
≈
1
16
\frac{y(x_{i+1})-y_{i+1}^{(\frac{h}{2})}}{y(x_{i+1})-y_{i+1}^{(h)}}\approx\frac{1}{16}
y(xi+1)−yi+1(h)y(xi+1)−yi+1(2h)≈161
由此易得出下列误差估计式:
y
(
x
i
+
1
)
≈
2
4
y
i
+
1
(
h
2
)
−
y
i
+
1
(
h
)
2
4
−
1
y(x_{i+1})\approx\frac{2^4y_{i+1}^{(\frac{h}{2})}-y_{i+1}^{(h)}}{2^4-1}
y(xi+1)≈24−124yi+1(2h)−yi+1(h)
取:
y
i
+
1
=
2
4
y
i
+
1
(
h
2
)
−
y
i
+
1
(
h
)
2
4
−
1
y_{i+1}=\frac{2^4y_{i+1}^{(\frac{h}{2})}-y_{i+1}^{(h)}}{2^4-1}
yi+1=24−124yi+1(2h)−yi+1(h)
作为
y
(
x
i
+
1
)
y(x_{i+1})
y(xi+1) 的近似值,精度比
y
i
+
1
(
h
)
、
y
i
+
1
(
h
2
)
y_{i+1}^{(h)}、y_{i+1}^{(\frac{h}{2})}
yi+1(h)、yi+1(2h) 都高。(理查森外推方法)
也可以写成:
y
(
x
i
+
1
)
−
y
i
+
1
(
h
2
)
≈
y
i
+
1
(
h
2
)
−
y
i
+
1
(
h
)
2
4
−
1
y(x_{i+1})-y_{i+1}^{(\frac{h}{2})}\approx\frac{y_{i+1}^{(\frac{h}{2})}-y_{i+1}^{(h)}}{2^4-1}
y(xi+1)−yi+1(2h)≈24−1yi+1(2h)−yi+1(h)
可以通过检查步长折半前后两次计算结果的偏差
Δ
=
∣
y
i
+
1
(
h
2
)
−
y
i
+
1
(
h
)
∣
\Delta=|y_{i+1}^{(\frac{h}{2})}-y_{i+1}^{(h)}|
Δ=∣yi+1(2h)−yi+1(h)∣
来判断所选的步长是否合适:
上述为变步长方法。
定义3:若一个数值方法对任意固定的点 x i = x 0 + i h x_i=x_0+ih xi=x0+ih,当 h = x i − x 0 i → 0 h=\dfrac{x_i-x_0}{i}\to0 h=ixi−x0→0(即 i → ∞ i\to\infin i→∞),都有 y i → y ( x i ) y_i\to y(x_i) yi→y(xi) ,则该方法是收敛的。
收敛性与方法的整体截断误差有关,记整体截断误差 ε i = y ( x i ) − y i \varepsilon_i=y(x_i)-y_i εi=y(xi)−yi 为在 x i x_i xi 处的准确值 y ( x i ) y(x_i) y(xi) 与数值方法得到的近似值 y i y_i yi 之间的误差,则有:
定理1:设 f ( x , y ) f(x,y) f(x,y) 关于 y y y 满足利普希茨条件,即存在常数 L L L,使得:
∣ f ( x , y 1 ) − f ( x , y 2 ) ∣ ≤ L ∣ y 1 − y 2 ∣ ( ∀ x ∈ [ a , b ] ) |f(x,y_1)-f(x,y_2)|\leq L|y_1-y_2|\ \ \ (\forall x\in[a,b]) ∣f(x,y1)−f(x,y2)∣≤L∣y1−y2∣ (∀x∈[a,b])
且 y ′ ′ ( x ) y''(x) y′′(x) 有界,记 M = max x ∈ [ a , b ] ∣ y ′ ′ ( x ) ∣ M=\max_{x\in[a,b]}|y''(x)| M=maxx∈[a,b]∣y′′(x)∣,则欧拉方法的整体截断误差有估计式:
∣ ε i ∣ ≤ e L ( b − a ) ∣ ε 0 ∣ + M h 2 L ( e L ( b − a ) − 1 ) |\varepsilon_i|\leq e^{L(b-a)}|\varepsilon_0|+\frac{Mh}{2L}(e^{L(b-a)}-1) ∣εi∣≤eL(b−a)∣ε0∣+2LMh(eL(b−a)−1)
其中 ε 0 = y ( x 0 ) − y 0 \varepsilon_0=y(x_0)-y_0 ε0=y(x0)−y0。当 ε 0 = 0 \varepsilon_0=0 ε0=0 时,有
∣ ε i ∣ ≤ M h 2 L ( e L ( b − a ) − 1 ) = O ( h ) |\varepsilon_i|\leq\frac{Mh}{2L}(e^{L(b-a)}-1)=O(h) ∣εi∣≤2LMh(eL(b−a)−1)=O(h)
即具有一阶收敛速度。
整体截断误差与局部截断误差之间关系: 整体截断误差= O ( h − 1 ∗ O(h^{-1}* O(h−1∗局部截断误差)。
如果存在正常数
C
、
h
0
C、h_0
C、h0,使得对任意初始值
y
0
、
z
0
y_0、z_0
y0、z0 的欧拉方法的解
y
i
、
z
i
y_i、z_i
yi、zi 满足估计式:
∣
y
i
−
z
i
∣
≤
C
∣
y
0
−
z
0
∣
,
x
0
≤
x
0
+
i
h
≤
b
,
h
≤
h
0
|y_i-z_i|\leq C|y_0-z_0|, \ x_0\leq x_0+ih\leq b,\ \ h\leq h_0
∣yi−zi∣≤C∣y0−z0∣, x0≤x0+ih≤b, h≤h0
则称欧拉方法是稳定的。
定理(*):设 f ( x , y ) f(x,y) f(x,y) 关于 y y y 满足利普希茨条件,则欧拉方法是稳定的。
定义4:设用某一数值方法计算 y i y_i yi 时,所得到的实际计算结果为 y ~ i \tilde y_i y~i,且由误差 δ i = y i − y ~ i \delta_i=y_i-\tilde y_i δi=yi−y~i 引起以后各结点处 y j ( j > i ) y_j(j>i) yj(j>i) 的误差为 δ j \delta_j δj,如果总有 ∣ δ j ∣ ≤ ∣ δ i ∣ |\delta_j|\leq|\delta_i| ∣δj∣≤∣δi∣,则称该方法是绝对稳定的。
一个数值方法的绝对稳定性与方法本身有关,也与 f ( x , y ) f(x,y) f(x,y) 和步长 h h h 有关。
稳定性问题比较复杂,为简化讨论,通常考虑如下试验方程,取
f
(
x
,
y
)
=
λ
y
f(x,y)=\lambda y
f(x,y)=λy:
y
′
=
λ
y
y'=\lambda y
y′=λy
其中
λ
\lambda
λ 是一个复常数,记
h
~
=
λ
h
\tilde h=\lambda h
h~=λh。能使某一数值方法绝对稳定的
h
~
\tilde h
h~ 的允许取值范围称为该方法的绝对稳定域。
欧拉方法的绝对稳定性:
y
i
+
1
=
y
i
+
h
f
(
x
i
,
y
i
)
=
y
i
+
h
λ
y
i
=
(
1
+
h
~
)
y
i
y_{i+1}=y_i+hf(x_i,y_i)=y_i+h\lambda y_i=(1+\tilde h)y_i
yi+1=yi+hf(xi,yi)=yi+hλyi=(1+h~)yi
当
y
i
y_i
yi 有误差而变为
y
~
i
\tilde y_i
y~i 时,有
y
~
i
+
1
=
(
1
+
h
~
)
y
~
i
\tilde y_{i+1}=(1+\tilde h)\tilde y_i
y~i+1=(1+h~)y~i
记
δ
i
=
y
i
−
y
~
i
\delta_i=y_i-\tilde y_i
δi=yi−y~i,两式相减有
δ
i
+
1
=
(
1
+
h
~
)
δ
i
\delta_{i+1}=(1+\tilde h)\delta_i
δi+1=(1+h~)δi
要使误差不增加,需满足:
∣
1
+
h
~
∣
≤
1
|1+\tilde h|\leq1
∣1+h~∣≤1
即欧拉方法的绝对稳定区域是以(-1,0)为中心、半径为1的圆形区域。欧拉方法是条件稳定的。
向后欧拉方法绝对稳域: ∣ 1 − h ~ ∣ > 1 |1-\tilde h|>1 ∣1−h~∣>1
改进欧拉方法的绝对稳域:
y
i
+
1
=
y
i
+
h
2
[
λ
y
i
+
λ
(
y
i
+
h
λ
y
i
)
]
=
(
1
+
h
~
+
1
2
h
~
2
)
y
i
δ
i
+
1
=
(
1
+
h
~
+
1
2
h
~
2
)
δ
i
∣
1
+
h
~
+
1
2
h
~
2
∣
≤
1
y_{i+1}=y_i+\frac{h}{2}[\lambda y_i+\lambda(y_i+h\lambda y_i)]=(1+\tilde h+\frac{1}{2}\tilde h^2)y_i\\\delta_{i+1}=(1+\tilde h+\frac{1}{2}\tilde h^2)\delta_i\\|1+\tilde h+\frac{1}{2}\tilde h^2|\leq1
yi+1=yi+2h[λyi+λ(yi+hλyi)]=(1+h~+21h~2)yiδi+1=(1+h~+21h~2)δi∣1+h~+21h~2∣≤1
经典龙格-库塔法的绝对稳域:
∣
1
+
h
~
+
1
2
h
~
2
+
1
6
h
~
3
+
1
24
h
~
4
∣
≤
1
|1+\tilde h+\frac{1}{2}\tilde h^2+\frac{1}{6}\tilde h^3+\frac{1}{24}\tilde h^4|\leq1
∣1+h~+21h~2+61h~3+241h~4∣≤1
对于一般方程
d
y
d
x
=
f
(
x
,
y
)
\dfrac{dy}{dx}=f(x,y)
dxdy=f(x,y),可近似地取:
λ
≈
−
∣
∂
f
∂
y
∣
(
x
i
,
y
i
)
\lambda\approx-|\frac{\partial f}{\partial y}|_{(x_i,y_i)}
λ≈−∣∂y∂f∣(xi,yi)
以便判断绝对稳定性,并用以确定求
y
i
+
1
y_{i+1}
yi+1 时的步长
h
i
+
1
h_{i+1}
hi+1。
{
d
y
i
d
x
=
f
i
(
x
,
y
1
,
y
2
,
⋯
,
y
n
)
y
i
(
x
0
)
=
y
i
0
,
i
=
1
,
2
,
⋯
,
n
若把其中的未知函数、方程右端都表成向量形式:
Y
=
(
y
1
,
y
2
,
⋯
,
y
n
)
T
,
F
=
(
f
1
,
f
2
,
⋯
,
f
n
)
T
Y=(y_1,y_2,\cdots,y_n)^T,F=(f_1,f_2,\cdots,f_n)^T
Y=(y1,y2,⋯,yn)T,F=(f1,f2,⋯,fn)T
初值条件表示为:
Y
(
x
0
)
=
Y
0
=
(
y
10
,
y
20
,
⋯
,
y
n
0
)
T
Y(x_0)=Y_0=(y_{10},y_{20},\cdots,y_{n0})^T
Y(x0)=Y0=(y10,y20,⋯,yn0)T
方程可表示为:
{
d
Y
d
x
=
F
(
x
,
Y
)
Y
(
x
0
)
=
Y
0
例如:
{ y ′ = f ( x , y , z ) , y ( x 0 ) = y 0 z ′ = g ( x , y , z ) , z ( x 0 ) = z 0\\ {y′=f(x,y,z),y(x0)=y0z′=g(x,y,z),z(x0)=z0{y′=f(x,y,z),y(x0)=y0z′=g(x,y,z),z(x0)=z0
令 x i = x 0 + i h x_i=x_0+ih xi=x0+ih,
Y ( x ) = [ y ( x ) z ( x ) ] , F ( x , Y ) = [ f ( x , y , z ) g ( x , y , z ) ] , Y ( x 0 ) = [ y ( x 0 ) z ( x 0 ) ] = [ y 0 z 0 ] Y(x)=\left[\right],F(x,Y)=\left[y(x)z(x) \right],Y(x_0)=\left[f(x,y,z)g(x,y,z) \right]=\left[y(x0)z(x0) \right] Y(x)=[y(x)z(x)],F(x,Y)=[f(x,y,z)g(x,y,z)],Y(x0)=[y(x0)z(x0)]=[y0z0]y0z0
改进的欧拉格式的预报公式:
Y ~ i + 1 = Y i + h F ( x i , Y i ) , [ y ~ i + 1 z ~ i + 1 ] = [ y i z i ] + h [ f ( x i , y i , z i ) g ( x i , y i , z i ) ] \tilde Y_{i+1}=Y_i+hF(x_i,Y_i),\left[\right]=\left[y~i+1z~i+1 \right]+h\left[yizi \right] Y~i+1=Yi+hF(xi,Yi),[y~i+1z~i+1]=[yizi]+h[f(xi,yi,zi)g(xi,yi,zi)]f(xi,yi,zi)g(xi,yi,zi)
校正公式:
{ y i + 1 = y i + h 2 [ f ( x i , y i , z i ) + f ( x i + 1 , y ~ i + 1 , z ~ i + 1 ) ] z i + 1 = z i + h 2 [ g ( x i , y i , z i ) + g ( x i + 1 , y ~ i + 1 , z ~ i + 1 ) ]⎩⎪⎨⎪⎧yi+1=yi+2h[f(xi,yi,zi)+f(xi+1,y~i+1,z~i+1)]zi+1=zi+2h[g(xi,yi,zi)+g(xi+1,y~i+1,z~i+1)]⎧⎩⎨⎪⎪⎪⎪yi+1=yi+h2[f(xi,yi,zi)+f(xi+1,y~i+1,z~i+1)]zi+1=zi+h2[g(xi,yi,zi)+g(xi+1,y~i+1,z~i+1)]
四阶经典龙格—库塔公式:
{ y i + 1 = y i + h 6 ( K 1 + 2 K 2 + 2 K 3 + K 4 ) z i + 1 = z i + h 6 ( L 1 + 2 L 2 + 2 L 3 + L 4 ) K 1 = f ( x i , y i , z i ) , L 1 = g ( x i , y i , z i ) K 2 = f ( x i + h 2 , y i + h 2 K 1 , z i + h 2 L 1 ) , L 2 = g ( x i + h 2 , y i + h 2 K 1 , z i + h 2 L 1 ) K 3 = f ( x i + h 2 , y i + h 2 K 2 , z i + h 2 L 2 ) , L 3 = g ( x i + h 2 , y i + h 2 K 2 , z i + h 2 L 2 ) K 4 = f ( x i + h , y i + h K 3 , z i + h L 3 ) , L 4 = g ( x i + h , y i + h K 3 , z i + h L 3 )\\K_1=f(x_i,y_i,z_i),L_1=g(x_i,y_i,z_i)\\K_2=f(x_i+\dfrac{h}{2},y_i+\dfrac{h}{2}K_1,z_i+\dfrac{h}{2}L_1),L_2=g(x_i+\dfrac{h}{2},y_i+\dfrac{h}{2}K_1,z_i+\dfrac{h}{2}L_1)\\K_3=f(x_i+\dfrac{h}{2},y_i+\dfrac{h}{2}K_2,z_i+\dfrac{h}{2}L_2),L_3=g(x_i+\dfrac{h}{2},y_i+\dfrac{h}{2}K_2,z_i+\dfrac{h}{2}L_2)\\K_4=f(x_i+h,y_i+hK_3,z_i+hL_3),L_4=g(x_i+h,y_i+hK_3,z_i+hL_3) ⎩⎪⎨⎪⎧yi+1=yi+6h(K1+2K2+2K3+K4)zi+1=zi+6h(L1+2L2+2L3+L4)K1=f(xi,yi,zi),L1=g(xi,yi,zi)K2=f(xi+2h,yi+2hK1,zi+2hL1),L2=g(xi+2h,yi+2hK1,zi+2hL1)K3=f(xi+2h,yi+2hK2,zi+2hL2),L3=g(xi+2h,yi+2hK2,zi+2hL2)K4=f(xi+h,yi+hK3,zi+hL3),L4=g(xi+h,yi+hK3,zi+hL3)⎧⎩⎨⎪⎪⎪⎪yi+1=yi+h6(K1+2K2+2K3+K4)zi+1=zi+h6(L1+2L2+2L3+L4)
若引入向量记号:
y = [ y z ] , f = [ f g ] , y i = [ y i z i ] , K i = [ K i L i ] ( i = 1 , 2 , 3 , 4 ) \boldsymbol y=\left[\right],\boldsymbol f=\left[yz \right],\boldsymbol y_i=\left[fg \right],\boldsymbol K_i=\left[yizi \right]\ \ (i=1,2,3,4) y=[yz],f=[fg],yi=[yizi],Ki=[KiLi] (i=1,2,3,4)KiLi
初值问题即为:
{ y ′ = f ( x , y ) y ( x 0 ) = y 0 f ( x , y ) = f ( x , y , z )\\f(x,\boldsymbol y)=f(x,y,z) {y′=f(x,y)y(x0)=y0f(x,y)=f(x,y,z){y′=f(x,y)y(x0)=y0
相应的经典R-K公式为:
y i + 1 = y i + h 6 ( K 1 + 2 K 2 + 2 K 3 + K 4 ) K 1 = f ( x i , y i ) K 2 = f ( x i + h 2 , y i + h 2 K 1 ) K 3 = f ( x i + h 2 , y i + h 2 K 2 ) K 4 = f ( x i + h , y i + h K 3 ) \boldsymbol y_{i+1}=\boldsymbol y_i+\frac{h}{6}(\boldsymbol K_1+2\boldsymbol K_2+2\boldsymbol K_3+\boldsymbol K_4)\\\boldsymbol K_1=\boldsymbol f(x_i,\boldsymbol y_i)\\\boldsymbol K_2=\boldsymbol f(x_i+\frac{h}{2},\boldsymbol y_i+\frac{h}{2}\boldsymbol K_1)\\\boldsymbol K_3=\boldsymbol f(x_i+\frac{h}{2},\boldsymbol y_i+\frac{h}{2}\boldsymbol K_2)\\\boldsymbol K_4=\boldsymbol f(x_i+h,\boldsymbol y_i+h\boldsymbol K_3) yi+1=yi+6h(K1+2K2+2K3+K4)K1=f(xi,yi)K2=f(xi+2h,yi+2hK1)K3=f(xi+2h,yi+2hK2)K4=f(xi+h,yi+hK3)
对于如下形式的高阶常微分方程:
y
(
n
)
=
f
(
x
,
y
,
y
′
,
⋯
,
y
(
n
−
1
)
)
y^{(n)}=f(x,y,y',\cdots,y^{(n-1)})
y(n)=f(x,y,y′,⋯,y(n−1))
其初值问题应在初值点
x
=
x
0
x=x_0
x=x0 处给出
n
n
n 个条件:
y
(
x
0
)
=
y
0
,
y
′
(
x
0
)
=
y
0
′
,
⋯
,
y
(
n
−
1
)
(
x
0
)
=
y
0
(
n
−
1
)
y(x_0)=y_0,y'(x_0)=y_0',\cdots,y^{(n-1)}(x_0)=y^{(n-1)}_0
y(x0)=y0,y′(x0)=y0′,⋯,y(n−1)(x0)=y0(n−1)
可引进新的未知函数:
y
1
=
y
,
y
2
=
y
′
,
⋯
,
y
n
=
y
(
n
−
1
)
y_1=y,y_2=y',\cdots,y_n=y^{(n-1)}
y1=y,y2=y′,⋯,yn=y(n−1),把上述初值问题变成一个常微分方程组:
{
y
1
′
=
y
2
y
2
′
=
y
3
⋮
y
n
−
1
′
=
y
n
y
n
′
=
f
(
x
,
y
1
,
y
2
,
⋯
,
y
n
−
1
)
初始条件为:
y
1
(
x
0
)
=
y
0
,
y
2
(
x
0
)
=
y
0
′
,
⋯
,
y
n
(
x
0
)
=
y
0
(
n
−
1
)
y_1(x_0)=y_0,y_2(x_0)=y_0',\cdots,y_n(x_0)=y_0^{(n-1)}
y1(x0)=y0,y2(x0)=y0′,⋯,yn(x0)=y0(n−1)
例如:
{ y ′ ′ = f ( x , y , y ′ ) y ( x 0 ) = y 0 y ′ ( x 0 ) = y 0 ′⎩⎪⎨⎪⎧y′′=f(x,y,y′)y(x0)=y0y′(x0)=y0′⎧⎩⎨y′′=f(x,y,y′)y(x0)=y0y′(x0)=y′0
引入新的变量 z = y ′ z=y' z=y′,可化为一解方程组的初值问题:
{ y ′ = z , y ( x 0 ) = y 0 z ′ = f ( x , y , z ) , z ( x 0 ) = y 0 ′{y′=z,y(x0)=y0z′=f(x,y,z),z(x0)=y0′{y′=z,y(x0)=y0z′=f(x,y,z),z(x0)=y′0
四阶经典龙格—库塔公式:
{ y i + 1 = y i + h 6 ( K 1 + 2 K 2 + 2 K 3 + K 4 ) z i + 1 = z i + h 6 ( L 1 + 2 L 2 + 2 L 3 + L 4 ) K 1 = z i , L 1 = f ( x i , y i , z i ) K 2 = z i + h 2 L 1 , L 2 = f ( x i + h 2 , y i + h 2 K 1 , z i + h 2 L 1 ) K 3 = z i + h 2 L 2 , L 3 = f ( x i + h 2 , y i + h 2 K 2 , z i + h 2 L 2 ) K 4 = z i + h L 3 , L 4 = f ( x i + h , y i + h K 3 , z i + h L 3 )\\K_1=z_i,L_1=f(x_i,y_i,z_i)\\K_2=z_i+\dfrac{h}{2}L_1,L_2=f(x_i+\dfrac{h}{2},y_i+\dfrac{h}{2}K_1,z_i+\dfrac{h}{2}L_1)\\K_3=z_i+\dfrac{h}{2}L_2,L_3=f(x_i+\dfrac{h}{2},y_i+\dfrac{h}{2}K_2,z_i+\dfrac{h}{2}L_2)\\K_4=z_i+hL_3,L_4=f(x_i+h,y_i+hK_3,z_i+hL_3) ⎩⎪⎨⎪⎧yi+1=yi+6h(K1+2K2+2K3+K4)zi+1=zi+6h(L1+2L2+2L3+L4)K1=zi,L1=f(xi,yi,zi)K2=zi+2hL1,L2=f(xi+2h,yi+2hK1,zi+2hL1)K3=zi+2hL2,L3=f(xi+2h,yi+2hK2,zi+2hL2)K4=zi+hL3,L4=f(xi+h,yi+hK3,zi+hL3)⎧⎩⎨⎪⎪⎪⎪yi+1=yi+h6(K1+2K2+2K3+K4)zi+1=zi+h6(L1+2L2+2L3+L4)
求解二阶常微分方程: y ′ ′ = f ( x , y , y ′ ) , x ∈ [ a , b ] y''=f(x,y,y'),x\in[a,b] y′′=f(x,y,y′),x∈[a,b],需两个特定条件,除初值条件外。也可以通过给定边界条件来确定。
边界条件的三种给法:
考虑二阶常微分方程第一边值问题:
{
y
′
′
=
f
(
x
,
y
,
y
′
)
,
a
<
x
<
b
y
(
a
)
=
α
,
y
(
b
)
=
β
解记为
y
(
x
)
y(x)
y(x)。
假设存在唯一解,选取适当的
t
t
t,构造初值问题:
{
y
′
′
=
f
(
x
,
y
,
y
′
)
,
a
<
x
<
b
y
(
a
)
=
α
,
y
′
(
a
)
=
t
解记为
y
(
x
,
t
)
y(x,t)
y(x,t),
ε
\varepsilon
ε 为给定精度要求,若能使:
∣
y
(
b
,
t
)
−
β
∣
<
ε
|y(b,t)-\beta|<\varepsilon
∣y(b,t)−β∣<ε
则可把
y
(
x
,
t
)
y(x,t)
y(x,t) 作为
y
(
x
)
y(x)
y(x) 的近似解,即表示近似“命中”精确解。
要通过不断试算和修正的方法来获得 t t t 的值。先凭经验确定 y ′ ( a ) y'(a) y′(a) 的两个预测值 t 1 , t 2 t_1,t_2 t1,t2 进行试算,分别得到两个解 y ( x , t 1 ) , y ( x , t 2 ) y(x,t_1),y(x,t_2) y(x,t1),y(x,t2)。
记
β
1
=
y
(
b
,
t
1
)
,
β
2
=
y
(
b
,
t
2
)
\beta_1=y(b,t_1),\beta_2=y(b,t_2)
β1=y(b,t1),β2=y(b,t2),若
∣
β
1
−
β
∣
<
ε
|\beta_1-\beta|<\varepsilon
∣β1−β∣<ε,则取
y
(
x
,
t
1
)
y(x,t_1)
y(x,t1) 作为近似解,若
∣
β
2
−
β
∣
<
ε
|\beta_2-\beta|<\varepsilon
∣β2−β∣<ε,则取
y
(
x
,
t
2
)
y(x,t_2)
y(x,t2)。否则,通过线性插值或他法确定
t
t
t 的新的预测值:
t
3
=
t
1
+
t
2
−
t
1
β
2
−
β
1
(
β
−
β
1
)
t_3=t_1+\frac{t_2-t_1}{\beta_2-\beta_1}(\beta-\beta_1)
t3=t1+β2−β1t2−t1(β−β1)
重新试算可得
β
3
,
⋯
\beta_3,\cdots
β3,⋯,直到满足
∣
β
i
−
β
∣
<
ε
|\beta_i-\beta|<\varepsilon
∣βi−β∣<ε 为止,其中
β
i
=
y
(
b
,
t
i
)
\beta_i=y(b,t_i)
βi=y(b,ti):
t
i
=
t
i
−
2
+
t
i
−
1
−
t
i
−
2
β
i
−
1
−
β
i
−
2
(
β
−
β
i
−
2
)
,
i
=
3
,
4
,
⋯
t_i=t_{i-2}+\frac{t_{i-1}-t_{i-2}}{\beta_{i-1}-\beta_{i-2}}(\beta-\beta_{i-2}),i=3,4,\cdots
ti=ti−2+βi−1−βi−2ti−1−ti−2(β−βi−2),i=3,4,⋯
- 也可以通过牛顿迭代法等方法来得到 t t t 的值。
- 对于第二、第三边值问题,类似地可以得到相应的解。
考虑两点边值问题:
{
L
y
=
−
d
d
x
(
p
(
x
)
d
y
d
x
)
+
r
(
x
)
d
y
d
x
+
q
(
x
)
y
=
f
(
x
)
,
a
<
x
<
b
y
(
a
)
=
α
,
y
(
b
)
=
β
p
(
x
)
≥
p
0
>
0
,
q
(
x
)
≥
0
p(x)\geq p_0>0,q(x)\geq0
p(x)≥p0>0,q(x)≥0。在
x
=
a
,
x
=
b
x=a,x=b
x=a,x=b 两个端点给定两个边值条件,也可给定其他带一阶导数值的边值条件。
将区间
[
a
,
b
]
[a,b]
[a,b] 均匀分成
N
N
N 等份网格,即:
x
n
=
a
+
n
h
,
h
=
b
−
a
N
,
n
=
0
,
1
,
⋯
,
N
x_n=a+nh,h=\frac{b-a}{N},n=0,1,\cdots,N
xn=a+nh,h=Nb−a,n=0,1,⋯,N
在每个内网格结点
x
n
x_n
xn,令
L
y
∣
x
n
=
f
∣
x
n
,
n
=
1
,
2
,
⋯
,
N
−
1
Ly|_{x_n}=f|_{x_n},n=1,2,\cdots,N-1
Ly∣xn=f∣xn,n=1,2,⋯,N−1
假定
y
(
x
)
y(x)
y(x) 充分光滑,由泰勒展开式,有:
{
d
y
d
x
∣
x
n
=
y
(
x
n
+
1
)
−
y
(
x
n
−
1
)
2
h
+
O
(
h
2
)
d
d
x
(
p
(
x
)
d
y
d
x
)
∣
x
n
=
1
h
(
(
p
d
y
d
x
)
x
n
+
1
2
−
(
p
d
y
d
x
)
x
n
−
1
2
)
+
O
(
h
2
)
=
1
h
[
p
n
+
1
2
y
(
x
n
+
1
)
−
y
(
x
n
)
h
−
p
n
−
1
2
y
(
x
n
)
−
y
(
x
n
−
1
)
h
]
+
O
(
h
2
)
这里
x
n
+
1
2
=
1
2
(
x
n
+
1
+
x
n
)
,
p
n
±
1
2
=
p
(
x
n
±
1
2
)
x_{n+\frac{1}{2}}=\dfrac{1}{2}(x_{n+1}+x_n),p_{n\pm\frac{1}{2}}=p(x_{n\pm\frac{1}{2}})
xn+21=21(xn+1+xn),pn±21=p(xn±21)。
于是有:
−
1
h
[
p
n
+
1
2
y
(
x
n
+
1
)
−
y
(
x
n
)
h
−
p
n
−
1
2
y
(
x
n
)
−
y
(
x
n
−
1
)
h
]
+
r
n
y
(
x
n
+
1
)
−
y
(
x
n
−
1
)
2
h
+
q
n
y
(
x
n
)
+
R
n
=
f
n
R
n
=
O
(
h
2
)
-\dfrac{1}{h}[p_{n+\frac{1}{2}}\dfrac{y(x_{n+1})-y(x_n)}{h}-p_{n-\frac{1}{2}}\dfrac{y(x_n)-y(x_{n-1})}{h}]+r_n\dfrac{y(x_{n+1})-y(x_{n-1})}{2h}+q_ny(x_n)+R_n=f_n\\R_n=O(h^2)
−h1[pn+21hy(xn+1)−y(xn)−pn−21hy(xn)−y(xn−1)]+rn2hy(xn+1)−y(xn−1)+qny(xn)+Rn=fnRn=O(h2)
忽略高阶项
R
n
R_n
Rn,并用
y
n
y_n
yn 表示
y
(
x
n
)
y(x_n)
y(xn) 的近似值,得:
−
1
h
[
p
n
+
1
2
y
n
+
1
−
y
n
h
−
p
n
−
1
2
y
n
−
y
n
−
1
h
]
+
r
n
y
n
+
1
−
y
n
−
1
2
h
+
q
n
y
n
=
f
n
,
n
=
1
,
2
,
⋯
,
N
−
1
边
值
条
件
:
y
0
=
α
,
y
N
=
β
-\dfrac{1}{h}[p_{n+\frac{1}{2}}\dfrac{y_{n+1}-y_n}{h}-p_{n-\frac{1}{2}}\dfrac{y_n-y_{n-1}}{h}]+r_n\dfrac{y_{n+1}-y_{n-1}}{2h}+q_ny_n=f_n,n=1,2,\cdots,N-1\\边值条件:y_0=\alpha,y_N=\beta
−h1[pn+21hyn+1−yn−pn−21hyn−yn−1]+rn2hyn+1−yn−1+qnyn=fn,n=1,2,⋯,N−1边值条件:y0=α,yN=β
上述方程是关于未知量
y
n
(
n
=
1
,
2
,
⋯
,
N
−
1
)
y_n(n=1,2,\cdots,N-1)
yn(n=1,2,⋯,N−1) 的一个线性方程组,其系数矩阵为:
A
=
[
b
1
−
c
1
−
a
2
b
2
−
c
2
⋱
⋱
⋱
−
a
N
−
2
b
N
−
2
−
c
N
−
2
−
a
N
−
1
b
N
−
1
]
(
N
−
1
)
×
(
N
−
1
)
b
n
=
1
h
2
(
p
n
+
1
2
+
p
n
−
1
2
)
+
q
n
c
n
=
1
h
2
p
n
+
1
2
+
1
2
h
r
n
a
n
=
1
h
2
p
n
−
1
2
−
1
2
h
r
n
A=\left[
当网格步长
h
h
h 充分小时,
A
A
A 是一个对角占优的三对角矩阵,因此
A
A
A 是非奇异矩阵,可用追赶法直接求解。
若
p
(
x
)
≡
1
,
r
(
x
)
≡
0
,
f
(
x
)
=
−
γ
(
x
)
p(x)\equiv1,r(x)\equiv0,f(x)=-\gamma(x)
p(x)≡1,r(x)≡0,f(x)=−γ(x),则两点边值问题为:
{
L
y
=
−
y
′
′
+
q
(
x
)
y
=
−
γ
(
x
)
,
q
(
x
)
≥
0
,
a
<
x
<
b
y
(
a
)
=
α
,
y
(
b
)
=
β
y
′
′
(
x
i
)
−
q
(
x
i
)
y
(
x
i
)
=
γ
(
x
i
)
{
y
i
+
1
−
2
y
i
+
y
i
−
1
h
2
−
q
i
y
i
=
γ
i
y
0
=
α
,
y
N
=
β
,
i
=
1
,
2
,
⋯
,
N
−
1
矩阵形式:
A
y
=
b
A
=
[
−
2
−
q
1
h
2
1
1
−
2
−
q
2
h
2
1
⋱
⋱
⋱
1
−
2
−
q
N
−
2
h
2
1
1
−
2
−
q
N
−
1
h
2
]
(
N
−
1
)
×
(
N
−
1
)
y
=
[
y
1
y
2
⋮
y
N
−
2
y
N
−
1
]
,
b
=
[
γ
1
h
2
−
α
γ
2
h
2
⋮
γ
N
−
2
h
2
γ
N
−
1
h
2
−
β
]
Ay=b\\A=\left[
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。