线性方程组的解法.ppt

上传人:博****1 文档编号:569780664 上传时间:2024-07-31 格式:PPT 页数:39 大小:548KB
返回 下载 相关 举报
线性方程组的解法.ppt_第1页
第1页 / 共39页
线性方程组的解法.ppt_第2页
第2页 / 共39页
线性方程组的解法.ppt_第3页
第3页 / 共39页
线性方程组的解法.ppt_第4页
第4页 / 共39页
线性方程组的解法.ppt_第5页
第5页 / 共39页
点击查看更多>>
资源描述

《线性方程组的解法.ppt》由会员分享,可在线阅读,更多相关《线性方程组的解法.ppt(39页珍藏版)》请在金锄头文库上搜索。

1、线性方程组的解法线性方程组的解法解线性方程组的迭代法解线性方程组的迭代法Iterative Methods for Linear SystemsJacobi迭迭代和代和Gauss-Seidel迭代迭代迭代法的矩阵表示迭代法的矩阵表示Matrix form of the Iterative Methods线性方程组的解法在计算数学中占有极其线性方程组的解法在计算数学中占有极其重要的地位。重要的地位。线性方程组的解法大致分为线性方程组的解法大致分为迭代法迭代法与与直接直接法法两大类两大类雅可比雅可比(Jacobi)迭代法迭代法举例说明雅可比迭代法的基本思路举例说明雅可比迭代法的基本思路例例4.1特

2、点特点:系数矩阵主系数矩阵主对角元均不为零对角元均不为零取迭代初值取迭代初值x1(0) =0, x2(0) =0, x3(0) =0将方程改写成如下等价形式将方程改写成如下等价形式据此建立迭代公式据此建立迭代公式 x(0) 0 0 0 x(1) 0.7778 0.8000 0.8667 x(2)0.96300.96440.9778 x(3)0.99290.99350.9952 x(4) 0.99870.99880.9991x1* 1.0000,x2* 1.0000,x3* 1.0000准确解准确解可以看出,迭代每前进一步,结果就逼近准确解一步可以看出,迭代每前进一步,结果就逼近准确解一步 迭代

3、过程收敛迭代过程收敛矩阵形式矩阵形式: 以上这种迭代方法称以上这种迭代方法称雅可比雅可比(Jacobi)迭代法。迭代法。基本思想:基本思想:将方程组的求解问题转化为重复将方程组的求解问题转化为重复计算一组彼此独立的线性表达式。计算一组彼此独立的线性表达式。(i = 1,2, ,n; k=0,1,2, )(i = 1,2, ,n)设有方程组设有方程组将第将第i个方程的第个方程的第i个变量个变量xi分离出来,据此建立分量形式分离出来,据此建立分量形式的的雅可比迭代公式雅可比迭代公式如果如果用矩阵形式来表示雅可比迭代公式用矩阵形式来表示雅可比迭代公式设有方程组设有方程组: AX = b 其中其中A(

4、aij)n为非奇异矩阵,为非奇异矩阵,X=(x1, x2, , xn)T, b=(b1, b2, , bn)T,唯一解为,唯一解为X*=(x1*, x2*, , xn*)T将将A分解为:分解为:AU+D+L其中其中于是于是 (U+D+L)X = b得得 X D (U+L)X +Db据此得矩阵形式的据此得矩阵形式的雅可比迭代公式雅可比迭代公式 X(k+1)D(U+L)X(k) +Db记记 BD (U+L), f Db有有B:迭代矩阵迭代矩阵( k=0,1,2, )X(k+1)= BX(k) + f任任取取 X(0), 迭代计算产生向量序列迭代计算产生向量序列:若若则迭代过程收敛。则迭代过程收敛。

5、x* 是方程组是方程组 Ax = b 的解的解X(1), X(2), X(k),迭代法迭代法适用于解适用于解大型稀疏方程组大型稀疏方程组(万阶以上的方程组万阶以上的方程组,系数矩阵中零元素占很系数矩阵中零元素占很大比例大比例,而非零元按某种模式分布而非零元按某种模式分布)背景背景: 电路分析、边值问题的数值解和数学物电路分析、边值问题的数值解和数学物理方程理方程问题问题: (1)如何构造迭代格式?如何构造迭代格式? (2)迭代格式是否收敛?迭代格式是否收敛? (3)收敛速度如何?收敛速度如何? (4)如何进行误差估计?如何进行误差估计?高斯塞德尔高斯塞德尔Gauss-Seidel迭代法迭代法G

