在许多实际问题中,常常需要求解这样的线性方程组:他们的系数矩阵数很高,但非零元素很少,也就是大型稀疏线性代数方程组。对于这类方程组,如果不具备带状性,那么用直接发求解就不会很有效。因为用直接法进行消元或矩阵的三角分解时,没有考虑到系数矩阵的稀疏性,破坏了系数矩阵的形状,导致计算量的增加和存储单元的浪费。

  迭代法是通过逐次迭代来逼近方程组的解,因此,收敛性和收敛速度是构造迭代方法时要注意的问题。那么,是否可以构造一种适用于一般情况的迭代法?答案是否定的,这时因为不同的稀疏矩阵具有不同的性态,一般的,每一种迭代法都具有一定的适用范围。

一,雅克比迭代

考虑线性方程组,如下:

深度学习模型每轮迭代不变_深度学习模型每轮迭代不变

采用矩阵和向量记号,可以把(2.1)写成:

深度学习模型每轮迭代不变_系数矩阵_02

为了方便给出矩阵表示式,引进下列矩阵分裂:

深度学习模型每轮迭代不变_系数矩阵_03

其中:

深度学习模型每轮迭代不变_迭代_04

深度学习模型每轮迭代不变_深度学习模型每轮迭代不变_05

深度学习模型每轮迭代不变_系数矩阵_06

从式(2.1)的第i个方程中解出xi

深度学习模型每轮迭代不变_系数矩阵_07

我们把迭代前面的值代入上式右边,从而得到等式左边的值作为新一次迭代的新值。如此反复就得到了雅克比迭代公式:

深度学习模型每轮迭代不变_深度学习模型每轮迭代不变_08

由式(2.4)及采用矩阵A的分裂记号(2.3),可以得到:

深度学习模型每轮迭代不变_方程组_09

于是雅克比迭代的矩阵表示形式为:

深度学习模型每轮迭代不变_迭代_10

现在回过过头来想想为什么这么做会收敛。在新一轮的迭代完成后,得到的新值与解之间的误差其实是其他所有值的综合,因为有的值会比解大一点,有的值会比解小一点,这样得到的数值可能就会更接近解,当然我们可以构造出发散的例子,也就是通过迭代,得到的值与解之间的偏差越来越大。

二、高斯-赛德尔迭代

  在雅克比迭代过程中都是用一组新值来计算得到旧的值,因为一般情况下新的结果会比旧的结果更加精确,所以在计算的过程中能用新值就用新的,这样能加速收敛的过程。这就是高斯-赛德尔迭代:

深度学习模型每轮迭代不变_系数矩阵_11

三、SOR迭代

  在迭代的过程中可能出现反复的现象:也就是说迭代得到的结果和真实的解之间的差距没有变小,而是有时比真实解大有时小而已。可以引入松弛因子来防止这种现象并能起到加速收敛的作用:

深度学习模型每轮迭代不变_方程组_12

SOR迭代的矩阵表示形式:

深度学习模型每轮迭代不变_系数矩阵_13

四、SSOR迭代

在SOR迭代过程中,新分量计算是依次从第1个到第n个逐个进行的,这个次序也可以反过来,即得到SSOR迭代:

深度学习模型每轮迭代不变_方程组_14