矩阵A紧凑格式的Doolittle分解为课件_第1页
矩阵A紧凑格式的Doolittle分解为课件_第2页
矩阵A紧凑格式的Doolittle分解为课件_第3页
矩阵A紧凑格式的Doolittle分解为课件_第4页
矩阵A紧凑格式的Doolittle分解为课件_第5页
已阅读5页,还剩163页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第三章线性方程组的解第三章线性方程组的解概述消元法三角分解法平方根法向量与范数方程组的性态与误差分析迭代法概述3.1概述大量实际计算问题=>一组线性方程组=>如何求解?1.术语非齐次线性方程组:若记:

则:(1.1)式可表示为Am×nx=b---线性方程组的矩阵表示)1.1(

22112222212111212111ïïîïïíì=+++=+++=+++mnmnmmnnnnbxaxaxabxaxaxabxaxaxaLLLLLLLLLLLLLLúúúúûùêêêêëé=aaaaaaaaamnmmnnLMMMLL212222111211Aúúúúûùêêêêëé=xxxnM21xúúúúûùêêêêëé=bbbmM21b3.1概述大量实际计算问题=>一组线性方程组=>如何求解?分类:据方程的个数与未知数的个数间关系,分为:m<n,即方程的个数小于未知数的个数,称为亚定方程组,有无穷多组解m>n,即方程的个数大于未知数的个数,称为超定方程组,或矛盾方程组。它没有一般意义下的解,但可以求其广义解。m=n,一般意义下的方程组,本章主要讨论的重点面临的问题:方程组Ax=b有没有解?有多少解?如何求解?分类:据方程的个数与未知数的个数间关系,分为:

2.Crammer法则求解An×nx=b方程组Ax=b有唯一解的充要条件是:|A|≠0A可逆A是非奇异矩阵Ax=b在A可逆时,存在唯一解结论:Crammer法则计算量非常大,需算n+1个n阶行列式。如:n=100,1000次/秒的计算机要算10120年nnninninniiiiiaabaaaabaaDADDDxLLMMMMMLL11111111111|,|,+-+-=== 2.Crammer法则求解An×nx=bnnninni3线性方程组的数值解法:直接法:思想:经有限步运算求得精确解的方法:舍入误差,因此也是近似解高斯消元法及其变形特点:它可靠且效率高,但它只适用于中小型方程组。迭代法:思想:构造适当的初始近似解向量x,按一定的法则,使之逐步逼近精确解,得到一个满足精度要求的近似解。即是用某种极限过程逐步逼近准确解的方法。主要方法:Jaccobi迭代法,Gauss-Sidel迭代法等3线性方程组的数值解法:3.1.1GAUSS消元法一.几种可以直接求解的线性方程组对角矩阵:=>n次除法3.1.1GAUSS消元法一.几种可以直接求解的线下三角矩阵:

即:l11x1=b1 l21x1+l22x2=b2 l31x1+l32x2+l33x3=b3 …… li1x1+li2x2+……+liixi=bi ……ln1x1+ln2x2+……+lnnxn=bn代入下三角矩阵:代入上三角矩阵:即:u11x1+u12x2+………+u1nxn=b1u22x2+………+u2nxn=b2 ……uiixi+ui,i+1xi+1+…+ui,nxn=bi un-1,n-1xn-1+un-1,nxn=bn-1 un,nxn=bn回代上三角矩阵:回代二、同解变换初等方阵:

:rirj:ri*k二、同解变换:rirj:ri*k注对矩阵A实施初等行变换

对A左乘初等方阵初等方阵是可逆的,多个初等方阵的积仍然可逆可逆阵A经有限次初等行变换单位矩阵:rj+k*ri:rj+k*ri2.对方程组Ax=b作如下的变换,解不变:交换两个方程的次序一个方程的两边同时乘以一个非0数一个方程的两边………,再将之加到另一个方程将方程组Ax=b对应的增广矩阵(A,b),作如下变换,解不变交换矩阵的两行某行乘以一个非0数某行乘以一个非0数,加到另一行增广矩阵第i行第i个方程对方程组Ax=b的增广矩阵作同解变换对其增广矩阵左乘一系列的初等矩阵2.对方程组Ax=b作如下的变换,解不变:增广矩阵第i行三、Gauss消元法消元法基本思想:对Ax=b的增广矩阵(A|b)进行初等变换,变成可直接求解的三种形式之一,再求解Gauss消元法:将A化为上三角阵回代求解=三、Gauss消元法消元法基本思想:对Ax=b的增广矩阵(A用高斯消去法解下列线性方程组原方程组对应的增广矩阵为:用高斯消去法解下列线性方程组1.消元步骤方程组AX=b的矩阵表示为:A(1)x=b(1)初始状态:1.消元步骤方程组AX=b的矩阵表示为:A(1)x=b(第一次消元:消去对角线下第1列元素(a11≠0)

方法:消去对角线下第1列元素为0,即ri-r1×ai1/a11:(i=2,3,…

第一次消元:消去对角线下第1列元素(a11≠0)第二次:若a22≠0,则消去对角线下第二列为0, 即:ri-r2×ai2/a22(i=3,4,…..)

第二次:若a22≠0,则消去对角线下第二列为0,经过k-1次消元后,增广矩阵变为:经过k-1次消元后,增广矩阵变为:第k次消元:若akk≠0,则消去对角线下第k列元素即:ri-rk×aik/akk(i=k+1,k+2,……)第k次消元:若akk≠0,则消去对角线下第k列元素2.经n次消元后得到同解方程组A(n)x=b(n),且A(n)为上三角矩阵,可逐步回代求解即:UX=YUY2.经n次消元后得到同解方程组A(n)x=b(n),且A(3.算法步骤将方程组用增广矩阵(A|b)=(aij)n×(n+1)表示,注意c语言中数组下标从0开始,故i=0,1,…,n-1,j=0,1,…,n消元:对k=0,1,……,n-2(消去第k列对角线下的元素)计算li,k=ai,k/ak,,k第i行-第k行×li,k(i=k+1,k+2,…n-1)

回代求解:xi=(ai,n-∑xjai,j)/ai,i.i=n-1,….,0,j=i+1,i+2,…..n-13.算法步骤将方程组用增广矩阵(A|b)=(aij)4.时间复杂度消元过程中:第k次消元每行均需计算第k行要乘以的常数:lik=aik/akk,消去第i行(第k列)时,i行各列元素加上k行各列元素乘以常数lik:aij=aij-akj*lik

(j=k,k+1,…,n),故需做n-k+1次乘法、加减法一共要做n-k行综上:第k次消元,除法:n-k次,乘法:(n-k)*(n-k+1)次,加减法:(n-k)*(n-k+1)次整个消元过程:除法:乘法、加减法:4.时间复杂度消元过程中:综上:算法时间度量为O(n3)综上:算法时间度量为O(n3)5.Gauss顺序消元法的适用条件GAUSS直接消元法的适用条件:akk(k)≠0A的各阶顺序主子式均不为0时,有akk(k)≠0(证明略)A是严格对角占优矩阵,则:akk(k)≠0(证明略)举例说明A的每行主对角元的绝对值>同行其余元素的绝对值之和5.Gauss顺序消元法的适用条件GAUSS直接消元法的适例2:用Gauss消元法解方程组(4位十进制机)

0.0001x1+x2=1x1+x2=2因要对阶,损失有效数字,求得x1=0,x2=1显然x1,x2不是方程的解,怎么办???x1+x2=20.0001x1+x2=1解之,得到x1=1,x2=1,接近与精确解

例2:用Gauss消元法解方程组(4位十进制机)3.1.2列主元Gauss消元法当采用Gauss消元法求解时,若|akk|《|aik|,会导致误差扩散第k步消元时,ri-rk*aik/akk=aij-akj*aik/akk因为|akk|<<|aik|,若rk行的误差为e=(ek+1,….,en+1),则e将被扩大(aik/akk)倍Gauss消元法在特殊情况下是不稳定的3.1.2列主元Gauss消元法当采用Gauss消元法求解解决办法:选择列主元:即选出第k列对角线下绝对值最大者设|atk|=max|aik|k≤i≤nrkrt以新的akk作为主对角元进行消元故列主元消元法只是在每步消元之前选出主对角元举实例说明列主元Gauss消元法的计算过程解决办法:列主元算法,只需在消元的第1步前增加以下几行代码i=k;//选择第k列的主元 for(j=k+1;j<n;j++) if(fabs(a[j][k])>fabs(a[i][k]))i=j; if(i!=k) for(j=k;j<=n;j++) { tmp=a[k][j];

a[k][j]=a[i][j];

a[i][j]=tmp; }列主元算法,只需在消元的第1步前增加以下几行代码3.1.3Gauss-Jordan消元法算法思想:在Gauss消元的第k次消元时,只是利用akk,将第k行以下各行的第k列消元为0,最终将系数矩阵消元为s上三角阵。将上述算法改进:第k次消元时,用akk将第k列的所有元素(akk除外)均消元为0,则系数矩阵最终成为对角矩阵(或单位矩阵)

3.1.3Gauss-Jordan消元法算法思想:第k步消元:若akk≠0,则消去除对角线外的第k列元素方法:计算:lik,即消去第k列元素(akk除外)为0,即ri-rk×lik第k步消元:若akk≠0,则消去除对角线外的第k列元素第k-1次消元结果第k次消元结果第k-1次消元结果第k次消元结果经过n次消元,原方程的增广矩阵变为:则,方程的根为:经过n次消元,原方程的增广矩阵变为:则,方程的根为:示例:Gauss-Jordan消元法求解示例:Gauss-Jordan消元法求解Gauss-Jordan消元法的归一化消元后对角线元素全为1,即单位矩阵E方法:第k次消元时,先将akk化为1(第k行除以akk),再用第k行消去各行k列的元素Gauss-Jordan消元法的归一化消元后对角线元素全为1经过n-1次消元,则原方程的增广矩阵变为:则,方程的根为:经过n-1次消元,则原方程的增广矩阵变为:则,方程的根为:归一化Gauss-Jordan消元法步骤:消元:(c/c++实现)对k=0,1,……,n-1(消去除对角线外第k列)第k行除以akk,将akk化为1第i行-第k行×aik(i=0,1,…n-1,且i≠k)增广矩阵最后一列ai,n即为方程组的解,无需回代归一化Gauss-Jordan消元法步骤:示例:用归一化的Gauss-Jordan消元法求解示例:用归一化的Gauss-Jordan消元法求解归一化的Gauss-Jordan消元法的应用可逆阵A经有限次初等行变换单位矩阵故可利用Gauss-Jordan消元法,构造矩阵(A|E)Gauss-Jordan消元(E|A-1)归一化的Gauss-Jordan消元法的应用示例:用Gauss-Jordan消元法求矩阵的逆矩阵示例:用Gauss-Jordan消元法求矩阵的逆矩阵3.2矩阵的三角分解法Gauss消元法的矩阵表示第一次消元r2-r1*l21ri-r1*li1即:第一步消元,相当于左乘初等变换矩阵L1,相当于:L1A(1)=A(2),L1b=b(2)3.2矩阵的三角分解法Gauss消元法的矩阵表示r2-r第二次消元:r3-r2*l32ri-r2*li2即:L2A(2)=A(3),L2L1A(1)=A(3)第二次消元:r3-r2*l32ri-r2*经过n-1次消元后Ln-1Ln-2…L2L1A=A(n),Ln-1Ln-2…L2L1b=b(n)故:A=L1-1L2-1…Ln-2-1Ln-1-1A(n),令L=L1-1L2-1…Ln-2-1Ln-1-1,则:经过n-1次消元后故:A=L

A(n)=L

UGauss消元法的实质:将系数矩阵分解为两个三角矩阵的乘积将矩阵A分解成一个上三角、下三角矩阵的乘积,即:A=LU,矩阵的三角分解、LU分解故:A=LA(n)=LU三角分解是从A的元素直接得到L、U的元素,不用中间步骤,即不用消元,所以称直接三角分解,或直接分解。A的LU分解只要求L是一个下三角阵、U是一个上三角阵,当A有LU分解时,这种分解不是唯一的。当L是一个单位下三角阵或者U是一个单位上三角阵时,A的这两种LU分解是唯一的。三角分解是从A的元素直接得到L、U的元素,不用中间步骤,即不上述是A的两种不同的三角分解一般地,若A=LU是一个三角分解,任取与A同阶的 非奇异对角矩阵D,则A=(LD)(D-1U)=L1U1 也是A的三角分解。上述是A的两种不同的三角分解常用的两种分解:L为单位下三角阵而U为一般上三角阵的分解称为Doolittle

分解一般上三角单位下三角常用的两种分解:一般上三角单位下三角L为一般下三角阵而U为单位上三角阵的分解称为Crout分解一般下三角单位上三角L为一般下三角阵而U为单位上三角阵的分解称为Crout定理:n阶矩阵A存在唯一的杜利特尔分解、克洛特分解的充要条件是A的顺序主子矩阵Ak

(k=1,2,…,n-1)非奇异(各阶顺序主子式非0)证明略(反证法)若不唯一,则可设A=L1U1=L2U2,推出因下三角矩阵的积仍然是下三角阵,上三角矩阵的积仍然是上三角阵下三角阵=上三角阵,则两个必为单位矩阵定理:n阶矩阵A存在唯一的杜利特尔分解、克洛特分解的充要1.Doolittle分解据矩阵的乘法,知:A的第一行元素:,故 第一列元素:,故:A的第二行元素:故:第二列元素: 故:=A=LU1.Doolittle分解=A=LU一般地:矩阵A紧凑格式的Doolittle分解为课件

推而广之:比较A第k行:

求U的第k行求U的第k行比较A第k列求L的第k列比较A第k列求L的第k列即:即:计算顺序为:为了便于记忆,将A的LU分解写成紧凑格式:123456.....计算顺序为:123456.对矩阵A进行Doolittle分解解:矩阵A紧凑格式的Doolittle分解为:对矩阵A进行Doolittle分解对矩阵A进行Doolittle分解,并求|A|解:-12212241-3-3对矩阵A进行Doolittle分解,并求|A|-122122三角分解法解线性方程组方程组Ax=b,若A非奇异,且有三角分解A=LU,则原方程组等价于:LUx=b令:Ux=y,则Ly=b故可先解出y,再求x所以等价于求U阵第k行元素ukj的公式,故可将增广矩阵(A|b)同时做LU分解,则最后一列即为y,再用Ux=y求解三角分解法解线性方程组方程组Ax=b,若A非奇异,且有三角例:用Doolittle分解法求解线性方程组:解:对增广矩阵进行Doolittle分解故:Ux=y为:所以x3=1,x2=-2,x1=222332-131-5266例:用Doolittle分解法求解线性方程组:22332-1用三角分解法求矩阵A的逆矩阵A-1若AX=E,则X=A-1用三角分解法求矩阵A的逆矩阵A-1若AX=E,则X=A-12.Crout分解类同于Doolittle分解比较两边可得:2.Crout分解类同于Doolittle分解紧凑格式的Crout分解为:214365.....紧凑格式的Crout分解为:214365.原方程:AX=b变为:LUX=b令Ux=y,则Ly=b,可见yk的表达式完全类同于ukj的表达式,故可将常向量放在系数矩阵之后,对整个增广矩阵进行Crout三角分解原方程:AX=b变为:LUX=b则UX=y的解即为线性方程组的解:即:则UX=y的解即为线性方程组的解:例3-11:分别用Doolittle、Crout分解法求解线性方程组解一:Doolittle分解:2-11521-14-61/23/23y向量例3-11:分别用Doolittle、Crout分解法求解线则解Ux=y可得线性方程组的解解之,得:x3=2,x2=-1,x1=1则解Ux=y可得线性方程组的解解二:Crout分解法则Ux=y的解即为原方程组的解解之,得:x3=2,x2=-1,x1=1-1/4-3/2423/22422-1/21/25/2注意:此处与Doolittle方法的区别解二:Crout分解法-1/4-3/2423/22422-13.追赶法解三对角线性方程组概念:三对角矩阵:除主对角线、次主对角线上的元素外,其余元素均为03.追赶法解三对角线性方程组概念:对系数矩阵进行Crout分解:比较矩阵两边可得:故:|A|=|L|*|U|=l1*l2*……*ln对系数矩阵进行Crout分解:定理3-6:定理:若A为对角占优的三对角阵,即:满足则方程组有唯一的LU分解证明:要证三对角方程组具有唯一的LU分解即要证:三对角方程组的各阶顺序主子式均≠0也即要证:该方程组组的Crout分解中lii

0定理3-6:定理:若A为对角占优的三对角阵,即:满足由于三对角矩阵的特殊性,无需用二维数组存放系数矩阵,而采用一维数组A,B,C,D存放所有的非0元求解步骤:三角分解:A=LU则方程组Ax=fLUx=f,令:Ux=y,则Ly=f故先解方程组Ly=f,求出y,再解Ux=y即可由于三对角矩阵的特殊性,无需用二维数组存放系数矩阵,而采用一追:由Ly=f,得:赶:再从Ux=y,回代求解:追:由Ly=f,得:示例:2示例:23.3平方根法:系数矩阵为对称正定矩阵的方程组称为对称正定方程组对称正定方程组可用高斯消去法、LU分解法求解也可导出计算量更小的平方根法利用对称正定矩阵的三角分解(Cholesky)求解对称正定方程组的方法称为平方根法对称矩阵:A=AT对称正定矩阵A=AT,且对任意非零向量x有:f(x)=xTAx>03.3平方根法:系数矩阵为对称正定矩阵的方程组称为对称正定对称正定阵A的几个重要性质A1

亦对称正定,且aii>0A的顺序主子阵

Ak

亦对称正定A的特征值i

>0

A的全部顺序主子式

det(Ak

)>0对称正定阵A的几个重要性质对称正定矩阵的乔累斯基分解对称正定矩阵A=Rn×n,存在唯一的单位下三角矩阵L和对角矩阵D,使A=LDLT证明:前面已经证明了对称正定矩阵A做Doolittle分解的唯一性,设A=LU(其中L为单位下三角矩阵,U为上三角矩阵)令 ,其中di为U阵对角线元素,故di>0则:A=LD(D-1U),AT=(D-1U)TDTLT=(D-1U)TDLT,又A=AT,故:LD(D-1U

)=(D-1U)DLT由上式知:L=(D-1U)T,LT=D-1U所以A=LDLT对称正定矩阵的乔累斯基分解对称正定矩阵A=Rn×n,存在唯一的主对角元素均为正数的下三角矩阵L,使A=LLT,此即:对称正定矩阵的乔累斯基分解证明:因A可唯一分解为A=LDLT,且D是di>0的对角矩阵故可将D进行拆分令:对称正定矩阵A=Rn×n,存在唯一的主对角元素均为正数的下三比较的等式两边,可得第j列元素:比较的等式两边,可得计算顺序为:l11li1li2…lin|A|=|L||LT|=l112…lnn2计算顺序为:l11li1li2…lin示例:对矩阵做乔累斯基分解,并求|A|乔累斯基分解的缺点:开方示例:对矩阵做乔累斯基分解,并求|A|改进的平方根法:利用已经证明的结论:对称正定矩阵A,可唯一分解为:A=LDLT改进的平方根法:利用已经证明的结论:对称正定矩阵A,可唯一分故:d1=u11,d1l12=u12,…,dilik=uik则实对称正定矩阵A=LDLT,可视为A=LU分解,由于A的对称性,致使L、U之间具有以下关系:故:d1=u11,d1l12=u12,…,dilik=则写成紧凑格式为:此即为改进平方根法:在LU分解过程中,利用系数矩阵的对称性,作Doolittle分解,只需计算U矩阵,L矩阵第k列的值可由U矩阵k行的值除以ukk算得,使得LU分解的计算量减少了一半其他可完全按Doolittle分解求解线性方程组的解的方法进行则写成紧凑格式为:示例3-17:用改进平方根法解线性方程组解:因系数矩阵是对称正定矩阵(需判断),用改进平方根法对方程组的增广矩阵做Doolittle分解335015/3224-22/30示例3-17:用改进平方根法解线性方程组335015/32则A=LU,Ax=bLUx=b,令y=Ux,则Ly=b,A矩阵改进平方根法LU分解的最后一列即为y向量所以解Ux=y得:x3=0,x2=-1,x1=1则A=LU,Ax=bLUx=b,令y=Ux,则Ly=b,A第三章线性方程组的解第三章线性方程组的解概述消元法三角分解法平方根法向量与范数方程组的性态与误差分析迭代法概述3.1概述大量实际计算问题=>一组线性方程组=>如何求解?1.术语非齐次线性方程组:若记:

则:(1.1)式可表示为Am×nx=b---线性方程组的矩阵表示)1.1(

22112222212111212111ïïîïïíì=+++=+++=+++mnmnmmnnnnbxaxaxabxaxaxabxaxaxaLLLLLLLLLLLLLLúúúúûùêêêêëé=aaaaaaaaamnmmnnLMMMLL212222111211Aúúúúûùêêêêëé=xxxnM21xúúúúûùêêêêëé=bbbmM21b3.1概述大量实际计算问题=>一组线性方程组=>如何求解?分类:据方程的个数与未知数的个数间关系,分为:m<n,即方程的个数小于未知数的个数,称为亚定方程组,有无穷多组解m>n,即方程的个数大于未知数的个数,称为超定方程组,或矛盾方程组。它没有一般意义下的解,但可以求其广义解。m=n,一般意义下的方程组,本章主要讨论的重点面临的问题:方程组Ax=b有没有解?有多少解?如何求解?分类:据方程的个数与未知数的个数间关系,分为:

2.Crammer法则求解An×nx=b方程组Ax=b有唯一解的充要条件是:|A|≠0A可逆A是非奇异矩阵Ax=b在A可逆时,存在唯一解结论:Crammer法则计算量非常大,需算n+1个n阶行列式。如:n=100,1000次/秒的计算机要算10120年nnninninniiiiiaabaaaabaaDADDDxLLMMMMMLL11111111111|,|,+-+-=== 2.Crammer法则求解An×nx=bnnninni3线性方程组的数值解法:直接法:思想:经有限步运算求得精确解的方法:舍入误差,因此也是近似解高斯消元法及其变形特点:它可靠且效率高,但它只适用于中小型方程组。迭代法:思想:构造适当的初始近似解向量x,按一定的法则,使之逐步逼近精确解,得到一个满足精度要求的近似解。即是用某种极限过程逐步逼近准确解的方法。主要方法:Jaccobi迭代法,Gauss-Sidel迭代法等3线性方程组的数值解法:3.1.1GAUSS消元法一.几种可以直接求解的线性方程组对角矩阵:=>n次除法3.1.1GAUSS消元法一.几种可以直接求解的线下三角矩阵:

即:l11x1=b1 l21x1+l22x2=b2 l31x1+l32x2+l33x3=b3 …… li1x1+li2x2+……+liixi=bi ……ln1x1+ln2x2+……+lnnxn=bn代入下三角矩阵:代入上三角矩阵:即:u11x1+u12x2+………+u1nxn=b1u22x2+………+u2nxn=b2 ……uiixi+ui,i+1xi+1+…+ui,nxn=bi un-1,n-1xn-1+un-1,nxn=bn-1 un,nxn=bn回代上三角矩阵:回代二、同解变换初等方阵:

:rirj:ri*k二、同解变换:rirj:ri*k注对矩阵A实施初等行变换

对A左乘初等方阵初等方阵是可逆的,多个初等方阵的积仍然可逆可逆阵A经有限次初等行变换单位矩阵:rj+k*ri:rj+k*ri2.对方程组Ax=b作如下的变换,解不变:交换两个方程的次序一个方程的两边同时乘以一个非0数一个方程的两边………,再将之加到另一个方程将方程组Ax=b对应的增广矩阵(A,b),作如下变换,解不变交换矩阵的两行某行乘以一个非0数某行乘以一个非0数,加到另一行增广矩阵第i行第i个方程对方程组Ax=b的增广矩阵作同解变换对其增广矩阵左乘一系列的初等矩阵2.对方程组Ax=b作如下的变换,解不变:增广矩阵第i行三、Gauss消元法消元法基本思想:对Ax=b的增广矩阵(A|b)进行初等变换,变成可直接求解的三种形式之一,再求解Gauss消元法:将A化为上三角阵回代求解=三、Gauss消元法消元法基本思想:对Ax=b的增广矩阵(A用高斯消去法解下列线性方程组原方程组对应的增广矩阵为:用高斯消去法解下列线性方程组1.消元步骤方程组AX=b的矩阵表示为:A(1)x=b(1)初始状态:1.消元步骤方程组AX=b的矩阵表示为:A(1)x=b(第一次消元:消去对角线下第1列元素(a11≠0)

方法:消去对角线下第1列元素为0,即ri-r1×ai1/a11:(i=2,3,…

第一次消元:消去对角线下第1列元素(a11≠0)第二次:若a22≠0,则消去对角线下第二列为0, 即:ri-r2×ai2/a22(i=3,4,…..)

第二次:若a22≠0,则消去对角线下第二列为0,经过k-1次消元后,增广矩阵变为:经过k-1次消元后,增广矩阵变为:第k次消元:若akk≠0,则消去对角线下第k列元素即:ri-rk×aik/akk(i=k+1,k+2,……)第k次消元:若akk≠0,则消去对角线下第k列元素2.经n次消元后得到同解方程组A(n)x=b(n),且A(n)为上三角矩阵,可逐步回代求解即:UX=YUY2.经n次消元后得到同解方程组A(n)x=b(n),且A(3.算法步骤将方程组用增广矩阵(A|b)=(aij)n×(n+1)表示,注意c语言中数组下标从0开始,故i=0,1,…,n-1,j=0,1,…,n消元:对k=0,1,……,n-2(消去第k列对角线下的元素)计算li,k=ai,k/ak,,k第i行-第k行×li,k(i=k+1,k+2,…n-1)

回代求解:xi=(ai,n-∑xjai,j)/ai,i.i=n-1,….,0,j=i+1,i+2,…..n-13.算法步骤将方程组用增广矩阵(A|b)=(aij)4.时间复杂度消元过程中:第k次消元每行均需计算第k行要乘以的常数:lik=aik/akk,消去第i行(第k列)时,i行各列元素加上k行各列元素乘以常数lik:aij=aij-akj*lik

(j=k,k+1,…,n),故需做n-k+1次乘法、加减法一共要做n-k行综上:第k次消元,除法:n-k次,乘法:(n-k)*(n-k+1)次,加减法:(n-k)*(n-k+1)次整个消元过程:除法:乘法、加减法:4.时间复杂度消元过程中:综上:算法时间度量为O(n3)综上:算法时间度量为O(n3)5.Gauss顺序消元法的适用条件GAUSS直接消元法的适用条件:akk(k)≠0A的各阶顺序主子式均不为0时,有akk(k)≠0(证明略)A是严格对角占优矩阵,则:akk(k)≠0(证明略)举例说明A的每行主对角元的绝对值>同行其余元素的绝对值之和5.Gauss顺序消元法的适用条件GAUSS直接消元法的适例2:用Gauss消元法解方程组(4位十进制机)

0.0001x1+x2=1x1+x2=2因要对阶,损失有效数字,求得x1=0,x2=1显然x1,x2不是方程的解,怎么办???x1+x2=20.0001x1+x2=1解之,得到x1=1,x2=1,接近与精确解

例2:用Gauss消元法解方程组(4位十进制机)3.1.2列主元Gauss消元法当采用Gauss消元法求解时,若|akk|《|aik|,会导致误差扩散第k步消元时,ri-rk*aik/akk=aij-akj*aik/akk因为|akk|<<|aik|,若rk行的误差为e=(ek+1,….,en+1),则e将被扩大(aik/akk)倍Gauss消元法在特殊情况下是不稳定的3.1.2列主元Gauss消元法当采用Gauss消元法求解解决办法:选择列主元:即选出第k列对角线下绝对值最大者设|atk|=max|aik|k≤i≤nrkrt以新的akk作为主对角元进行消元故列主元消元法只是在每步消元之前选出主对角元举实例说明列主元Gauss消元法的计算过程解决办法:列主元算法,只需在消元的第1步前增加以下几行代码i=k;//选择第k列的主元 for(j=k+1;j<n;j++) if(fabs(a[j][k])>fabs(a[i][k]))i=j; if(i!=k) for(j=k;j<=n;j++) { tmp=a[k][j];

a[k][j]=a[i][j];

a[i][j]=tmp; }列主元算法,只需在消元的第1步前增加以下几行代码3.1.3Gauss-Jordan消元法算法思想:在Gauss消元的第k次消元时,只是利用akk,将第k行以下各行的第k列消元为0,最终将系数矩阵消元为s上三角阵。将上述算法改进:第k次消元时,用akk将第k列的所有元素(akk除外)均消元为0,则系数矩阵最终成为对角矩阵(或单位矩阵)

3.1.3Gauss-Jordan消元法算法思想:第k步消元:若akk≠0,则消去除对角线外的第k列元素方法:计算:lik,即消去第k列元素(akk除外)为0,即ri-rk×lik第k步消元:若akk≠0,则消去除对角线外的第k列元素第k-1次消元结果第k次消元结果第k-1次消元结果第k次消元结果经过n次消元,原方程的增广矩阵变为:则,方程的根为:经过n次消元,原方程的增广矩阵变为:则,方程的根为:示例:Gauss-Jordan消元法求解示例:Gauss-Jordan消元法求解Gauss-Jordan消元法的归一化消元后对角线元素全为1,即单位矩阵E方法:第k次消元时,先将akk化为1(第k行除以akk),再用第k行消去各行k列的元素Gauss-Jordan消元法的归一化消元后对角线元素全为1经过n-1次消元,则原方程的增广矩阵变为:则,方程的根为:经过n-1次消元,则原方程的增广矩阵变为:则,方程的根为:归一化Gauss-Jordan消元法步骤:消元:(c/c++实现)对k=0,1,……,n-1(消去除对角线外第k列)第k行除以akk,将akk化为1第i行-第k行×aik(i=0,1,…n-1,且i≠k)增广矩阵最后一列ai,n即为方程组的解,无需回代归一化Gauss-Jordan消元法步骤:示例:用归一化的Gauss-Jordan消元法求解示例:用归一化的Gauss-Jordan消元法求解归一化的Gauss-Jordan消元法的应用可逆阵A经有限次初等行变换单位矩阵故可利用Gauss-Jordan消元法,构造矩阵(A|E)Gauss-Jordan消元(E|A-1)归一化的Gauss-Jordan消元法的应用示例:用Gauss-Jordan消元法求矩阵的逆矩阵示例:用Gauss-Jordan消元法求矩阵的逆矩阵3.2矩阵的三角分解法Gauss消元法的矩阵表示第一次消元r2-r1*l21ri-r1*li1即:第一步消元,相当于左乘初等变换矩阵L1,相当于:L1A(1)=A(2),L1b=b(2)3.2矩阵的三角分解法Gauss消元法的矩阵表示r2-r第二次消元:r3-r2*l32ri-r2*li2即:L2A(2)=A(3),L2L1A(1)=A(3)第二次消元:r3-r2*l32ri-r2*经过n-1次消元后Ln-1Ln-2…L2L1A=A(n),Ln-1Ln-2…L2L1b=b(n)故:A=L1-1L2-1…Ln-2-1Ln-1-1A(n),令L=L1-1L2-1…Ln-2-1Ln-1-1,则:经过n-1次消元后故:A=L

A(n)=L

UGauss消元法的实质:将系数矩阵分解为两个三角矩阵的乘积将矩阵A分解成一个上三角、下三角矩阵的乘积,即:A=LU,矩阵的三角分解、LU分解故:A=LA(n)=LU三角分解是从A的元素直接得到L、U的元素,不用中间步骤,即不用消元,所以称直接三角分解,或直接分解。A的LU分解只要求L是一个下三角阵、U是一个上三角阵,当A有LU分解时,这种分解不是唯一的。当L是一个单位下三角阵或者U是一个单位上三角阵时,A的这两种LU分解是唯一的。三角分解是从A的元素直接得到L、U的元素,不用中间步骤,即不上述是A的两种不同的三角分解一般地,若A=LU是一个三角分解,任取与A同阶的 非奇异对角矩阵D,则A=(LD)(D-1U)=L1U1 也是A的三角分解。上述是A的两种不同的三角分解常用的两种分解:L为单位下三角阵而U为一般上三角阵的分解称为Doolittle

分解一般上三角单位下三角常用的两种分解:一般上三角单位下三角L为一般下三角阵而U为单位上三角阵的分解称为Crout分解一般下三角单位上三角L为一般下三角阵而U为单位上三角阵的分解称为Crout定理:n阶矩阵A存在唯一的杜利特尔分解、克洛特分解的充要条件是A的顺序主子矩阵Ak

(k=1,2,…,n-1)非奇异(各阶顺序主子式非0)证明略(反证法)若不唯一,则可设A=L1U1=L2U2,推出因下三角矩阵的积仍然是下三角阵,上三角矩阵的积仍然是上三角阵下三角阵=上三角阵,则两个必为单位矩阵定理:n阶矩阵A存在唯一的杜利特尔分解、克洛特分解的充要1.Doolittle分解据矩阵的乘法,知:A的第一行元素:,故 第一列元素:,故:A的第二行元素:故:第二列元素: 故:=A=LU1.Doolittle分解=A=LU一般地:矩阵A紧凑格式的Doolittle分解为课件

推而广之:比较A第k行:

求U的第k行求U的第k行比较A第k列求L的第k列比较A第k列求L的第k列即:即:计算顺序为:为了便于记忆,将A的LU分解写成紧凑格式:123456.....计算顺序为:123456.对矩阵A进行Doolittle分解解:矩阵A紧凑格式的Doolittle分解为:对矩阵A进行Doolittle分解对矩阵A进行Doolittle分解,并求|A|解:-12212241-3-3对矩阵A进行Doolittle分解,并求|A|-122122三角分解法解线性方程组方程组Ax=b,若A非奇异,且有三角分解A=LU,则原方程组等价于:LUx=b令:Ux=y,则Ly=b故可先解出y,再求x所以等价于求U阵第k行元素ukj的公式,故可将增广矩阵(A|b)同时做LU分解,则最后一列即为y,再用Ux=y求解三角分解法解线性方程组方程组Ax=b,若A非奇异,且有三角例:用Doolittle分解法求解线性方程组:解:对增广矩阵进行Doolittle分解故:Ux=y为:所以x3=1,x2=-2,x1=222332-131-5266例:用Doolittle分解法求解线性方程组:22332-1用三角分解法求矩阵A的逆矩阵A-1若AX=E,则X=A-1用三角分解法求矩阵A的逆矩阵A-1若AX=E,则X=A-12.Crout分解类同于Doolittle分解比较两边可得:2.Crout分解类同于Doolittle分解紧凑格式的Crout分解为:214365.....紧凑格式的Crout分解为:214365.原方程:AX=b变为:LUX=b令Ux=y,则Ly=b,可见yk的表达式完全类同于ukj的表达式,故可将常向量放在系数矩阵之后,对整个增广矩阵进行Crout三角分解原方程:AX=b变为:LUX=b则UX=y的解即为线性方程组的解:即:则UX=y的解即为线性方程组的解:例3-11:分别用Doolittle、Crout分解法求解线性方程组解一:Doolittle分解:2-11521-14-61/23/23y向量例3-11:分别用Doolittle、Crout分解法求解线则解Ux=y可得线性方程组的解解之,得:x3=2,x2=-1,x1=1则解Ux=y可得线性方程组的解解二:Crout分解法则Ux=y的解即为原方程组的解解之,得:x3=2,x2=-1,x1=1-1/4-3/2423/22422-1/21/25/2注意:此处与Doolittle方法的区别解二:Crout分解法-1/4-3/2423/22422-13.追赶法解三对角线性方程组概念:三对角

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论