6、auss-Seidel迭代法是通过对迭代法是通过对Jacobi迭代法稍加改迭代法稍加改进得到的。进得到的。Jacobi迭代法的每一步迭代新值迭代法的每一步迭代新值 x(k+1)=x1(k+1),x2(k+1) , ,xn(k+1)T 都是用前一步的旧值都是用前一步的旧值 x(k)=x1(k),x2(k) , ,xn(k)T的全部分量计算出来的。那么在计算第的全部分量计算出来的。那么在计算第i个分量个分量xi(k+1) 时,已经计算出时,已经计算出 x1(k+1),x2(k+1) , ,xi-1(k+1) (i-1)个分量,这些分量新值没用在计算个分量,这些分量新值没用在计算xi(k+1) 上。

7、将这些上。将这些(i = 1,2,n)(i = 1,2,n; k =0,1,2,)将这些分量利用起来,有可能得到一个收敛更将这些分量利用起来,有可能得到一个收敛更快的迭代公式。快的迭代公式。具体作法:将分量形式的雅可比迭代公式右端具体作法:将分量形式的雅可比迭代公式右端前前(i-1)个分量的上标为个分量的上标为k换成换成k+1,即,即分量形式的分量形式的高斯高斯-塞德尔迭代公式塞德尔迭代公式。用矩阵形式来表示高斯用矩阵形式来表示高斯-塞德尔迭代公式塞德尔迭代公式DX(k+1)b-LX(k+1) - UX(k)即即 (D+L)X(k+1) -UX(k)+b如果如果 (D+L)存在,则存在,则 X

8、(k+1) (D+L) UX(k)+ (D+L) b记记 B(D+L), f (D+L) b则则( k=0,1,2,)X(k+1)= BX(k) + f矩阵形式的矩阵形式的高斯高斯-塞德尔迭代公式。塞德尔迭代公式。B:迭代矩阵迭代矩阵例例例例Jacobi迭代算法迭代算法A=9 -1 -1;-1 10 -1;-1 -1 15;b=7;8;13;x=0;0;0;er=1;k=0;while er0.00005 er=0;k=k+1; for i=1:3 s=0;t=x(i);x(i)=0; for j=1:3 s=s+A(i,j)*x(j); end x(i)=t; y(i)=(b(i)-s)/A

