版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、华中科技大学数值分析实验报告(实验6.1)华 中 科 技 大 学数值分析实验报告系、年级 研究生院2012级 学 号 姓 名 类 别 硕 士 2013年5月6日13实验6.1实验要求:根据教材实验6.1做出相应改编:分别使用Gauss消元、列选主元。全选主元的方法求解线性方程组,分别比较三种消元方法的结果和算法的区别,并说明主元的选取在Gauss消元的中的作用。问题提出:Gauss消去法是我们在线性代数中已经熟悉的。但由于计算机的数值运算是在一个有限的浮点数集合上进行的,如何才能确保Gauss消去法作为数值算法的稳定性呢?Gauss消去法从理论算法到数值算法,其关键是主元的选择。主元的选择从数
2、学理论上看起来平凡,它却是数值分析中十分典型的问题。一般来说书本上采用的列选主元的办法对其线性方程组进行求解的,那么我们是否可以选择一种行列都选取主元消去的办法来减小相应的误差呢?全主元消元法和列主元消元法一样都是由高斯消元法演变而来。只不过选取主元的范围有所加大。全选主元相对于列选主元的更加复杂化了,因为在运算的过程中导致了元的位置发生了变化,这样我们就不得不追踪每个元的位置。本次实验就几个问题进行了matlab实验分析,比较几种计算方法的优劣性。实验内容:考虑线性方程组 编制一个程序:分别能进行Gauss消去、列选主元Gauss消去、全选主元Gauss消去法进行解线性方程组。对三种算法所得
3、到的结果进行比较,分析三种计算方法的准确性。具体内容:(1)取矩阵,则方程有解。取n=10、n=20计算矩阵的条件数。分别编写利用matlab编写运算程序,实现Gauss消去、列选主元消去以及全选主元消去的方法。比较三种计算方法的运算结果。在列选主元的过程中分别采用每步消去过程总选取按模最小或按模尽可能小的元素作为主元或每步消去过程总选取按模最大的元素作为主元,结果又如何?分析实验的结果。1 采用普通Gauss消元法进行计算Gauss消去法的基本思想是,通过将一个方程乘或除某个数以及两个方程相加减这两种运算手续,逐步减少方程组中变元的数目,最终使某个方程只含有一个变元,从而得出所求的解。对于A
4、x=b,Gauss消去法的求解思路为:(1) 若a11(1)0,先让第一个方程组保持不变,利用它消去其余方程组中的x1,使之变成一个关于变元x2,x3xn的n-1阶方程组。(2) 按照(1)中的思路继续运算得到更为低阶的方程组。(3) 经过n-1步的消元后,得到一个三角方程。(4) 利用求解公式回代得到线性方程组的解。根据这个思路编写matlab程序如下:function x=gauss(n)disp('请输入构造的矩阵的阶数(10/20)')n=input('');disp('构造矩阵为A=')A = diag(6*ones(1,n)+diag
5、(ones(1,n-1),1)+diag(8*ones(1,n-1),-1)disp('由A构造出矩阵b=')b = A*ones(n,1)m,n=size(A);disp('增广矩阵为:')Ab=A bfor i=1:n-1 yuan=Ab(i,i); for k=i+1:n Ab(k,i:(n+1)=Ab(k,i:(n+1)-(Ab(k,i)/yuan)*Ab(i,i:(n+1); end disp(Ab); pauseendx=zeros(n,1);x(n)=Ab(n,(n+1)/Ab(n,n);for i=n-1:-1:1 x(i)=(Ab(i,(n+1
6、)-Ab(i,i+1:n)*x(i+1:n)/Ab(i,i);end取n=10运行的结果为:Ab = 6 1 0 0 0 0 0 0 0 0 7 8 6 1 0 0 0 0 0 0 0 15 0 8 6 1 0 0 0 0 0 0 15 0 0 8 6 1 0 0 0 0 0 15 0 0 0 8 6 1 0 0 0 0 15 0 0 0 0 8 6 1 0 0 0 15 0 0 0 0 0 8 6 1 0 0 15 0 0 0 0 0 0 8 6 1 0 15 0 0 0 0 0 0 0 8 6 1 15 0 0 0 0 0 0 0 0 8 6 14消去结束后的矩阵为:解得线性方程组的解为:
7、ans =1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000取n=20运行的结果为:Ab =消去结束后的矩阵为: 解得线性方程组的解为:ans =1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.00002 采用列选主元消去法进行计算在采用Gauss消去法的时候,
8、主元绝对值的大小将影响到计算结果,主元的绝对值越大,算法的稳定性越好。列选主元消去法matlab程序的计算思路为:(1)先构造需要计算的矩阵,得到增广矩阵Ab。(2)将系数矩阵A的每一列的绝对值最大的元素换至对角线上,矩阵b中的元素也随之改变,先判断主元是否为0。然后利用此主元逐行消去此主元所在的列中的元素,矩阵b中的元素也随之改变。(3)经过n-1步运算过后,矩阵A就变换成为一个三角矩阵。(4)逐次回代,就能计算出方程组的解。分别每步消去过程总选取按模最大的元素作为主元和每步消去过程总选取按模最小的元素作为主元选取列选主元消去法的matlab程序为:function x=gauss(n)di
9、sp('请输入构造的矩阵的阶数(10/20)')n=input('');disp('构造矩阵为A=')A = diag(6*ones(1,n)+diag(ones(1,n-1),1)+diag(8*ones(1,n-1),-1)disp('由A构造出矩阵b=')b = A*ones(n,1)m,n=size(A);disp('增广矩阵为:')Ab=A bfor i=1:n-1 if way=1 i=i disp('输入每一列的主元所在的行') hang=input(''); Ab(i
10、 hang,:)=Ab(hang i,:); disp(Ab); pause end zhuyuan=Ab(i,i); for k=i+1:n Ab(k,i:(n+1)=Ab(k,i:(n+1)-(Ab(k,i)/zhuyuan)*Ab(i,i:(n+1); end disp(Ab); pauseendx=zeros(n,1);x(n)=Ab(n,(n+1)/Ab(n,n);for i=n-1:-1:1 x(i)=(Ab(i,(n+1)-Ab(i,i+1:n)*x(i+1:n)/Ab(i,i);end(i):每步消去过程总选取按模最大的元素作为主元:取n=10手动执行该程序:消去结束后的矩阵为
11、:解得线性方程组的解为:ans = 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000取n=20运行的结果为:Ab = 解得线性方程组的解为:ans =1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000(ii)每步消去过程总选取按模最小的元素作为主元:取n
12、=10手动执行该程序:消去结束后的矩阵为:解得线性方程组的解为:ans = 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000取n=20运行的结果为: 消去结束后的矩阵为: 解得线性方程组的解为:ans =1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000
13、由上述两种选取主元的方法比较可知,采用每一步消去过程总选取按模最大或按模尽可能大的元素作为主元的选取方法最终得到的方程组的解更加精确,这是因为在计算过程中人为的避免了大数除小数而造成的误差的扩大,而每一步消去过程总选取按模最小或按模尽可能小的元素作为主元的选取方法最终得到的解会有误差,而误差的产生就是由于上诉原因而造成了。所以在实际计算过程中,必须考察计算模型的可行性。3 采用全选主元消去进行计算全选主元和列选主元消去法的区别在于全选主元不仅要用到列选主元,而且需要行选绝对值最大的元,这样的麻烦之处就在于不仅需要进行线性方程顺序的变换,而且在解方程的过程中未知数的顺序也发生了相应的改变,这就给
14、程序的编写和运算的时间的上带来了很大的麻烦。全选主元消去法的基本思路为:(1)先构造需要计算的矩阵,得到增广矩阵Ab(2)将每次更新后系数矩阵的每一列的绝对值最大的元素换至对角线上(绝对值最大的元素必须在对角线的下方),矩阵b中的元素也随之改变。(3)然后将更新后系数矩阵的每行中的绝对值最大元素换至对角线上(该绝对值最大元素必须要在主元的右侧)。先判断主元是否为0,然后利用此主元逐行消去此主元所在的列中的元素,矩阵b中的元素也随之改变。(4)经过n-1步运算过后,矩阵A就变换成为一个三角矩阵。(5)逐次回代,就能计算出方程组的解。采用全选主元Gauss消去法编写的matlab程序为:funct
15、ion x=gauss(n)disp('请输入构造的矩阵的阶数(10/20)')n=input('');disp('构造矩阵为A=')A = diag(6*ones(1,n)+diag(ones(1,n-1),1)+diag(8*ones(1,n-1),-1)disp('由A构造出矩阵b=')b = A*ones(n,1)m,n=size(A);disp('增广矩阵为:')Ab=A bfor i=1:n-1 zhuyuan = max(max(abs(A(i:n,i:n); for r = i:n for t =
16、i:n if zhuyuan = abs(A(r,t) zhuhang = r; zhulie = t; end end end ph = A(i,:); A(i,:) = A(zhuhang,:); A(zhuhang,:) = ph; b = b' bb = b(i); b(i) = b(zhuhang); b(zhuhang) = bb; b = b' pl = A(:,i); A(:,i) = A(:,zhulie); A(:,zhulie) = pl; Ab = A,b; zhuyuan = Ab(i,i); for k=i+1:n Ab(k,i:(n+1)=Ab(k
17、,i:(n+1)-(Ab(k,i)/zhuyuan)*Ab(i,i:(n+1); end A = Ab(:,1:n); b = Ab(:,(n+1); disp(Ab); pauseendx=zeros(n,1);x(n)=Ab(n,(n+1)/Ab(n,n);for i=n-1:-1:1 x(i)=(Ab(i,(n+1)-Ab(i,i+1:n)*x(i+1:n)/Ab(i,i);end取n=10手动执行该程序:消去结束后的矩阵为:解得线性方程组的解为:ans =1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0
18、000 1.0000 1.0000取n=20运行的结果为:Ab = 解得线性方程组的解为:ans =1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000 1.0000根据消去后的矩阵的可以看出:全选主元消去得到的矩阵十分稳定。因此全选主元的的稳定性和精确程度都比列选主元的方法得到的要高。4 实验总结通过本次实验可以看出,matlab程序的编写复杂程度来看:普通Gauss消去法的编写最简单,只需要通过简单的运算就可以得到需要的计算的结果,采用列选主元的办法进行gauss消去的程序略微比普通Gauss消去法难度大,由于增加了需要选取主元的过程,而全选主元由于涉及到换行换列,程序的编写比价麻烦,三种算法的在执行速度来看,也是十分明显地可以看出:普通Gauss消去列选主元消去全选主元消去。而从计算的结果来看,普通Gauss消去法明显比列
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026年传统艺术测试题及答案
- 5G网络攻击场景下的隐私保护机制设计-洞察与解读
- 2026年前厅接待服务案例分析报告
- 2026年社区老年人服务活动
- 2026年泰康职业测试题及答案
- 艺术培训公司教学事故认定与处理管理制度
- 洗车服务公司员工入职管理制度
- 标志设计理论试题及答案
- 2026年全国二级建造师之二建矿业工程实务考试综合能力题(附答案)
- 2026学年湖南省冷水江市五年级数学期末通关专项攻坚题(附答案)详细答案和解析
- 2026上海市宝山区融媒体中心招聘专业技术人员6人备考题库及答案详解1套
- 江苏省南通市2025-2026学年五年级下学期6月数学期末调研试题(试卷+答案)
- 2026浙江台州椒江邮政管理局编外招聘1人备考题库含答案详解
- 微信小程序模板-电商平台服务协议和交易规则、对用户处理纠纷的机制或方案、对入驻经营者的审核要求或规范
- 2025新疆机场集团乌机场分公司飞行区管理部第三季度招聘12人笔试历年参考题库附带答案详解
- 2026泰安市泰山医养健康集团有限公司部分权属企业公开招聘(25人)笔试参考题库及答案详解
- 2026年安徽高考政治试卷及答案
- 2026年江苏省《保安员资格证考试》考试题库及答案
- 喉癌术后误吸管理专家共识(2026版)
- 2026中国金融监管沙盒试点成效与推广路径研究报告
- 2026年事业单位新进人员岗前培训试题及答案
评论
0/150
提交评论