数学实验线性方程组的J迭代GS迭代SOR迭代解法实验报告内含matlab程序代码.docx

上传人:b****3 文档编号:12921901 上传时间:2023-04-22 格式:DOCX 页数:7 大小:74.54KB
下载 相关 举报
数学实验线性方程组的J迭代GS迭代SOR迭代解法实验报告内含matlab程序代码.docx_第1页
第1页 / 共7页
数学实验线性方程组的J迭代GS迭代SOR迭代解法实验报告内含matlab程序代码.docx_第2页
第2页 / 共7页
数学实验线性方程组的J迭代GS迭代SOR迭代解法实验报告内含matlab程序代码.docx_第3页
第3页 / 共7页
数学实验线性方程组的J迭代GS迭代SOR迭代解法实验报告内含matlab程序代码.docx_第4页
第4页 / 共7页
数学实验线性方程组的J迭代GS迭代SOR迭代解法实验报告内含matlab程序代码.docx_第5页
第5页 / 共7页
点击查看更多>>
下载资源
资源描述

数学实验线性方程组的J迭代GS迭代SOR迭代解法实验报告内含matlab程序代码.docx

《数学实验线性方程组的J迭代GS迭代SOR迭代解法实验报告内含matlab程序代码.docx》由会员分享,可在线阅读,更多相关《数学实验线性方程组的J迭代GS迭代SOR迭代解法实验报告内含matlab程序代码.docx(7页珍藏版)》请在冰豆网上搜索。

数学实验线性方程组的J迭代GS迭代SOR迭代解法实验报告内含matlab程序代码.docx

数学实验线性方程组的J迭代GS迭代SOR迭代解法实验报告内含matlab程序代码

西京学院数学软件实验任务书

课程名称

数学软件实验

班级

数0901

学号

姓名

李亚强

实验课题

线性方程组的J-迭代,GS-迭代,SOR-迭代方法。

实验目的

熟悉线性方程组的J-迭代,GS-迭代,SOR-迭代方法。

实验要求

运用Matlab/C/C++/Java/Maple/Mathematica等其中一种语言完成。

实验内容

线性方程组的J-迭代;

线性方程组的GS-迭代;

线性方程组的SOR-迭代。

成绩

教师

实验四实验报告

一、实验名称:

线性方程组的J-迭代,GS-迭代,SOR-迭代。

二、实验目的:

熟悉线性方程组的J-迭代,GS-迭代,SOR-迭代,SSOR-迭代方法,编程实现雅可比方法和高斯-赛德尔方法求解非线性方程组

的根,提高matlab编程能力。

三、实验要求:

已知线性方程矩阵,利用迭代思想编程求解线性方程组的解。

四、实验原理:

1、雅可比迭代法(J-迭代法):

线性方程组

,可以转变为:

迭代公式

其中

,称

为求解

的雅可比迭代法的迭代矩阵。

以下给出雅可比迭代的分量计算公式,令

,由雅可比迭代公式有

,既有

,于是,解

的雅可比迭代法的计算公式为

2、高斯-赛德尔迭代法(GS-迭代法):

GS-迭代法可以看作是雅可比迭代法的一种改进,给出了迭代公式:

其余部分与雅克比迭代类似。

3、逐次超松弛迭代法(SOR-迭代法):

选取矩阵A的下三角矩阵分量并赋予参数w,将之作为分裂矩阵M,

,其中,w>0,为可选择的松弛因子,又

(1)公式构造一个迭代法,其迭代矩阵为

从而得到解

的逐次超松弛迭代法。

其中:

由此,解

的SOR-迭代法的计算公式为

(2)

观察

(2)式,可得结论:

(1)、当w=1时,SOR-迭代法为J-迭代法。

(2)、当w>1时,称为超松弛迭代法,当w<1时,称为低松弛迭代法。

五、实验内容:

  %1.J-迭代

functionx1=jacobi(A,b,y);

m=input('请输入迭代次数m:

');

eps=input('请输入精度eps:

');

D=diag(diag(A));

L=triu(A)-A;

U=tril(A)-A;

M=D\(L+U);

g=D\b;

a=1;

k=0;

whilea>eps

x2=M*x1+g;

a=norm(x2-x1,inf);

x1=x2;

k=k+1;

end

%输出方程组的近似解、精确值及误差

disp('近似解:

');

disp(x1);

x2=x1-y;

a=norm(x2,inf);

fprintf('误差:

%.6f;迭代次数:

%d\n',a,k);

%2.GS-迭代

functionx1=G_S(A,b,y)

n=100;

m=input('请输入迭代次数m:

');

eps=input('请输入精度eps:

');

D=diag(diag(A));

L=triu(A)-A;

U=tril(A)-A;

%生成矩阵M,向量g

M=(D-L)\U;

g=(D-L)\b;

%迭代首项

x1=eye(n-1,1);

x2=eye(n-1,1);

fori=1:

n-1

x1(i)=1;

x2(i)=0;

end

a=1;

k=0;

whilea>eps

x2=M*x1+g;

a=norm(x2-x1,inf);

x1=x2;

k=k+1;

end

%输出方程组的近似解、精确值及误差

disp('近似解:

');

x2=x1-y;

a=norm(x2,inf);

fprintf('误差:

%.4f;迭代次数:

%d\n',a,k);

%3.SOR-迭代

functiona=p(A)

[n,n]=size(A);

x=eig(A);

a=0;

fori=1:

n

b=abs(x(i));

ifb>a

a=x(i);

end

end

a=abs(a);

functionx1=SOR(A,b,y)%y为精确解

%超松弛迭代

D=diag(diag(A));

L=triu(A)-A;

U=tril(A)-A;

%求最佳松弛因子w

M=D\(L+U);

w=p(M);

w=2/(1+sqrt(1-w^2));

ifw<0||w>2

disp('迭代不收敛');

return;

end

%生成矩阵M,向量g

M=(D-w*L)\((1-w)*D+w*U);

g=(D-w*L)\b*w;

%进行迭代

w=1;

k=0;

%x1=eye(n,1);

whilew>1e-6

x2=M*x1+g;

w=norm(x2-x1,inf);

x1=x2;

k=k+1;

end

%输出方程组的近似解、精确值及误差

disp('近似解:

');

disp(x1);

x2=x1-y;

w=norm(x2,inf);

disp('误差:

');

disp(w);

disp('迭代次数:

');

disp(k);

六、实验结果:

A=[520;641;125];b=[1018-14]';

X1=G_S(A,b,[000]')

X1=

-0.8750

7.1874

-5.5000

 

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 医药卫生 > 预防医学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1