Skip to content

010 The Euler or Tangent Line Method 欧拉法或切线法

为了讨论数值近似法,主要集中于一阶微分方程的初值问题 假定 在平面 内某个包含 的矩形内是连续的,根据定理 2.4.2,在包含 的某个区间内有唯一解 。如果方程 是非线性的,解存在的区间比较难确定,或许无法表达成 的某种简单关系。不过这里假定要讨论的各种情况下,在研究区间内,初始问题 存在唯一解。

在 2.7 小节,我们简单的讨论过欧拉法,也称为切线法。为了推导这种方法,将 写作如下形式 使用差的商表示微分得到 如果用 代替 那么就得到了欧拉公式 如果步长 一样,用 表示,用 表示 ,那么上式可以简化为 欧拉法就是反复使用 或者 计算得到一系列的值 ,它们是解 的近似值。

这里我们分析的初值问题如下。 是一阶线性方程,容易求解,结合初始条件 那么解是 这个问题有解析解,因此不必使用数值法。不过精确的解可以用于评估数值法的精度。这一章我们会始终使用这个问题来评估不同的数值方法。 的解彼此迅速发散,因此可以预见在中等长度的区间上,想要近似都是一个很困难的事情。这也是选择这个问题的原因之一,它能很容易的观察到更有效的方法的收益。

例 1 使用欧拉公式 来近似求解初值问题 的解 ,区间要求是 ,步长

解:使用计算机辅助,得到下表。精度一般。如果 ,从 需要 2000 步,计算量相当大才得到一个比较好的精度。后续会讨论其他数值方法,使用更大的步长更少的计算步骤就能得到同样甚至更好的精度。

Exact
0.0 1.0000000 1.0000000 1.0000000 1.0000000 1.0000000
0.1 1.5475000 1.5761188 1.5952901 1.6076289 1.6090418
0.2 2.3249000 2.4080117 2.4644587 2.5011159 2.5053299
0.3 3.4333560 3.6143837 3.7390345 3.8207130 3.8301388
0.4 5.0185326 5.3690304 5.6137120 5.7754845 5.7942260
0.5 7.2901870 7.9264062 8.3766865 8.6770692 8.7120041
1.0 45.588400 53.807866 60.037126 64.382558 64.897803
1.5 282.07187 361.75945 426.40818 473.55979 479.25919
2.0 1745.6662 2432.7878 3029.3279 3484.1608 3540.2001

为了研究使用数值近似时的误差,同时也为了提出更精确的方法,从不同视角来审视欧拉法是很有帮助的。

一种方式是将问题写成积分方程。令 是初值问题 的解,那么从 积分得到 那么 里面的积分的几何意义是 之间曲线下的面积。如果我们用 处的值 代替函数,就是用矩形面积来代替实际区域。假定步长 都相等,那么 ,得到

为了得到 的近似 ,将 替换成其近似 。这样就得到了欧拉公式 。下一节会讨论通过更精确的积分近似得到更精确的算法。

另一个方法是假定 附近存在泰勒级数 如果仅保留两项,并且用 代替 那么得到了公式 。如果保留更多项,那么近似会更精确。通过泰勒级数的余项可以估算误差。

后向欧拉公式

