Share to: share facebook share twitter share wa share telegram print page

数值稳定性

数值分析中,数值稳定性是一种希望得到的数值算法特性。根据算法的不同,稳定性的精确定义也有所不同,但是都与算法的精确性与正确性相关。

理论上有些计算下可以用多种代数上等价的理想实数或者复数算法来实现,但是实际上由于不同的数值稳定性可能会得到不同的结果。数值稳定性的一项任务就是选择強健(robust,即有良好数值稳定性)的算法。

前向、后向与混合稳定性

数值线性代数中经常使用前向、后向以及混合稳定性的概念。

该图显示了前向误差、后向误差、它们与精确解以及数值解的关系

假设要用数值算法解决的问题是用函数将数据映射到解,通常算法的结果会与“真”解有一定的偏差。误差的来源主要有舍入误差截断误差以及数据误差。算法的「前向误差」是结果与真解之间的差别,即。「后向误差」是满足的最小,也就是说后向误差说明算法的所解决的问题。前向误差和后向误差通过条件数发生关系:前向误差的幅度最多是条件数乘以后向误差的幅度。

在许多情况下,需要考虑相对误差

而不是绝对误差

如果对于任意的输入来说后向误差都很小,那么算法就是「后向稳定」的。当然,“小”是一个相对的概念,需要根据所用的场合进行定义。通常要求误差要与单位舍入误差英语Machine epsilon处于同一数量级,或是略大一些。

包括前向误差与后向误差概念的混合稳定性

通常数值稳定性的定义是使用一个包括了前向误差与后向误差的更加宽泛的概念,称为「混合稳定性」。按照这个概念,如果一个算法是稳定的,那么存在使得都很小。因此,后向稳定算法永远是稳定的。

如果算法的前向误差除以条件数得到的结果很小,那么这个算法就是「前向稳定」的。这就意味着如果一个算法的前向误差与后向稳定算法的误差幅度类似那么就是前向稳定的。

数值微分方程的稳定性

上面的定义在截断误差不重要的情况下是很确切的。在微分方程等另外一些场合中,则需要另外的数值稳定性定义。

数值常微分方程中,有不同的数值稳定性概念,如A稳定性等。它们通常与动力系统中的李雅普诺夫稳定性等稳定性概念相关。在解刚性方程的时候稳定方法的使用很重要。

数值偏微分方程中有另外一种数值稳定性的定义。如果随着步长逐渐趋近于零,偏微分方程的数值解仍然保持有界,那么这个算法就是稳定的。拉克斯等价定理表明如果算法是一致的,且是稳定的,那么这个算法就会收敛。有时候将数值扩散考虑在内来实现稳定性。数值扩散是一个数学术语,它保证舍入误差以及其它误差在计算的过程中逐渐散去,而不会累积起来越变越大。

例子

根號2的計算(大約是1.41421)是適定性問題。許多演算法會用起始的近似值x0開始,最後收斂到,例如選x0 = 1.4,接著薒計算x1, x2等。其中一個方法是著名的巴比倫法英语Babylonian method,公式為xk+1 = (xk+ 2/xk)/2。另一個方法,先稱為X方法,公式是xk+1 = (xk2 − 2)2 + xk[註 1]以下是一些迭代後的結果,初始值x0分別是1.4和1.42。

巴比倫法 巴比倫法 X方法 X方法
x0 = 1.4 x0 = 1.42 x0 = 1.4 x0 = 1.42
x1 = 1.4142857... x1 = 1.41422535... x1 = 1.4016 x1 = 1.42026896
x2 = 1.414213564... x2 = 1.41421356242... x2 = 1.4028614... x2 = 1.42056...
... ...
x1000000 = 1.41421... x27 = 7280.2284...

不論初始值為何,巴比倫法都可以快速收斂。而X方法在初始值x0 = 1.4時收斂,但收斂很慢,而在初始值為1.42時會發散。因此巴比倫法具有數值穩定的特性,而X方法沒有。

數值穩定性也會受計算時有效位元的個數所影響。假設有電腦可以保持四位的有效數字,以下二個定效的函數可以說明有效位丟失(loss of significance)的問題

比較以下兩個結果

比較上述二個結果,可以看到第一式的有效位丟失(原因是來自兩個相近數字近似值相減後帶來的灾难性抵消),這對結果造成很大的影響,而這兩個函數其實是等效的

若用無限精度計算,其數值是11.174755...[註 2]

相關條目

腳註

  1. ^ 這是針對方程的定點迭代英语fixed point iteration,其解包括。因,此迭代會一直增加,在時,會收斂,在時則會發散。
  2. ^ 這是源自Mathews & Fink (1999)修改而來[1]

参考資料

  1. ^ Mathews, John H.; Fink, Kurtis D. Example 1.17. Numerical Methods Using MATLAB 3rd. Prentice Hall. 1999: 28. 
  • Nicholas J. Higham, Accuracy and Stability of Numerical Algorithms, Society of Industrial and Applied Mathematics, Philadelphia, 1996. ISBN 0-89871-355-2.
Prefix: a b c d e f g h i j k l m n o p q r s t u v w x y z 0 1 2 3 4 5 6 7 8 9

Portal di Ensiklopedia Dunia

Kembali kehalaman sebelumnya