复化梯形法-复化矩形法-变步长梯形-变步长辛普森.docx
《复化梯形法-复化矩形法-变步长梯形-变步长辛普森.docx》由会员分享,可在线阅读,更多相关《复化梯形法-复化矩形法-变步长梯形-变步长辛普森.docx(11页珍藏版)》请在课桌文档上搜索。
1、陕西科技大学切城教成斑用C+的积分其实积分的思想就是,微分一求和取极限,如果是用纯手工法那就是先对一个函数微分,再求出它的面积,在取极限,因为我们的计算速度和计算量有限,现在有了计算机这个速度很快的机器,我们可以把微分后的每个小的面积加起来,为了满足精度,我们可以加大分区,即使实现不了微分出无限小的极限情况,我们也至少可以用有限次去接近他,下面我分析了四种不同的积分方法,和一个综合通用程序。积分的根本思想1、思路:微分一求和一取极限。2、NewtonLeibniz公式其中,E(X)被积函数/()的原函数。3,用计算机积分的思路在积分区间内“微分一求和一控制精度。因为计算机求和不可以取极限,也就
2、是不可以无限次的加下去,所以要控制精度。二.现有的理论1、一阶求积公式梯形公式他只能精确计算被积函数为0、1次多项式时的积分。2、二阶求积分公式一一牛顿、科特斯公式他只能精确计算被积函数为0、1、2、3次多项式时的积分。三.四种实现方法1复化矩形法将积分区间a,b等分成n个子区间:那么h=(b-a)n,区间端点值Xk=a+kh源程序:#include#includedoublef(doublex)计算被积函数doubley;y=log(l+x)(l+x*x):被积函数returny:doubleTn(doublea,doubleb,intn)求Tndoublet=0.0;doublexk;区间
3、端点值doubletl,t2;用来判断精度dodoubleh=(b-a)n;for(intk=l;k=n-l;k+)每一小段的矩形叠加tl=t;xk=a+k*h;t+=h*f(xk);t2=t;n+;如果精度不够就对区间再次细分,直到到达精度要求while(fabs(tl-t2)=le-7);判断计算精度returnt;voidmain()doublea=0.0;积分下线doubleb=2.0;积分上限intn=1024;把区间分为1024段coutTn(a,b,n)endl;输出积分结果执行结果:2复化梯形法方法和复化矩形法类似,只是把原来的矩形小面积变成了梯形小面积,但是精确度明显提高了,
4、也就是说到达同样的精度需要的时间少了。变形一下:源程序:include#includedoublef(doublex)计算被积函数doubley;y=log(l+x)(l+x*x);被积函数returny:doubleTn(doublea,doubleb,intn)求Tndoublet=0.0;doublexk;区间端点值doubletl,t2,h=(b-a)n;用来判断精度doh=(b-a)/n;for(intk=l:k=n-l:k+)余项叠加,相当于每一个小梯形相加tl=t;xk=a+k*h;t+=f(xk);t2=t;n+;如果精度不够就对区间再次细分,直到到达精度要求while(fab
5、s(tl-t2)=le-7);判断计算精度t=h*(f(a)+f(b)2+t*h;加上初项就是积分结果了returnt;voidmain()积分下线积分上线把区间分为1024段doublea=0.0;doubleb=2.0;intn=1024;coutTn(a,b,n)endl;输出积分结果执行结果:3 .变步长梯形法上面我们在应用复化积分法的时候会对区间进行分割,但是在要求精度是我们也不知道事先应该分割成多少段,分的少了精度达不到,分的多了计算量太大,为了解决这个问题我在上面加了一个循环,来不断地对区间进行再次划分,直到到达精度要求,变步长积分法与我用的方法类似,只不过变步长积分法的区间划分
6、时成倍增加的。实现方法;由复化梯形法知道;步长h=(b-a)n现在将步长分半,即在相邻两节点xqXa+的中点X1=1+/G处增加2一个求积节点,那么变形一下:源程序:#include#includedoublef(doublex)计算被积函数的值doubley;y=log(l+x)(l+x*x):returny;doublet2ntn(doublea9doubleb)intn=l;doublehn=ba;原步长doubletn=O.0;doublet2n=(f(a)+f(b)*hn2.0;while(fabs(t2n-tn)le-7)判断精度tn=t2n;t2n=0.0;for(intk=O;
7、k=n-l;k+)循环叠加t2n+=f(a+hn2.0+k*hn);t2n=tn2.0+t2n*hn2.0;n=n*2;hn=hn2.0;步长分半returnt2n;voidmain()(doublea=0.0;doubleb=2.0;coutt2ntn(a,b)endl;执行结果:4 .变步长辛普森法之前的积分斜边都是直线,如果用抛物线接近就会更准确复化辛普森求积公式然后就只要每企让他的积分区间加倍就行直到到达要求的精度#include#include#includedoublea=0.0,b=2.0,e=le-7;积分上下线,和精度要求intn=1024;doublef(doublex)D
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 梯形 矩形 步长 辛普森
链接地址:https://www.desk33.com/p-845769.html