欧拉公式的一个变化是使用区间右侧的函数值来估算积分,那么 这就是后向欧拉公式(backward Euler formula 假定知道了 需要计算 ,而 并没有给出计算 的显式公式。这里仅仅是隐式地定义了 。因此,这个公式也称为隐式欧拉公式(implicit Euler formula)。如何求解 依赖于函数

例 2 使用后向欧拉公式 来近似求解初值问题 的解 ,区间要求是 ,步长

解:对于 ,后向欧拉公式 变成 微分方程 是线性的,因此上式也是线性的。整理得到 使用计算机辅助,得到下表。对于这个问题,后向欧拉法的值比精确值要大,而欧拉法的估算要比精确值小。后向欧拉法的误差也要比欧拉法大一些,不过当 很小时,差异不显著。

Exact
0.0 1.0000000 1.0000000 1.0000000 1.0000000 1.0000000
0.1 1.6929688 1.6474375 1.6236638 1.6104634 1.6090418
0.2 2.7616699 2.6211306 2.5491368 2.5095731 2.5053299
0.3 4.4174530 4.0920886 3.9285724 3.8396379 3.8301388
0.4 6.9905516 6.3209569 5.9908303 5.8131282 5.7942260
0.5 10.996956 9.7050002 9.0801473 8.7472667 8.7120041
1.0 103.06171 80.402761 70.452395 65.419964 64.897803
1.5 959.44236 661.00731 542.12432 485.05825 479.25919
2.0 8934.0696 5435.7294 4172.7228 3597.4478 3540.2001

后向欧拉法的名字由来是因为它使用后向差的商 来近似微分方程 中的导数,而不是不是公式 中的前向差的商。

既然后向欧拉公式并不比前向欧拉公式更精确,还比前向欧拉公式更复杂,那么讨论的目的是什么呢?这是后向微分公式中最简单的例子,这类方法在讨论特定的微分方程时非常有效且更为精确。8.4 小节的末尾还会讨论这一点。

数值近似的误差

使用类似欧拉公式的数值方法来求解初值问题,在接受近似数值解之前需要回答一系列的问题。这些问题之一是收敛(convergence)。随着步长 趋于零,数值近似 是否趋于真实解的值?如果答案是肯定的,下一个问题是收敛的速度如何?我们想要找到充分小但是不是太小的步长来确保达到需要的精度。一个不必要的太小的步长会使得计算步骤变多,甚至会导致精度损失。

初值问题的数值近似解的误差主要来源于三个方面。

  1. 用于计算的公式带来的误差。比如欧拉公式使用直线来近似真实的解。
  2. 对于每一步,使用近似值 来计算下一个近似值 带来的误差。
  3. 计算机计算只有有限精度。

首先假定计算机可以执行任意精度,也就是说每一步可以保留无限精度。那么初值问题 的解 和数值近似解 之间的误差可以表示为 误差 称为全局截断误差(global truncation error),主要是由于前面两种原因引入的,即公式和输入数据带来的误差。

不过,现实中要考虑计算过程中使用有限精度算术带来的误差,这是每一步只保留有限数字带来的误差。这称为舍入误差(round-off error 其中 是实际计算得到的结果。

计算 时的误差的绝对值是 利用三角不等式 得到 总误差的上界是全局截断误差和舍入误差的绝对值之和。

对于本书讨论的数值方法,可以分析估计全局截断误差。分析舍入误差更困难,这依赖于依赖于数值类型、计算的步骤、舍入的方法等等。详尽的舍入误差分析超出了本书的范围。

单独分析全局截断误差中由于近似公式带来的误差对分析问题很有帮助。可以通过假定第 步的输入是精确的,即 。这个误差称为局部截断误差,用 表示。

欧拉法的局部截断误差

假定初值问题 的解 在研究区间上有连续的二阶导。为了保证这一点,需要假定 是连续的。因为如果 满足这个属性并且 是初值问题 的解,那么 根据链式法则 右边都是连续函数,因此 也是连续的。

处将 展开泰勒级数并保留余项得到 其中 。注意到 ,那么 可以写作 假定我们已知 时正确的值 ,那么可以估算 的值 这里星号表示这是 的近似值。 的差值是 步的局部截断误差,用 表示。根据 可以得到 欧拉公式的局部截断误差与 的平方成正比,与解 的二阶导成正比。 说明误差依赖于 ,通常来说每一步是不同的。在区间 成立的一致边界是 其中 在区间 上的最大值。由于 是最差情况,因此它是对真实局部截断误差的高估。

的一个作用是估计使局部截断误差不超过某个指定值的步长。比如如果要求局部截断误差不超过 ,那么 使用 最大的困难是估计 。不过,这个式子主要想表达的是误差正比于 。比如, 减少一倍,那么结果的误差是原来误差的四分之一。

相比局部截断误差,更重要的是全局截断误差 。不过分析 比要比分析 困难的多。能够证明在有限区间内使用欧拉方法的全局截断误差不会超过 的常数倍,那么 是常数。欧拉法是一阶方法(first-order method),因为它的全局截断误差正比于步长的一次幂。

由于局部截断误差更容易分析,后续我们使用它来分析比较不同方法的精度。如果我们预先知道初值问题的解,那么可以用 分析局部截断误差随 增长的变化。

下面分析微分方程 在区间 上的行为做例子。令 是初值问题 的解,那么 因此 那么 就是 因子 19 和快速增长的 的出现解释了上面的表格为什么不精确。

比如对于 ,第一步的误差是 很明显 是正的,由于 ,那么 同时,,因此 ,实际误差是 0.02542。根据 ,随着 的增加误差会快速增长。这和上面的表格结论一致。类似的,可以计算得到从 0.95 到 1.0 时的局部截断误差上下界 从 1.95 到 2.0 的上下界是 这个结果意味着在 附近的局部截断误差是 附近的 2500 倍。为了在整个区间上将误差减少到一个可以接受范围,我们必须基于 附近来选择步长 ,当然这个步长小于 附近对步长的要求。比如我们要达到局部截断误差小于 0.01 的目标, 附近的步长要求是 0.032 附近即可,而 附近的补偿要求是 0.00059。在整个区间上选择一个更小的统一的步长会导致更多的计算,更多的消耗,更危险的是无可接受的舍入误差。

另一个保持局部截断误差常量的方法是随着 的方法逐步减少步长。比如这个问题,从 步长逐渐减少 50 倍。这个变步长的方法称为自适应(adaptive)。现在解决微分方程的软件都有这个能力。