9、(i,i); er=max(abs(x(i)-y(i),er); end x=y;xend0.7778 0.8000 0.86670.9630 0.9644 0.97190.9929 0.9935 0.99520.9987 0.9988 0.99910.9998 0.9998 0.99981.0000 1.0000 1.00001.0000 1.0000 1.0000Gauss-Seidel迭代算法迭代算法A=9 -1 -1;-1 10 -1;-1 -1 15;b=7;8;13;x=0;0;0;er=1;k=0;while er0.00005 er=0;k=k+1; for i=1:3 s=0

10、;t=x(i);x(i)=0; for j=1:3 s=s+A(i,j)*x(j); end x(i)=(b(i)-s)/A(i,i); er=max(abs(x(i)-t),er); end xend 0.7778 0.8778 0.9770 0.9839 0.9961 0.9987 0.9994 0.9998 0.9999 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000从计算结果可以明显看出,从计算结果可以明显看出,Gauss-Seidel迭代迭代法比法比Jacobi迭代法效果好。迭代法效果好。一般而言,一般而言, Gauss-Seidel迭代法收敛速度

11、比迭代法收敛速度比Jacobi迭代法快,但这两种迭代法的收敛范围迭代法快,但这两种迭代法的收敛范围并不完全重合,而只是部分相交,有的时候并不完全重合,而只是部分相交,有的时候Jacobi迭代法可能比迭代法可能比Gauss-Seidel迭代法收敛速迭代法收敛速度更快。甚至可以举出度更快。甚至可以举出Jacobi迭代法收敛而迭代法收敛而Gauss-Seidel迭代法发散的例子。迭代法发散的例子。Gauss-Seidel迭代法和迭代法和Jacobi迭代法的异同:迭代法的异同:Jacobi迭代法:公式简单,每次只需做矩阵和向量的迭代法:公式简单,每次只需做矩阵和向量的 一次乘法;特别适合于并行计算;一

12、次乘法;特别适合于并行计算;不足之处:需存放不足之处:需存放X(k)和和X(k+1)两个存储空间。两个存储空间。Gauss-Seidel迭代法:只需一个向量存储空间,一旦迭代法:只需一个向量存储空间,一旦计算出了计算出了xj(k+1)立即存入立即存入xj(k)的位置,可节约一套存储的位置,可节约一套存储单元单元 ;有时起到加速收敛的作用。;有时起到加速收敛的作用。是一种典型的串行算法,每次迭代中必须依次计算解是一种典型的串行算法,每次迭代中必须依次计算解的各个分量。的各个分量。超超松驰松驰(SOR)迭代法迭代法超松驰迭代法是迭代方法的一种加速方法,其计超松驰迭代法是迭代方法的一种加速方法,其计

13、算公式算公式 简单,但需要选择合适的松驰因子,以保简单,但需要选择合适的松驰因子,以保证迭代过程有较快的收敛速度。证迭代过程有较快的收敛速度。设有方程组设有方程组 AX = b 其中其中A(aij)n为非奇异矩阵,为非奇异矩阵,X=(x1, x2, , xn)T, b=(b1, b2, , bn)T,记,记X(k)为第为第k步迭代近似值,步迭代近似值,则则 r(k) = b AX(k)表示近似解表示近似解X(k)的残余误差,引进如下形式的加速迭的残余误差,引进如下形式的加速迭代公式代公式 X(k+1) X(k)+w(b AX)w称作松驰因子。其分量形式为称作松驰因子。其分量形式为选择适当的松驰

14、因子,可期望获得较快的收敛速度。选择适当的松驰因子,可期望获得较快的收敛速度。如果在计算分量如果在计算分量xi(k+1) 时,考虑利用已经计算出来时,考虑利用已经计算出来的分量的分量x1(k+1),x2(k+1) , ,xi-1(k+1) ,又可得到,又可得到一个新的迭代公式一个新的迭代公式特别当特别当aii0时,将上面迭代公式应用于方程组时,将上面迭代公式应用于方程组(i=1,2, n)由此得下列由此得下列超松驰超松驰(SOR)迭代公式迭代公式(i=1,2, n; k = 0,1,2,3, )当当w1时,称超松驰法;当时,称超松驰法;当w1时,称低松时,称低松驰法;当驰法;当w1时,就是时,

15、就是Gauss-Seidel迭代公迭代公式。式。所以超松驰所以超松驰(SOR)迭代法可以看成是迭代法可以看成是Gauss-Seidel迭代法的加速,而迭代法的加速,而Gauss-Seidel迭代法迭代法是超松驰方法的特例。是超松驰方法的特例。定理定理4.8 若若A是对称正定矩阵是对称正定矩阵,则当则当0w2时时SOR迭代法解方程组迭代法解方程组 Ax = b 是收敛的是收敛的定理定理4.9 若若A是是严格对角占优矩阵严格对角占优矩阵,则当则当0w0.0005 er=0;k=k+1; for i=1:3 s=0;t=x(i);x(i)=0; for j=1:3 s=s+A(i,j)*x(j);

16、end x(i)=(1-w)*t+w*(b(i)-s)/A(i,i); er=max(abs(x(i)-t),er); endendkk=10x= 1.1999 1.3999 1.5999=1.2,只需只需k=6 块迭代块迭代法法简介简介设设 ARnn, xRn, bRn将方程组将方程组A x = b中系数矩阵中系数矩阵A分块分块其中其中, AiiRnini, AijRninj , xiRni, biRni将将A分解分解, A = DB LB UB (1)Jacobi块迭块迭代代 DB x(k+1) = (LB + UB)x(k) + bi=1,2, r(2)Gauss-Seidel块迭块迭代

17、代 DB x(k+1) = LB x(k+1)+ UBx(k) + bi=1,2, r迭代法的收敛性迭代法的收敛性Convergence of iterative method迭代矩阵谱半径迭代矩阵谱半径Spectral radius对角占优矩阵对角占优矩阵diagonally dominant matrix 原始方程原始方程: Ax = b迭代格式迭代格式: x(k+1) = Bx(k) + f定理定理4.1(迭代法基本定理迭代法基本定理) 迭代法迭代法 x(k+1) = Bx(k) + f收敛的收敛的充要条件充要条件是是 (B) 1迭代法有着算法简单,程序设计容易以及可节迭代法有着算法简单

18、,程序设计容易以及可节省计算机存贮单元等优点。但是迭代法也存在省计算机存贮单元等优点。但是迭代法也存在着收敛性和收敛速度等方面的问题。因此弄清着收敛性和收敛速度等方面的问题。因此弄清楚迭代法在什么样的条件下收敛是至关重要的。楚迭代法在什么样的条件下收敛是至关重要的。证证 对任何对任何 n 阶矩阵阶矩阵B都存在非奇矩阵都存在非奇矩阵P使使 B = P 1 J P其中其中, J 为为B的的 Jordan 标准型标准型其中其中, Ji 为为Jordan块块其中其中,i 是矩阵是矩阵B的特征值的特征值, 由由 B = P 1 J PB k = (P 1 J P) (P 1 J P) (P 1 J P)

19、= P 1 J k P迭代法迭代法 x(k+1) = Bx(k) + f收敛收敛 (i = 1, 2, r)(i = 1, 2, r)谱半径谱半径 (B) 1例例 线性方程组线性方程组 Ax = b, 分别取系数矩阵为分别取系数矩阵为试试分析分析Jacobi 迭代法迭代法和和 Seidel 迭代法的敛散性迭代法的敛散性(1)(2) A2=2, -1, 1; 1, 1, 1; 1, 1, -2两种迭代法之间没有直接联系两种迭代法之间没有直接联系对矩阵对矩阵A1,求求A1x = b 的的Jacobi迭代法收敛迭代法收敛,而而Gauss-Seidel迭代法发散迭代法发散;对矩阵对矩阵A2,求求A2x

20、 = b 的的Jacobi迭代法发散迭代法发散,而而Gauss-Seidel迭代法收敛迭代法收敛.证证 由由 (k) = B (k-1),得得 | (k)| | B| | (k-1)| (k = 1, 2, 3, )所以所以定理定理4.2(迭代收敛的充分条件迭代收敛的充分条件)设有迭代公式设有迭代公式 x(k+1) =Bx(k) +f,如果,如果|B|1, 则对任意初始向量则对任意初始向量x(0)和任意和任意f,迭代公式收敛。,迭代公式收敛。| (k)| | B|k | (0)| | B| |-1| + |-1|10 |-1| + |-1|15 |-1| + |-1|a11| |a12| +

21、|a13|a22| |a21| + |a23|a33| |a31| + |a32|定理定理4.3 若若Ax=b的系数矩阵的系数矩阵A是严格对角占优是严格对角占优矩阵矩阵,则则Jacobi迭代和迭代和Seidel迭代均收敛迭代均收敛证证 由于矩阵由于矩阵A严格对角占优严格对角占优由由A矩阵构造矩阵构造Jacobi迭代矩阵迭代矩阵BJ = D-1(D A) 第第i行绝对值求和行绝对值求和所以所以例例4.2 试对下列方程组建立收敛的迭代公式试对下列方程组建立收敛的迭代公式解解 通过观察可发现这个方程组的系数矩阵不是对通过观察可发现这个方程组的系数矩阵不是对角占优的。但经行交换后可得下列等价形式角占优的。但经行交换后可得下列等价形式此等价形式的系数矩阵是严格对角占优阵,据此建此等价形式的系数矩阵是严格对角占优阵,据此建立的雅可比迭代公式和高斯塞德尔迭代公式收敛。立的雅可比迭代公式和高斯塞德尔迭代公式收敛。收敛速度:称收敛速度:称R(B)=-ln (B) 为迭代法的渐为迭代法的渐进收敛速度简称收敛速度。进收敛速度简称收敛速度。

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 研究生课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号