矩阵LU分解求逆详细分析和C语言实现.docVIP

矩阵LU分解求逆详细分析和C语言实现.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
题目要求 给定一个多维矩阵,实现该矩阵的求逆运算。 1、理论分析 矩阵的一种有效而广泛应用的分解方法是矩阵的LU三角分解,将一个n阶矩阵A分解为一个下三角矩阵L和一个上三角矩阵U的乘积。所以首先对矩阵进行三角分解,这里采用Doolittle分解,即分解为一个下三角矩阵(对角元素为1),和一个上三角矩阵的乘积。再进行相应的处理。 所以,矩阵求逆的算法流程可表述如下: 图1 矩阵求逆流程图 1)进行LU分解; 2)对分解后的L阵(下三角矩阵)和U阵(上三角矩阵)进行求逆;; 3)L阵的逆矩阵和U阵的逆矩阵相乘,即可求得原来矩阵的逆。即: (1) 1.1矩阵的LU 分解 若n阶方阵 的各阶顺序主子式不等于零,即: (2) 则A的LU分解存在且唯一。 (3) 由矩阵的乘法原理, 可推导出LU分解的迭代算法 (4) (5) (6) (7) 矩阵的LU分解是一个循环迭代的过程, U矩阵是从第1行迭代到第n行, 而L矩阵则是从第1列迭代到第n列, 且U矩阵先于L矩阵一个节拍。 1.2 L矩阵和U矩阵求逆 首先假设下三角矩阵L的逆矩阵为,不失一般性,考虑4阶的情况,利用,有: (1) ,,; (2) (3) (4)。 从而求得下三角矩阵L的逆矩阵R式如下: , (8) 上三角矩阵U的逆矩阵可以由下式得到:。 , (9) 矩阵求逆是一个迭代的过程,依次循环, 迭代次, 求出整个逆矩阵。其中U矩阵的循环迭代时按行顺序,列倒序进行,L矩阵的循环迭代按列顺序,行顺序进行,直到计算出整个矩阵的所有结果为止。 1.3 矩阵相乘 上三角矩阵U的逆矩阵u与下三角矩阵L的逆矩阵相乘, 最终得到原始矩阵A的逆矩阵, 完成整个矩阵求逆的过程。对于n阶矩阵相乘的迭代形式可表示如下: (10) 1.4 实例分析 例:给定一4阶矩阵,通过LU分解求逆矩阵。 解:算法过程为:, 第一步:求LU矩阵 设,通过(4)~(7)式可逐步进行矩阵L和U中元素的计算,如下所示: 经迭代计算,最后得到L和U矩阵为: 第二步:求L和U矩阵的逆, (1)求U矩阵的逆 由式(9)可得矩阵U的逆的各元素计算如下: (2)求L矩阵的逆 由(8)式可得L矩阵的逆的各元素计算如下 所以得到L和U的逆矩阵为: (3)求A的逆矩阵 由式(10)可计算得到矩阵A的逆,如下: 由程序计算出的结果如下: 2、C语言程序设计及测试 2.1 算法c程序实现 #includestdio.h #include string.h #define N 4 void main() { float a[N][N]; float L[N][N],U[N][N],out[N][N], out1[N][N]; float r[N][N],u[N][N]; memset( a , 0 , sizeof(a)); memset( L , 0 , sizeof(L)); memset( U , 0 , sizeof(U)); memset( r , 0 , sizeof(r)); memset( u , 0 , sizeof(u)); int n=N; int k,i,j; int flag=1; float s,t; ////////////////////input a matrix//// printf(\ninput A=); for(i=0;in;i++) for(j=0;jn;j++) scanf(%f,a[i][j]); //////////////////figure the input matrix////////////////////////// printf(输入矩阵:\n); for(i=0;in;i++) { for (j = 0; j n; j++) { printf(%lf , a[i][j]); } printf(\n); } for(j=0;jn;j++) a[0][j]=a[0][j]; //计算U矩阵的第一行 for(i=1;in;i++) a[i][0]=a[i][0]/a[0][0]; //计算L矩阵的第1列 for(k=1;kn;k++) { for(j=k;j

文档评论(0)

lyxbb + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档