ImageVerifierCode 换一换
格式:DOCX , 页数:11 ,大小:109.53KB ,
资源ID:5895111      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/5895111.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Romberg求积法.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

Romberg求积法.docx

1、Romberg求积法安徽中医药大学题目:Romberg求积法c语言编程姓名:杨撞撞学号:13713042班级:13医软(1)班1简介2计算公式3算法描述4程序流程图5算法程序表示6算法结果截图 1.简介龙贝格求积公式也称为逐次分半加速法。它是在梯形公式、辛普森公式和柯特斯公式之间的关系的基础上,构造出一种加速计算积分的方法。 作为一种外推算法, 它在不增加计算量的前提下提高了误差的精度.在等距基点的情况下,用计算机计算积分值通常都采用把区间逐次分半的方法进行。这样,前一次分割得到的函数值在分半以后仍可被利用,且易于编程。 2.计算公式梯形公式复化辛普森公式复化科特斯公式 龙贝格求积公式其对应的

2、公式为:T2n=1/2(Tn+Hn) (梯形公式)Sn=4/(4-1)T2n-1(4-1)Tn (辛普森公式)Cn=42/(42-1)S2n-1/(42-1)Sn (柯特斯公式)Rn=43/(43-1)C2n-1/(43-1)Cn (龙贝格求积法公式) 3.算法描述3.1龙贝格算法基本描述先算出T0(0),从而计算出T0(1),以此类推,直到计算出|T0(0)-Tn-1(0)|e即可利用加速推算公式推算出结果。 3.2龙贝格算法程序包步骤 1.输入积分上限 2输入程序下限3输入区间等分数4输入要求的函数5计算出所求函数的积分,分别是: 复化梯形求积结果 辛普森求积结果 柯特斯求积结果 龙贝格求

3、积结果 4.程序流程图例题:用Romberg方法计算积分I=0sin(x)/xdx的相关算法流程图表示如下图 5.算法程序表示#include#include#define A(x)(sin(x)/x) /宏定义若干常用函数A,B,C,D,E,G#define B(x)(cos(x*x+2*x+1)#define C(x)(atan(sqrt(x*x+1)#define D(x)(sqrt(exp(x)+sin(2*x)#define E(x)(x*x*x+3*x*x+5)#define G(x)(log10(x)/pow(2,x)double t20,s20,c20,r20;/定义全局数组d

4、ouble dh,fan,a,b,m; /定义全局变量int jj=0;char hs;double F(double x) /用switch调用若干被积函数 switch(hs) case A:fan=A(x);break; case B:fan=B(x);break; case C:fan=C(x);break; case D:fan=D(x);break; case E:fan=E(x);break; case G:fan=G(x);break; default :printf(输入错误!); return(fan);/返回被积函数值double H(int i) /求和函数并返回和SU

5、M int j; double zh,SUM=0.0; /定义求和变量SUM并赋初值 for(j=1;j=pow(2,i-1);j+) zh=(a+(2*j-1)*(b-a)/pow(2,i); SUM=SUM+F(zh); /调用F(x)函数 SUM=(b-a)*SUM/pow(2,i); return(SUM);double Txing(int k) /梯形公式 if(k=0) dh=tjj=(b-a)/2)*(F(a)+F(b); /分半次数为零时T形公式求积 else dh=0.5*Txing(k-1)+H(k); /Txing函数递归调用循环输出并返回dh t+jj=dh; m=po

6、w(2,jj); printf(T%0.0lf=%0.7lft,m,tjj);/输出并返回dh return(dh);double Simpson(int k) /辛普森公式 int i,j; Txing(k); /调用梯形公式 for(i=0;i=k-1;i+) si=(4.0*ti+1-ti)/3.0; /递推辛普森公式 printf(n); for(j=0;j=k-1;j+) /循环输出 m=pow(2,j); printf(S%0.0lf=%0.7lf,m,sj); printf(t); return(sk-1); /返回最后一个值sk-1double Cotes(int k) /科特

7、斯公式 int i,j; Simpson(k); for(i=0;i=k-2;i+) ci=(16.0*si+1-si)/15.0; /递推科特斯公式 printf(n); for(j=0;j=k-2;j+) /循环输出 m=pow(2,j); printf(C%0.0lf=%0.7lft,m,cj); return(ck-2); /返回最后一个值ck-2double Romberg(int k) /隆贝格公式 int i,j; /调用科特斯公式 Cotes(k); for(i=0;i=k-3;i+) ri=(64.0*ci+1-ci)/63.0; /递推隆贝格公式 printf(n); fo

8、r(j=0;j=k-3;j+) /循环输出 m=pow(2,j); printf(R%0.0lf=%0.7lft,m,rj); printf(n); return(rk-3); /返回最后一个值rk-3main() int k; char y; printf(请从以下公式中选择积分函数:n); printf(A: sin(x)/(x)tB:cos(x2+2x+1)tC:atan(sqrt(x2+1)nn); printf(D:sqrt(ex+sin(2x)tE:x3+3*x2+5tG:log10(x)/pow(2,x)nn); printf(请选择函数F(x)(大写):n); scanf(%c

9、,&hs); getchar(); printf(请输入您选用的求积公式第一个字母(大写):n); y=getchar(); switch(y) /根据输入的大写字母判断所选求积公式 case T:printf(请输入分半次数:n); scanf(%d,&k); printf(请输入积分区间a,b且(ab):n); scanf(%lf,%lf,&a,&b); if(a=0) a=0.0000000001; /输入当积分区间为零时默认为一极小数 printf(-n); printf(nTxing=%0.7fn,Txing(k);break; /输出计算结果小数点后保留7位 case S:prin

10、tf(请输入分半次数大于等于1的正整数:n); scanf(%d,&k); printf(请输入积分区间a,b且(ab):n); scanf(%lf,%lf,&a,&b); if(a=0) a=0.0000000001; /输入当积分区间为零时默认为一极小数 printf(-n); printf(Simpson=%0.7fn,Simpson(k);break; /输出计算结果小数点后保留7位 case C:printf(请输入分半次数大于等于2的正整数:n); scanf(%d,&k); printf(请输入积分区间a,b且(ab):n); scanf(%lf,%lf,&a,&b); if(a

11、=0) a=0.0000000001; /输入当积分区间为零时默认为一极小数 printf(-n); printf(Cotes=%0.7fn,Cotes(k);break; /输出计算结果小数点后保留7位 case R:printf(请输入分半次数大于等于3的正整数:n); scanf(%d,&k); printf(请输入积分区间a,b且(ab):n); scanf(%lf,%lf,&a,&b); if(a=0) a=0.0000000001; /输入当积分区间为零时默认为一极小数 printf(-n); printf(Romberg=%0.7fn,Romberg(k);break; /输出计算结果小数点后保留7位 default:printf(-n); printf(公式输入有误,请查证!n); printf(-n);6.算法结果截图

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

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