数值分析读书笔记(3)求解线性代数方程组的迭代法

数值分析读书笔记(3)求解线性代数方程组的迭代法

1.基本迭代法及其构造

考虑方程组Ax=b,其中A属于n*n维的矩阵空间,b和x属于n维向量空间,一般来说我们需要从这个隐式的方程组转变成显示的等价方程,一般具有形式x=\phi (x),这样的方程为不动点方程,我们可以通过不断迭代,计算出等式右端然后赋值给变量x

对于Ax=b而言,如果我们简单取A=I-B,可以得到等价的x=Bx+b,从而构造迭代格式x^{(k+1)}=Bx^{(k)}+b

需要注意的是,迭代法不一定会是收敛的,也就是说x不一定会收敛到某个值,这样并不是我们所希望的,故后面会讨论一下迭代法的收敛性,我们先来谈谈迭代法的构造,从迭代格式中可以看到,我们对矩阵A进行了一次分裂,分裂的格式显然不是唯一的,我们将采取A=M-N这样一种分裂方法,可以得到线性的不动点方程x=Bx+f,B=M^{-1}N=I-M^{-1}A,f=M^{-1}b

不同的分裂法将使我们的B和f不一致,我们通常将A分裂成三个部分A=D-L-U,其中D为对角矩阵,L和U分别是下三角和上三角矩阵,这里需要注意一下符号的不同,L和U的元素都是原矩阵上三角和下三角元素符号的相反数

下面通过这样的一种分裂方式,我们介绍几种迭代形式,首先是Jacobi迭代法(同步迭代)

注意到线性迭代中的M和N,在Jacobi迭代中,我们令M=D, N=L+U,构造出迭代格式,即\begin{align}Ax&=((D)-(L+U))x=b\\Dx&=(L+U)x+b\\x&=D^{-1}(L+U)x+D^{-1}b\\x^{(k+1)}&=D^{-1}(L+U)x^{(k)}+D^{-1}b\\x^{(k+1)}&=B_{J}x^{(k)}+f_{J}\end{align}

直观上来看Jacobi迭代,就是把方程n行对应的x保留,其余维度的x移到方程的左端,用这n维的左端的式子来迭代更新n个维度的x

那么这样看就可以理解Jacobi迭代为什么是同步迭代了,因为所有的维度的x必须全部更新完成之后才可以进行下一步的迭代,由此我们介绍下一种迭代,Gauss-Seidel迭代(异步迭代)

在Gauss-Seidel迭代中,我们和上面对A进行同样的分裂方式,只不过在M,N的选取上做出了改变,我们令M=D-L,N=U,构造出迭代格式,即\begin{align}Ax&=((D-L)-(U))x=b\\(D-L)x&=Ux+b\\x&=(D-L)^{-1}Ux+(D-L)^{-1}b\\x^{(k+1)}&=(D-L)^{-1}Ux^{(k)}+(D-L)^{-1}b\\x^{(k+1)}&=B_{G}x^{(k)}+f_{G}\end{align}

直观来看Gauss-Seidel迭代,和Jacobi一样就是把方程n行对应的第n个x保留,其余的x移到方程的左端,只不过在我们更新第k个的时候会利用前面迭代更新完成了的前k-1个x进行带入计算后面的n-k个x仍然使用初始值,也就是一种异步的思想

在实际中,我们使用Jacobi迭代或者是Gauss-Seidel迭代都可能会出现不收敛或者收敛速度比较慢这样的情况,我们是不是可以试着去构造一种带参数的迭代方法,这样我们就能够利用参数的调整来实现对整个迭代方法调整已增加其收敛速度等,下面介绍SOR(Successive over relaxation method)迭代

SOR迭代的基本思想是,在以求出第k个x值的基础上用Gauss-Seidel解出第k+1个x值,然后利用这k+1个x的值和第k个x的值的线性组合来的出更好的近似解

