实验三数值积分.docVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验三数值积分

《数值计算基础》实验报告 专 业:计算机科学与技术 班 级: 2013级1303班 学 号: 201313137085 姓 名: 胡恒德 指导老师: 王 薇 实验名称 数值积分 实验日期 2015.06.05 报告规范 (10分) 程序一 (35分) 程序二 (35分) 实验小结 (20分) 总分 【实验目的】 掌握复化梯形法与龙贝格法计算定积分。 【实验内容】 分别写出变步长梯形法与Romberg法计算定积分的算法,编写程序上机调试出结果,要求所编程序适用于任何类型的定积分,即能解决这一类问题,而不是某一个问题。 实验中以下列数据验证程序的正确性。 求。 【实验小结】 通过变步长梯形法与龙贝格法,我们只要知道已知n个求积节点的函数值,则可由相应的公式求出该函数的积分值,从而不需要求该函数的原函数。有了这个思想,结合相应的公式,编程就很容易实现了。 变步长梯形法 一、问题 保存计算的Tn和T2n的值可以只用T[1]、T[2]来保存,而不需要很大的数组,比如T[1]、T[2]、T[4]等,这就比较浪费空间。 二、源代码 double Tn(double a,double b,double eps) //变步长梯形计算 { int k,n=1; double h=b-a,T[3]; T[1]=h*(b-a)/2; do{ T[2]=0; for(k=0;kn;k++) T[2]+=Fx(a+(k+0.5)*h); T[2]=(T[1]+h*T[2])/2; T[0]=T[2]-T[1]; //保存结果 T[1]=T[2]; n*=2; h/=2; }while(T[0]eps); return T[1]; } 三、运行结果 Romberg法计算定积分 一、问题 采用二维数组保存计算的Tm(k)的计算值,一行一行的计算,注意数组下标与真实T-数表的关系,就比较容易的算出来了。另外,在计算过程中,涉及到比较多的指数运算,还是相同的多次运算,可以只算一次保存在一个变量中,这样可以提高运算效率。 二、源代码 #includestdio.h #includemath.h #includestdlib.h #define MAX 10 double a,b,eps,T[MAX][MAX]; double Fx(double x) //就算f(x) { if(x==0) return 1; else return sin(x)/x; } double Romberg() { int i,j,m=0,k=0; double t; T[0][0]=(b-a)*(Fx(a)+Fx(b))/2; for(m=1; ;m++) { for(k=0;k=m;k++) { if(k==0) { t=(b-a)/pow(2,m); T[m][k]=0; for(j=0;j=pow(2,m-1)-1;j++) T[m][k]+=Fx(a+(2*j+1)*t); T[m][k]=T[m][k]*t+0.5*T[m-1][k]; } else { T[m][k]=(pow(4,k)*T[m][k-1]-T[m-1][k-1])/(pow(4,k)-1); } } if(fabs(T[m][k-1]-T[m-1][k-2])=eps) break; } printf(T-数表为:\n); for(i=0;i=m;i++) { for(j=0

文档评论(0)

kakaxi + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档