- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)