同样的我们利用和Jacobi,Gauss-Seidel迭代方法一样的分裂方法,对A进行分裂,注意到一种矩阵的记法
\begin{align}Dx^{(k+1)}&=(1-\omega)Dx^{(k)}+\omega (b+Lx^{(k+1)}+Ux^{(k)})\\&=(1-\omega)Dx^{(k)}+\omega b+\omega Lx^{(k+1)}+\omega Ux^{(k)}\end{align}

注意到等式右端的第一部分,即(1-\omega )Dx^{(k)},这一部分其实就是之前的上一步的值

等式的第二部分就是类似Gauss-Seidel迭代得到的解然后乘上一个松弛因子(\omega

通过对上式进行化简,我们可以简单的得到\begin{align}(D-\omega L)x^{(k+1)}&=(1-\omega)Dx^{(k)}+\omega b+\omega U x^{(k)}\\&=((1-\omega D)-\omega U)x^{(k)}+\omega b\end{align}

对于D-\omega L这个矩阵我们知道,当\omega取任意值的时候,总为非奇异矩阵,也就是所总存在逆矩阵,所以上式可以继续化简(证明过程只需将矩阵的形式画出来,由于对角线元素不等于0,即可得证)

得到x^{(k+1)}=(D-\omega L)^{-1}((1-\omega D)-\omega U)x^{(k)}+\omega (D-\omega L)^{-1}b

所以我们可以根据上式建立起来SOR的迭代格式

x^{(k+1)}=B_{\omega} x^{(k)}+f_{\omega}

其中,B_{\omega} = (D-\omega L)^{-1}((1-\omega D)-\omega U),f_{\omega}=\omega(D-\omega L)^{-1}b

注意到SOR中的Guass-Seidel迭代也有区分向前或者向后Gauss-Seidel迭代,由此可以引申出SSOR(Sysmetrical Successive Over Relaxation method),此外还有Richardson迭代以及块迭代的方法,这里暂时不做出说明,以后补充

2.迭代法的收敛性分析

我们利用上面的知识可以构造迭代格式来进行迭代,但是这里就出现一个问题,所有的迭代方法都是可行的吗?这里指的可行可能是收不收敛,收敛的快慢等等,所以我们有必要对其进行规范化,系统化的分析

先来看看一般的迭代格式x^{(k+1)}=Bx^{(k)}+f

我们可以从n=0一直写到n=k+1,这样来看就有x^{(k+1)}=B^{(k+1)}x^{(0)}+(B^{k}+\cdots+B+I)f

我们必须研究矩阵B是否会变的越来越大,或者趋近于一个常数矩阵B^{*},以及x是否去趋近于x^{*}

这里引入误差向量e^{(k+1)}=x^{(k+1)}-x^{*}

只要误差向量趋近于0即可收敛,这里做个简单的计算

e^{(k+1)}=x^{(k+1)}-x^{*}=(Bx^{(k)}+f)-(Bx^{*}+f)=B(x^{(k)}-x^{*})=Be^{(k)}=B^{(k+1)}(x^{(0)}-x^{*})

下面给出收敛定理

B=(b_{ij})_{n \times n}, 则 B^{k}\rightarrow O(k \rightarrow \infty)的充要条件是B的谱半径满足\rho(B)<1

这里直接给出这个收敛定理,并没有给出证明,具体的证明思路为利用Jordan标准型以及极限关系可以证明,后续等待补充

继续不加证明地给出一个定理

设方程组Ax=b的不动点方程组为x=Bx+f,则对于任意初始近似向量x^{(0)}与任意常数向量f,求解Ax=b的基本迭代法x^{(k+1)}=Bx^{(k)}+f收敛的充要条件为\rho(B)<1

一般来说我们通过上述几个定理就可以通过计算矩阵的谱半径,也就是先计算最大的特征值,然后判断其是否大于1来判别一个基本迭代格式是否是收敛的,但是对于维度等级十分高的矩阵,我们可能得寻求一种较为简单的判别方法,下面我们不加证明地给出利用范数来判别的一个定理

求解Ax=b的基本迭代法x^{(k+1)}=Bx^{(k)}+f收敛的充分条件为
\begin{Vmatrix} B\end{Vmatrix}<1
其中\begin{Vmatrix}\cdot\end{Vmatrix}为任意一种矩阵范数

3.误差估计

对于迭代格式的收敛性我们已经讨论过了,下面给出误差的估计,主要是用来计算相应到达误差范围相应迭代次数的值,下面给出一个定理

设求解 Ax=b 的基本迭代法为x^{(k+1)}=Bx^{(k)}+f, x^{(0)}为初始迭代向量,且迭代矩阵的一矩阵范数\begin{Vmatrix}B\end{Vmatrix}=q<1, 则
\begin{Vmatrix}x^{(k)}-x^{*}\end{Vmatrix}\leq \frac{\begin{Vmatrix}B\end{Vmatrix}}{1-\begin{Vmatrix}B\end{Vmatrix}} \begin{Vmatrix}x^{(k)}-x^{(k-1)}\end{Vmatrix}
\begin{Vmatrix}x^{(k)}-x^{*}\end{Vmatrix}\leq \frac{\begin{Vmatrix}B\end{Vmatrix}^{k}}{1-\begin{Vmatrix}B\end{Vmatrix}}\begin{Vmatrix}x^{(1)}-x^{(0)}\end{Vmatrix}

该定理证明可以利用之前所介绍的Banach引理来证明

用上面的式子,可以求解出来精度\begin{Vmatrix}e^{(k)}\end{Vmatrix}\leq \epsilon的迭代步数,令步数为k,B的范数为q,则有
k\geq \frac{\epsilon (1-q)}{\begin{Vmatrix}x^{(0)}-x^{(1)}\end{Vmatrix}\begin{vmatrix}ln(q)\end{vmatrix}}

4.关于几类特殊矩阵进行迭代法的收敛性

首先我们来看看对角占优矩阵进行基本迭代法的收敛性

对角占优矩阵可以简单的划分成严格对角占优弱对角占优

严格对角占优是指对角线上的元素的绝对值比相同行其他元素的绝对值的和都大,这里不存在等号的条件
弱对角占优是严格对角占优的基础上添加等号的条件,也就是说对角线上的元素的绝对值大于等于相同行其他元素的绝对值的和

我们直接不加证明的给出一个定理:

对于严格对角占优矩阵和弱对角占优矩阵,我们使用任意的初始向量,构造Jacobi迭代格式或者Gauss-Seidel迭代格式,结果均收敛

接下来,我们看一下另外一种特殊矩阵,即对称正定矩阵

给出一个定理

设A对称,且对角元素为正,则方程组Ax=b的Jacobi迭代格式收敛的充分必要条件就是A和2D-A均正定,其中D为A生成的对角矩阵

同样的,我们对于Gauss-Seidel迭代也给出一个定理

设A对称正定,则方程组Ax=b的Gauss-Seidel迭代收敛

对SOR的迭代格式,比较复杂,对于某些特定的矩阵有着一定规律,给出一个定理

对任意的A \in R^{n \times n},如果它的对角元素皆非0,则SOR迭代的迭代矩阵B_{\omega}的谱半径\rho(B_{\omega})与松弛系数\omega有着下列关系\rho(B_{\omega}) \geq \begin{vmatrix} (1-\omega)\end{vmatrix}

由上述定理可以推出,方程组使用SOR方法收敛的一个必要条件 0 < \omega < 2

反过来,也有一个定理

A \in R^{n \times n},且A对称正定,如果0<\omega<2, 则求解Ax=b的SOR迭代格式收敛

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,383评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,522评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,852评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,621评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,741评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,929评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,076评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,803评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,265评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,582评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,716评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,395评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,039评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,027评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,488评论 2 361
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,612评论 2 350

推荐阅读更多精彩内容