《太原理工大学计算机数值方法实验报告(共30页).doc》由会员分享,可在线阅读,更多相关《太原理工大学计算机数值方法实验报告(共30页).doc(30页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、精选优质文档-倾情为你奉上本科实验报告课程名称: 计算机数值方法 实验地点: 专业班级: 学号:学生姓名: 指导教师: 成 绩: 年 月 日专心-专注-专业太原理工大学学生实验报告学院名称计算机科学与技术学院专业班级学号学生姓名实验日期成绩课程名称计算机数值方法实验题目实验一 方程求根一、 实验目的和要求:(1)实验目的: 熟悉使用二分法、迭代法、牛顿法、割线法等方法对给定的方程进行根的求解。求方程:f(x)=x*x*x+4*x*x-10=0在1,2内的一个实根,且要求满足精度|x*-xn|0.001(2)实验要求:1.应用C,C+或JAVA编出通用程序,源程序要有详细的注释和说明;2.比较计
2、算结果,对不同方法进行比较分析;3.实验完成,提交实验结果并写出报告,分析计算结果是否符合问题的要求,找出计算成功的原因或计算失败的教训。二、 实验内容和原理: (1) 增值寻根法:基本思想为:从初始值x0开始,按规定的一个初始步长h来增值。令x(n+1)=x(n)+h,(n=0,1,2.),同时计算f(x(n+1).在增值过程中会遇到三种情况:1. f(x(n+1))=0,此时x(n+1)即为方程根。2. f(x(n))和f(x(n+1)同号,说明区间内无根。3. f(x(n))和f(x(n+1)同号,说明区间内有根,则把步长缩小,直至满足精度要求为止,x(n)或x(n+1)就是满足精度的近
3、似根。 (2) 二分法:基本思想为:设f(x)在a,b内连续,且f(a)*f(b)0,则方程f(x)=0在(a,b)内有实根x*.然后逐步对分区间a,b,通过判断两端点函数值乘积的符号,进一步缩小有根区间从而求出满足精度要求的近似值。(3) 牛顿迭代法:基本思想为给定一个初始值由牛顿法的迭代公式:x(n+1)=x(n)-f(x(n)/f(x(n) (n=0,1,2.)逐步求出x(n),直至(x(n+1)-x(n))的绝对值小于给定精度,则x(n+1)即可作为近似值。 (4) 双点割线法:由给出的两个初始近似值,再根据双点割线法迭代公式:x(n+1)=x(n)-(f(x(n)/(f(x(n)-f
4、(x(n-1)*(x(n)-x(n-1),(n=1,2,3.)逐步求出x(n),直至x(n+1)-x(n)的绝对值满足精度,则x(n+1)即可作为近似值。 (5) 单点割线法:由给出的两个初始近似值,再根据双点割线法迭代公式:x(n+1)=x(n)-(f(x(n)/(f(x(n)-f(x(0)*(x(n)-x(0),(n=1,2,3.)逐步求出x(n),直至x(n+1)-x(n)的绝对值满足精度,则x(n+1)即可作为近似值。三、 主要仪器设备:笔记本电脑 四、 操作方法:源代码:(1)增值寻根法: #includedouble fun(double x) /原函数 return(x*x*x+
5、4*x*x-10);/求解方程f(x)=x*x*x+4*x*x-10=0的根,精度为10-3. int main() double a=1.25,h=1,x=a; printf(初始近似值为:%lfn,a); doif(fun(x)=0)printf(根为:%f,x);return 0; /*如果初始值函数值为0,则初始值即为根*/ else if(fun(x)*fun(x+h)0) /*如果fun(x)和fun(x+h)同号则使X加h并跳出本次循环执行下一次*/ x=x+h;continue; else if(fun(x)*fun(x+h)0.001);/当不满足精度要求时继续执行循环体 p
6、rintf(根为:%fn,x);/跳出循环说明满足精度要求则x可近似作为方程根 return 0;(2)二分法:#include#include#define esp 1e-3 /精度double f(double x) /原函数 return (x*x*x+4*x*x-10);double root(double (*fun)(double),double left,double right,double deviation)/用二分法求方程根 /其中形参*fun为指向原函数的指针 double x,y; while(fabs(right-left)deviation)/当不满足精度要求继续
7、执行循环体 x=(right+left)/2; /求出中点的横坐标 y=fun(x); /计算中点的函数值if(y=0)return x; /如果中点函数值等于0则中点即为所求根if(y0)right=x; /若中点函数值大于0则令其为区间右终点值else left=x; /否则令其为左端点值 return(right+left)/2; /以中点值作为最终近似值int main() double a,b;printf(请输入区间左右端点值:n);scanf(%lf%lf,&a,&b);printf(近似根为%lfn,root(f,1,2,esp); return 0;(3)牛顿迭代法:#inc
8、lude#includedouble f1(double x) /原函数 return x*x*x+4*x*x-10;double f2(double x) /导函数 return 3*x*x+8*x;double newton(double x0,double e) double x1; do x1=x0; /按牛顿迭代公式Xn+1=Xn-(f1(Xn)/f2(Xn)求解x0=x1-f1(x1)/f2(x1); while(fabs(x0-x1)e); /当不满足精度要求时继续执行循环体 return x0; /满足精度要求时返回Xn+1的值int main()double x0=1.5;/
9、初始近似值double e=pow(10,-3); /精度printf(初始近似值为:%lfn,x0); printf(近似根为:%lfn,newton(x0,e); return 0;(4)双点割线法:# include # include #define esp 10e-3 /精度 double f(double x) /原函数 return(x*x*x+4*x*x-10); double fun(double x0,double x1) /双点割线法求近似根 double x; int i=0; while(fabs(x1-x0)esp) /当不满足精度要求继续执行循环体 x=x1-f(
10、x1)*(x1-x0)/(f(x1)-f(x0); x0=x1; x1=x; i+; /达到精度要求后跳出循环 printf(执行循环次数为 i=%dn,i); return (x1); /返回最终近似根main () double m,n,result; printf(请输入两个双精度初始近似值 m n: n); /输入两个双精度初始近似值 scanf(%lf%lf,&m,&n); result=fun(m,n); printf(result=%lfn,result);/输出最后结果,保留四位小数(5)单点割线法:# include # include #define esp 5*(10e-
11、3) /精度 double f(double x) /原函数 return(x*x*x-3*x-1); double fun(double x0,double x1) /单点割线法求近似根 double x; int i=0; while(fabs(x1-x0)esp) /当不满足精度要求继续执行循环体 x=x1-f(x1)*(x1-x0)/(f(x1)-f(x0); x1=x; i+; /达到精度要求后跳出循环 printf(执行循环次数为 i=%dn,i); return (x1); /返回最终近似根main () double m,n,result; printf(please inpu
12、t m n: n); /输入两个双精度初始近似值 scanf(%lf%lf,&m,&n); result=fun(m,n); printf(result=%.4fn,result);/输出最后结果,保留四位小数五、 实验结果: 程序运行结果:(1)增值寻根法:初始近似值为:1.根为:1.Press any key to continue(2)二分法:请输入区间左右端点值:1 2近似根为1.Press any key to continue (3)牛顿迭代法:初始近似值为:1.近似根为:1.Press any key to continue(4) 双点割线法:请输入两个双精度初始近似值 m n:
13、1 2执行循环次数为 i=4result=1.Press any key to continue(5)单点割线法:please input m n:1 2执行循环次数为 i=15result=1.Process returned 14 (0xE) execution time : 4.411 sPress any key to continue. 六、 结果分析: (1)通过对不同方法比较可知,收敛速度:牛顿迭代法双点割线法 单点割线法,二分法和增值寻根法的收敛速度就相对较慢,且结果相对前三种方法较不精确。(2)但二分法和增值寻根法的优点是简单,对f(x)只要求连续,局限性是只能用于求实根,不
14、能求复根及偶数重根。(3)牛顿法则收敛很快,而且可求复根,缺点是对重根收敛较慢,要求函数一阶导数存在。(4)割线法省去了牛顿法求函数导数过程,简化了计算步骤,且收敛速度也较快,其中双点割线法比单点割线法收敛速度快。 七、心得体会: 本次实验内容较为简单,最主要的是要学会将数学方法转变为程序上机实现,同时要学会对不同方法进行比较,确定时间复杂度最小的算法。 实验地点指导教师 太原理工大学学生实验报告学院名称计算机科学与技术学院专业班级学号学生姓名实验日期成绩课程名称计算机数值方法实验题目实验二 线性方程组的直接求解法一、 实验目的和要求:(1)实验目的:合理利用Gauss消元法、LU分解法求解下
15、列方程组:0.001X1+2.000X2+3.000X3=1.000-1.000X1+3.712X2+4.623X3=2.000-2.000X1+1.072X2+5.643X3=3.000(2)实验要求:1.应用C,C+或JAVA编出通用程序,源程序要有详细的注释和说明;2.比较计算结果,对不同方法进行比较分析;3.实验完成,提交实验结果并写出报告,分析计算结果是否符合问题的要求,找出计算成功的原因或计算失败的教训。二、 实验内容和原理:(1)Gauss消元法:基本思想为:对于n阶线性方程组,只要各步主元素不为0,经过n-1步消元,就可以得到一个等价的的系数矩阵为上三角形矩阵的方程组,然后再利
16、用回代过程即可求得原方程的解。时间复杂度约为O(n3)。(2)Gauss列主元素消元法:基本思想:在用高斯消元法求解方程组时,用作除法的小主元素可能使舍入误差增加,因此需要考虑依次按列选主元素,然后换行使之变到主元素位置上,再进行消元计算。(3)Gauss完全主元素消元法:基本思想:首先在系数矩阵A中选取绝对值最大的元素作为主元素,然后交换相应行和列,进行高斯消元,其次在A(1)的2n行及2n列选取主元素进行消元,依次进行下去。(4)LU分解法:当系数矩阵A满足顺序主子式不为0时,可将A分解为为一个单位下三角矩阵L和一个上三角矩阵U的乘积,且分解唯一,然后方程式变为Ly=b,Ux=y,接着先求
17、y,再求出x。三、主要仪器设备:笔记本电脑四、操作方法:(1)Gauss消元法: 源代码:/*矩阵A用于存放线性方程组的增广矩阵,向量X表示线性方程组的解,例题为P43例2*/#include#includeint main() double m,p,A1010,X10; int n,i,j,k,q; char c; printf(请输入方程的阶数(小于等于8):n); scanf(%d,&n); for(i=1;i=n;i+)/方便起见从A11开始存入数据 printf(请输入增广矩阵第%d行:n,i); for(j=1;j=n+1;j+) scanf(%lf,&Aij); /for for
18、(i=1;in;i+) m=fabs(Aii);j=i; /m表示矩阵第i列中的最大值,j用来标记最大值所在的行数 for(k=i+1;km)m=fabs(Aki);j=k;/易错 /for for(q=i;q=n+1;q+)/交换第i行和第j行 p=Aiq;Aiq=Ajq;Ajq=p; /for /*消去过程* for(k=i+1;k=n;k+) m=-Aki/Aii; for(j=i;j=1;i-) p=0.0;for(j=i+1;j=n;j+)p=p+Aij*Xj;Xi=(Ain+1-p)/Aii; /for printf(线性方程组的解为:n); for(i=1;i=n;i+) pri
19、ntf(x%d=%lfn,i,Xi); c=getchar(); return 0;(2)Gauss列主元素消元法: 源代码:/*矩阵A用于存放线性方程组的增广矩阵,向量X表示线性方程组的解,例题为P43例2*/#include#includeint main() double m,p,A1010,X10; int n,i,j,k,q; char c; printf(请输入方程的阶数(小于等于8):n); scanf(%d,&n); for(i=1;i=n;i+)/方便起见从A11开始存入数据 printf(请输入增广矩阵第%d行:n,i); for(j=1;j=n+1;j+) scanf(%
20、lf,&Aij); /for for(i=1;in;i+) m=fabs(Aii);j=i; /m表示矩阵第i列中的最大值,j用来标记最大值所在的行数 for(k=i+1;km)m=fabs(Aki);j=k;/易错 /for for(q=i;q=n+1;q+)/交换第i行和第j行 p=Aiq;Aiq=Ajq;Ajq=p; /for /*消去过程* for(k=i+1;k=n;k+) m=-Aki/Aii; for(j=i;j=1;i-) p=0.0;for(j=i+1;j=n;j+)p=p+Aij*Xj;Xi=(Ain+1-p)/Aii; /for printf(线性方程组的解为:n); f
21、or(i=1;i=n;i+) printf(x%d=%.3lfn,i,Xi); c=getchar(); return 0;(3)Gauss完全主元素消元法: 源代码:/*矩阵A用于存放线性方程组的增广矩阵,向量X表示线性方程组的解*/#include#includeint main() double m,p,A1010,X10; int n,i,j,k,q,l,c,w; char a; printf(请输入方程的阶数(小于等于8):n); scanf(%d,&n); for(i=1;i=n;i+)/方便起见从A11开始存入数据 printf(请输入增广矩阵第%d行:n,i); for(j=1
22、;j=n+1;j+) scanf(%lf,&Aij); /for for(i=1;in;i+) m=fabs(Aii);j=i;l=i; /m表示矩阵第i列中的最大值,j用来标记最大值所在的行数,l用来标记最大值所在的列数 for(k=i;k=n;k+) for(c=i;cm)m=fabs(Akc);j=k;l=c;/易错,忘加fabs for(q=i;q=n+1;q+)/交换第i行和第j行 p=Aiq;Aiq=Ajq;Ajq=p; /for for(w=i;w=n;w+)/交换第i列与第c列 p=Awi; Awi=Awc; Awc=p; /*消去过程* for(k=i+1;k=n;k+) m
23、=-Aki/Aii; for(j=i;j=1;i-) p=0.0;for(j=i+1;j=n;j+)p=p+Aij*Xj;Xi=(Ain+1-p)/Aii; /for printf(线性方程组的解为:n); for(i=1;i=n;i+) printf(x%d=%lfn,i,Xi); a=getchar(); return 0;(4)LU分解法: 源代码:#include#includeint main() double p,A1212,x12,L1212,R1212,b12,y12; int n,i,j,k,m; printf(请输入方程组的阶数(小于等于10):n); scanf(%d,&
24、n); for(i=1;i=n;i+) printf(请输入系数矩阵的第%d行:n,i);for(j=1;j=n;j+)scanf(%lf,&Aij); /for printf(请输入右端向量b:n); for(i=1;i=n;i+) scanf(%lf,&bi); for(j=1;j=n;j+) R1j=A1j;/上三角矩阵R的第一行为A的第一行 for(i=2;i=n;i+) Li1=Ai1/R11;/求出L的第一列 for(k=2;k=n-1;k+) for(j=k;j=n;j+)p=0.0; for(m=1;m=k-1;m+)p=p+Lkm*Rmj;Rkj=Akj-p;/forfor(
25、i=k+1;i=n;i+) p=0.0; for(m=1;m=k-1;m+)p=p+Lim*Rmk; Lik=(Aik-p)/Rkk;/for /for p=0.0; for(j=1;j=n-1;j+)/求Rnn p=p+Lnj*Rjn; Rnn=Ann-p; y1=b1;/回代过程求y for(k=2;k=n;k+) p=0.0;for(j=1;j=1;k-) p=0.0;for(j=k+1;j=n;j+)p=p+Rkj*xj;xk=(yk-p)/Rkk; /for printf(线性方程组的解为:n); for(i=1;i列主元素消元法完全主元素消元法,同时LU分解法的运算量与高斯消元法差
26、不多。(2)运算精确度:高斯消元法解方程的时候,用做除法的小主元素可能使舍入误差增加,而完全主元素消元法和列主元素消元法可以避免采用绝对值小的主元素,使高斯消元法有较好的数值稳定性,减小舍入误差。同时通过对程序分析可知完全主元素消元法比列主元素更精确些。七、心得体会: 将一种数学方法转化为程序还应考虑它的通用性,应将程序设计成通用性高,能够解决一类问题而不是一种问题,这才是一个计算机专业人员应该考虑的。实验地点指导教师 太原理工大学学生实验报告学院名称计算机科学与技术学院专业班级学号学生姓名实验日期成绩课程名称计算机数值方法实验题目实验三 线性方程组的迭代求解法一、 实验目的和要求:(1)实验
27、目的:使用雅可比迭代法或高斯-赛德尔迭代法对下列方程组进行求解。 10X1-X2-2X3=7.2 -X1+10X2-2X3=8.3 -X1-X2+5X3=4.2(2)实验要求:1.应用C,C+或JAVA编出通用程序,源程序要有详细的注释和说明;2.比较计算结果,对不同方法进行比较分析;3.实验完成,提交实验结果并写出报告,分析计算结果是否符合问题的要求,找出计算成功的原因或计算失败的教训。二、 实验内容和原理:(1)雅克比迭代:基本思想:对线性方程组AX=b的系数矩阵A可逆且主对角元素均不为0,令D=diag(a11,a22,a33,.ann),并将A分解成A=(A-D)+D,从而方程组可写为
28、DX=(D-A)X+b,令X=B1X+f1,其中B1=I-AD-1,f1=bD-1,以B1为迭代矩阵的迭代法公式:X(k+1)=B1X(k)+f1,称为雅克比迭代法。(2)高斯赛德尔迭代法:基本思想:由雅克比迭代法可知,在迭代的每一步都是用X(k)的全部分量来计算X(k+1)的所有分量,在计算Xi(k+1)时,Xi(k+1)(i=0,1,.i-1)没有被利用。因此,对这些最新计算出来的第k+1次近似X(k+1)的分量加以利用,就得到解方程组的高斯赛德尔迭代法。三、 主要仪器设备: 笔记本电脑四、 操作方法:源代码:(1)雅克比迭代法:#include#includeint main() dou
29、ble e,m,q,A1212,x012,x112;/*x0和x1分别表示第k次和第k+1次迭代结果,且初始x0=0*/ int n,i,j,k; printf(请输入方程组的阶数(小于等于10):n); scanf(%d,&n); for(i=1;i=n;i+) printf(请输入增广矩的第%d行:n,i);/逐行输入增广矩阵,并对x0赋初值 for(j=1;j=n+1;j+) scanf(%lf,&Aij); x0i=0.0; /forprintf(请输入误差限e:n);scanf(%lf,&e);for(i=1;i=n;i+)/*按照迭代公式x1i=(Ain+1-Aij*x0j)/Ai
30、i(1=i=n,j!=i,k=0,1,2,3.)计算求解*/ m=0.0; for(j=1;j=i-1;j+) m=m+Aij*x0j; for(j=i+1;j=n;j+) m=m+Aij*x0j; x1i=(Ain+1-m)/Aii;/forq=0.0;/q为x1与x0间的误差for(i=1;ie) /*当不满足精度要求则执行迭代过程*/ for(i=1;i=n;i+) x0i=x1i; for(i=1;i=n;i+) m=0.0; for(j=1;j=i-1;j+) m=m+Aij*x0j; for(j=i+1;j=n;j+) m=m+Aij*x0j; x1i=(Ain+1-m)/Aii;/forq=0.0;for(i=1;i=n;i+) q=q+fabs(x1i-x0i);/whileprintf(线性方程组的解为:n);for(i=1;i=n;i+) printf(x%d=%.4lfn,i,x1i);return 0;(2)高斯赛德尔迭代法: #include#includeint main() double e,m,q,A1212,x012,x112;/*x0和x1分别表示