您好,欢迎访问三七文档
当前位置:首页 > 电子/通信 > 综合/其它 > 数学实验“几种常见的求积分近似解的方法”实验报告(内含matlab程序)
西京学院数学软件实验任务书课程名称数学软件实验班级数0901学号0912020107姓名李亚强实验课题Romberg积分法,Gauss型积分法,高斯-勒让德积分法,高斯-切比雪夫积分法,高斯-拉盖尔积分法,高斯-埃尔米特积分法实验目的熟悉Romberg积分法,Gauss型积分法,高斯-勒让德积分法,高斯-切比雪夫积分法,高斯-拉盖尔积分法,高斯-埃尔米特积分法实验要求运用Matlab/C/C++/Java/Maple/Mathematica等其中一种语言完成实验内容Romberg积分法,Gauss型积分法,高斯-勒让德积分法,高斯-切比雪夫积分法,高斯-拉盖尔积分法,高斯-埃尔米特积分法成绩教师-1-实验二十一实验报告一、实验名称:Romberg积分法,Gauss型积分法,高斯-勒让德积分法,高斯-切比雪夫积分法,高斯-拉盖尔积分法,高斯-埃尔米特积分法。二、实验目的:进一步熟悉Romberg积分法,Gauss型积分法,高斯-勒让德积分法,高斯-切比雪夫积分法,高斯-拉盖尔积分法,高斯-埃尔米特积分法。三、实验要求:运用Matlab/C/C++/Java/Maple/Mathematica等其中一种语言完成程序设计。四、实验原理:1.Romberg积分法:龙贝格积分法是用里查森外推算法来加快复合梯形求积公式的收敛速度,它的算法如下,其中()imT是通过一系列逼近原定积分的龙贝格分值.计算(0)1[()()]2baTfafb对1,2,3,kn,计算下列各步:21()(1)11111(21)()[()]222kkkkkjbajbaTTfa对1,2,,mk和,1,2,,1ikkk,计算111441miiimmmmTTT-2-随着计算的步骤的增加,()imT越来越逼近积分()bafxdx。2.Gauss型积分法:高斯积分公式的思想是用n个不等距的节点123,,,nxxxx对被积函数进行插值,然后对插值后的函数进行积分,其积分公式为:111()()nkkkfxdxAfx如果积分区间不是[1,1],则需转换到此区间:11()()222babababafxdxftdt其中系数kA、节点kx与n的关系如下表所示:3.高斯-切比雪夫积分法:第一类切比雪夫积分形式为:12111()()1nkkkfxdxAfxx其中kAn,21cos2kkxn4.高斯-拉盖尔积分法:高斯-拉盖尔公式有两种形式:01()()nxkkkefxdxAfx01()()knxkkkfxdxAefx-3-下面编制的程序是针对第一种形式的高斯-拉盖尔公式,即01()()nxkkkefxdxAfx因此程序的第一个输入参数——被积函数,是上式中的()fx。5.高斯-埃尔米特积分法:高斯-埃尔米特公式有以下两种形式:21()()nxkkkefxdxAfx21()()knxkkkfxdxAefx下面编制的程序是针对第一种形式的高斯-埃尔米特公式,即21()()nxkkkefxdxAfx因此程序的第一个输入参数——被积函数,是上式中的()fx。五、实验内容:%Romberg积分法function[q,step]=Roberg(f,a,b,eps)if(nargin==3)-4-eps=1.0e-4;endM=1;tol=10;k=0;T=zeros(1,1);h=b-a;T(1,1)=(h/2)*(subs(sym(f),findsym(sym(f)),a)+subs(sym(f),findsym(sym(f)),b));whiletolepsk=k+1;h=h/2;Q=0;fori=1:Mx=a+h*(2*i-1);Q=Q+subs(sym(f),findsym(sym(f)),x);endT(k+1,1)=T(k,1)/2+h*Q;M=2*M;forj=1:kT(k+1,j+1)=T(k+1,j)+(T(k+1,j)-T(k,j))/(4^j-1);endtol=abs(T(k+1,j+1)-T(k,j));endq=T(k+1,j+1);step=k;%Gauss型积分法functionq=IntGauss(f,a,b,n,AK,XK)if(n5&&nargin==4)AK=0;XK=0;elseXK1=((b-a)/2)*XK+((a+b)/2);q=((b-a)/2)*sum(AK.*subs(sym(f),findsym(f),XK1));endta=(b-a)/2;tb=(a+b)/2;-5-switchncase1q=2*ta*subs(sym(f),findsym(sym(f)),tb);case2q=ta*(subs(sym(f),findsym(sym(f)),ta*0.5773503+tb)+subs(sym(f),findsym(sym(f)),-ta*0.5773503+tb));case3q=ta*(0.55555556*subs(sym(f),findsym(sym(f)),ta*0.7745967+tb)+0.55555556*subs(sym(f),findsym(sym(f)),-ta*0.7745967+tb)+0.88888889*subs(sym(f),findsym(sym(f)),tb));case4q=ta*(0.3478548*subs(sym(f),findsym(sym(f)),ta*0.8611363+tb)+0.3478548*subs(sym(f),findsym(sym(f)),-ta*0.8611363+tb)+0.6521452*subs(sym(f),findsym(sym(f)),ta*0.3398810+tb)+0.6521452*subs(sym(f),findsym(sym(f)),-ta*0.3398810+tb));case5q=ta*(0.2369269*subs(sym(f),findsym(sym(f)),ta*0.9061793+tb)+0.2369269*subs(sym(f),findsym(sym(f)),-ta*0.9061793+tb)+0.4786287*subs(sym(f),findsym(sym(f)),ta*0.5384693+tb)+0.4786287*subs(sym(f),findsym(sym(f)),-ta*0.5384693+tb)+0.5688889*subs(sym(f),findsym(sym(f)),tb));end%高斯-勒让德积分法function[ql,Ak,xk]=guasslegendre(fun,a,b,n,tol)ifnargin==1a=-1;b=1;n=7;tol=1e-8;elseifnargin==3n=7;tol=1e-8;elseifnargin==4tol=1e-8;-6-elseifnargin==2|nargin5error('TheNumberofInputArgumentsIsWrong!');endsymsxp=sym2poly(diff((x^2-1)^(n+1),n+1))/(2^n*factorial(n));tk=roots(p);Ak=zeros(n+1,1);fori=1:n+1xkt=tk;xkt(i)=[];pn=poly(xkt);fp=@(x)polyval(pn,x)/polyval(pn,tk(i));Ak(i)=quadl(fp,-1,1,tol);endxk=(b-a)/2*tk+(b+a)/2;fun=fcnchk(fun,'vectorize');fx=fun(xk)*(b-a)/2;ql=sum(Ak.*fx);%高斯-切比雪夫积分法functionq=IntQBXF1(func,n)formatlong;pi=3.1415926535;q=0;A=zeros(n,1);x=zeros(n,1);fori=1:nA(i)=pi/n;x(i)=cos(pi*(2*i-1)/2/n);y(i)=subs(sym(func),findsym(sym(func)),x(i));q=q+A(i)*y(i);end%高斯-拉盖尔积分法functionq=IntGaussLager(f,n,AK,XK)if(n6&&nargin==2)AK=0;-7-XK=0;elseq=sum(AK.*subs(sym(f),findsym(f),XK));endswitchncase2q=0.853553*subs(sym(f),findsym(sym(f)),-0.585786)+0.146447*subs(sym(f),findsym(sym(f)),3.414214);case3q=0.711093*subs(sym(f),findsym(sym(f)),0.415575)+0.278518*subs(sym(f),findsym(sym(f)),2.294280)+0.0103893*subs(sym(f),findsym(sym(f)),6.289945);case4q=0.603154*subs(sym(f),findsym(sym(f)),0.322548)+0.357419*subs(sym(f),findsym(sym(f)),1.745761)+0.0388879*subs(sym(f),findsym(sym(f)),4.536620)+0.000539295*subs(sym(f),findsym(sym(f)),9.395071);case5q=0.521756*subs(sym(f),findsym(sym(f)),0.263560)+0.398667*subs(sym(f),findsym(sym(f)),1.413403)+0.0759424*subs(sym(f),findsym(sym(f)),3.596426)+0.00361176*subs(sym(f),findsym(sym(f)),7.085810)+0.0000233700*subs(sym(f),findsym(sym(f)),12.640801);end%高斯-埃尔米特积分法functionq=IntGaussHermite(f,n,AK,XK)if(n6&&nargin==2)AK=0;XK=0;elseq=sum(AK.*subs(sym(f),findsym(f),XK));endswitchn-8-case2q=0.886227*(subs(sym(f),findsym(sym(f)),-0.707107)+subs(sym(f),findsym(sym(f)),0.707107));case3q=1.181636*subs(sym(f),findsym(sym(f)))+0.295409*subs(sym(f),findsym(sym(f)),1.224745)+subs(sym(f),findsym(sym(f)),-1.224745);case4q=0.544444*(subs(sym(f),findsym(sym(f)),0.524648)+subs(sym(f),findsym(sym(f)),-0.524648))+0.100000*(subs(sym(f),findsym(sym(f)),1.650680)+subs(sym(f),findsym(sym(f)),-1.650680));case5q=0.945309*subs(sym(f),findsym(sym(f)),0)+0.393619*(subs(sym(f),findsym(sym(f)),0.958572)+subs(sym(f),findsym(sym(f)),-0.958572))+0.199532*(su
本文标题:数学实验“几种常见的求积分近似解的方法”实验报告(内含matlab程序)
链接地址:https://www.777doc.com/doc-2196285 .html