- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验八、解线性方程组的迭代法
解线性方程组的迭代法是用某种极限过程去逐步逼近线性方程组精确解的方法,即是从一个初始向量 x(0)出发,按照一定的迭代格式产生一个向量序列
{x(k)},使其收敛到方程组Ax二b的解。迭代法的优点是所需计算机存储单元少, 程序设计简单,原始系数矩阵在计算过程中始终不变等。但迭代法存在收敛性及 收敛速度问题。迭代法是解大型稀疏矩阵方程组的重要方法。
一、 实验目的
1、 熟悉迭代法的有关理论和方法;
2、 会编制雅可比迭代法、高斯-塞德尔迭代法的程序;
3、 注意所用方法的收敛性及其收敛速度问题。
二、 实验任务
1、用雅可比迭代法解方程组
x^i + 2x2 - 2x3 = 7
? Xi + x2 + x3 = 2 .
2x^ 2x2 +x3 = 5
注意:若用高斯-塞德尔迭代法则发散。
解:输入主程序:
fun ction X=jacdd(A,b,X0,P,wucha,max1)
[n m]=size(A);
for j=1:m
%a(j)=sum(abs(A(:,j)))-2*(abs(A(j,j)));
%e nd
%for i=1: n
%if a(i)=0
%disp(请注意:系数矩阵A不是严格对角占优的,此雅可比迭代不一定收敛)
%return
%e nd
%e nd
%if a(i)0
disp(请注意:系数矩阵A是严格对角占优的,此方程组有唯一解,且雅可比 迭代收敛)
%e nd
for k=1:max1
k
for j=1:m
X(j)=(b(j)-A(j,[1:j-1,j+1:m])*X0([1:j-1,j+1:m]))/A(j,j);
end
X,djwcX=norm(X-XO,P); xdwcX=djwcX/( norm(X,P)+eps); XO=X;X 仁A\b;
if (djwcXvwucha )( xdwcXvwucha)
disp(请注意:雅可比迭代收敛,此方程组的精确解jX和近似解X如下:)
return
end
end
if (djwcXwucha )( xdwcXwucha)
disp( 请注意:雅可比迭代次数已经超过最大迭代次数 max1 )
end
a,X=X;jX=X1,
在MATLAB^输入:
A=[1 2 -2 ; 1 1 1 ; 2 2 1];
b=[7 2 5]
X=jacdd(A,b,[O;O;O],i nf,0.01,20)
输入:
结果得:
k =1
X = 7
2
5
k =2
X =13
-10
-13
k =3
X = 1
2
-1
k =4
X = 1
2
-1
请注意:雅可比迭代收敛,此方程组的精确解jX和近似解X如下:
X =1 2 -1
2、用高斯-塞德尔迭代法解方程组
x-i 0.9x2 0.9x3 =1.9
0.9xj + x2 + 0.9x3 = 2.0.
0.9捲 +0.9x2 +x3=1.7
注意:若用雅可比迭代法则发散。
解:输入主程序:
fun ction X=gsdddy(A,b,X0,P,wucha,max1) D=diag(diag(A));U=-triu(A,1);L=-tril(A,-1);
dD=det(D);
if dD==0
disp(请注意:因为对角矩阵D奇异,所以此方程组无解.) else
disp(请注意:因为对角矩阵D非奇异,所以此方程组有解.)
iD=inv(D-L); B2=iD*U;f2=iD*b;jX=A\b; X=X0;
[n m]=size(A);
for k=1:max1
X1= B2*X+f2; djwcX=norm(X1-X,P); xdwcX=djwcX/(norm(X,P)+eps);
if (djwcXwucha)|(xdwcXwucha)
break
else k,X1,k=k+1;X=X1;
end
end if (djwcXwucha)|(xdwcXwucha)
disp( 请注意:高斯-塞德尔迭代收敛,此A的分解矩阵
D,U丄和方程组的精确解jX和近似解X如下:)
else
disp( 请注意:高斯 - 塞德尔迭代的结果没有达到给定的精度, 并且迭代次数已经超过最大迭代次数 max1, 方程组的精确解 jX和迭代向量X如下:)
X=X;jX=jX
end
end
X=X;D,U,L,jX=jX
然后再 MA TLAB 中输入:
A=[1 0.9 0.9;0.9 1 0.9;0.9 0.9 1]; b=[1.9;2.0;1.7];
X=gsdddy(A,b,[0;0;0],inf,0.01,20) 请注意:因为对角矩阵 D 非奇异,所以此方程组有解
k k k k k k k k k k k k k k k k k k k1
k k k k k k k
原创力文档


文档评论(0)