北航数值分析作业.docVIP

  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 1. 算法的设计方案 采用Jacobi算法理论上可以将所有特征值都能求出来,但实际计算后发现,Jabobi算法精度太低。对于最大和最小特征值(在该题中,这两个特征值模都在10左右,远离0),该算法尚能得出较高精度结果。而对于模最小特征值,得出结果为0。 于是改用幂法和反幂法。最先可以分别求出模最大特征值λ1和模最小特征值λs。从得到的结果发现λ1是负数,即λ1是最小特征值。分析一下,最小特征值减去最大特征值结果是模最大。于是将矩阵平移λ1,利用幂法,最后可以求出最大特征值λ501。 与λik最接近也就是与其差值的模最小,故而先将矩阵平移λik,然后采用反幂法,最后求出各λik。 在反幂法中用到了LU三角分解,矩阵A的行列式值就等于上三角阵U的行列式值,即U对角线元素的乘积。 2. 程序代码 using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace SpecificRootsResolve { class Program//定义主类 { const int r = 2, s = 2, N = 501; static double beta = 0, beta0; static double[,] a = new double[N, N]; static double[,] u = new double[N, N]; static double[,] l = new double[N, N]; static double[] b = new double[N]; static double[] x = new double[N]; static double[] y = new double[N]; static void Main(string[] args) { int i; double λ1, λ501, λs, condA2, detA = 1; double[] dev = new double[39]; double[] λnew = new double[39]; Initialize(x);//初始化迭代初始向量x Initialize(a);//初始化矩阵a InversePowerMethod(a);//调用反幂法函数 λs = 1 / beta; Console.WriteLine(λs={0:E11}, λs); beta = 0; Initialize(x); PowerMethod(a);//调用幂法函数 λ1 = beta; beta = 0; Initialize(x); Deviate(a, λ1);//调用平移函数 PowerMethod(a); λ501 = beta + λ1; beta = 0; Initialize(x); Console.WriteLine(λ1= {0:E11}, λ1); Console.WriteLine(λ501= {0:E11}, λ501); for (i = 0; i 39; i++) { dev[i] = λ1 + (i + 1) * (λ501 - λ1) / 40; Deviate(a, dev[i]); InversePowerMethod(a); λnew[i] = beta + dev[i]; Console.WriteLine(λnew{0}={1:E11}, i + 1, λnew[i]); } Initialize(a);//初始化矩阵a

文档评论(0)

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

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

1亿VIP精品文档

相关文档