《数值计算方法实验报告》由会员分享,可在线阅读,更多相关《数值计算方法实验报告(20页珍藏版)》请在人人文库网上搜索。
1、本科实验报告实验过程数值计算和方法大学名称专业名称学生姓名学生学号指导教师实验场所实验成绩2006年4月22日6年5月目录实验1:舍入误差和数值稳定性21.1目的和要求21.2舍入误差和数值稳定性21.2.1概述21.2.2程序和范例2实验2:方程式52.2二分法52.2.1算法52.2.2程序和范例5实验3牛顿迭代方法72.3.1算法7实验3牛顿迭代方法102.3.1算法10实验4:热主成分高斯消去法134.1算法134.2程序和范例14实验5:牛顿插值多项式165.1算法165.2程序和范例16实验1:舍入误差和数值稳定性1.1目的和要求(1)通过机器编程,审查和整合以前学过的编程语言和机。
2、器操作说明。(2)详述舍入误差引起的数值不稳定性,以便理解。1.2舍入误差和数值稳定性1.2.1摘要舍入误差是计算方法中非常重要的概念。在实际计算中,选择不同的算法会受到舍入误差的影响,得到非常不同的结果。因此,选择稳定的算法在实际计算中非常重要。1.2.2程序和范例N=0,1,2,计算40的明确积分算法1使用递归公式拿0。算法2使用递归公式(n=420,39,1)我注意到了醉意算法1 C语言程序为:#include#includeVoid main()双y_0=日志(6.0/5.0),y _ 1;/定义两个变量y_1,y_2的值/int n=1;/周期变量定义/Printf(y0=%-20f。
3、 ,y _ 0);/y0的值输出/While(1) /使用While循环递归计算/y _ 1=1.0/n-5 * y _ 0;/yn的值,y_0表示yn 1,y1表示yn/Printf(y%d=%-20f ,n,y _ 1);/计算的yn值输出小于20个字符的值的刷新空格/if(n=40)break;/n=40,偏离回路/y _ 0=y _ 1;/y_1的值作为y_0下一次计算的yn-1/n;/n逐步重叠/if(n % 2=0)printf( n );/每两个换行/算法2 C语言程序如下#include#includeVoid main()Double y _ 0=(1/205.0 1/246。
4、.0)/2,y _ 1;/定义两个双精度变量y_0、y_1并为y_指定值/Int n=40/分配n=40/Printf(y40=%-20f ,y _ 0);/y导出为20的字段宽度,y_0的值输出为/While(1)y _ 1=1/(5.0 * n)-y _ 0/5.0;/递归公式肌肉计算y1/Printf(y%d=%-20f ,n-1,y _ 1);/计算次数n-1级y_(n-1)的值输出/if(n=1)break;/n=1,偏离回路/y _ 0=y _ 1;/将y_1的值指定给y_0/n-;/n自身相减/if(n % 3=0)printf( n );/n为奇数,空行/实验2:方程式2.2二。
5、分法2.2.1算法在指定部分a,b中,将f(a)和f(b)符号相反地设置为根的容差,将设置为|f(x)|的容差。命令(a b)/2。(c-a)或| f (c) | 时输出c,结束;否则,请执行。如果F(a)f(c)0,则a=c;否则,b=c,重复。2.2.2程序和范例范例2.1寻找靠近1.5的方程式。c语言程序包括:#include#include的库函数#define EPS 5e-6#define delta 1e-6Float bi section (float a,float b,float (* f) (float)Float c、fc、fa=(*f)(a),FB=(* f)(b);int n=1;Printf(二分法 t TC t t f(c) n );While(1)If(fa*fb0) printf(“不能用二分法求解”);BreakC=(a b)/2,fc=(* f)(c);printf(“% d t t % f t t % f n”,n,c,fc);if(fab)#include#define N 100 #define EPS 1e-6 #define eta 1e。
7、-8Float Newton (Float (* f) (float),float (* f1) (float),float x0)if(k n | | faps(* f1)(x1)n或x1替换为函数f1的浮点数的绝对值大于eps*/Printf(n Newton重复发散);Breakd=fab(x1)1?x1-x 03360(x1-x0)/x1;X0=x1Printf(x(%d)=%ft ,k,x0);while(faps(d)EPS faps(* f)(x1)eta);Return x1浮点f(浮点x)return x * x * x * x * x-3 * x-3;return 3.0 * x * x 2 * x-3;Void main()Float x0,y0;输入Printf(重复初始值x0n )。);scanf(“% f”,x0);Printf(x(0)=%fn ,x0);Y0=牛顿(f,f1,x0);中的f、f1、x0替换为NewtonPrintf(方程式的根为%fn ,y0)。实验3牛顿迭代法2.3.1算法给出初始值后,是根的容差,|f(x)|的容差,n是迭代数的容差。a)如果水果或迭代大于n,算法将失败并终止。否则就履行。B) 计算。c)如果。
10、| | 或|f()|输出,程序将终止;否则,执行。d)命令,切换。2.3.2程序和范例寻找方程式f(x)=1.5附近的布线。c语言程序包括:#include#include#define N 100 #define EPS 1e-6 #define eta 1e-8Float Newton (Float (* f) (float),float (* f1) (float),float x0)if(k n | | faps(* f1)(x1)n或x1替换为函数f1的浮点数的绝对值大于eps*/Printf(n Newton重复发散);Breakd=fab(x1)1?x1-x 03360(x1-x0)/x1;X0=x1Printf(x(%d)=%ft ,k,x0);while(faps(d)EPS faps(* f)(x1)eta);Return x1浮点f(浮点x)return x * x * x * x * x-3 * x-3;return 3.0 * x * x 2 * x-3;Void main()Float x0,y0;输入Printf(重复初始值x0n )。);scanf(“% f”,x0);Printf。