数值积分的算法比较及其MATLAB实现
- 格式:doc
- 大小:3.05 MB
- 文档页数:63
使用Matlab进行数值积分的方法与注意事项1. 引言数值积分是数学中的一个重要概念,它能够将曲线下的面积或者函数的总值进行估计和计算。
在实际应用中,由于很多函数无法直接进行解析求积,因此数值积分成为了一种常用的计算方法。
Matlab作为一款强大的数值计算软件,提供了很多用于数值积分的函数和方法。
2. 数值积分的基本原理数值积分的基本思想是将被积函数分割成一系列小区间,然后对每个小区间进行近似计算得到面积的总和。
这个过程可以看作是对大曲线的逼近,通过增加小区间的数目,可以得到更加精确的结果。
常见的数值积分方法有矩形法、梯形法、辛普森法等。
3. Matlab中的数值积分函数在Matlab中,有两个常用的数值积分函数分别是`quad`和`quadl`。
`quad`函数适用于一般的一元数值积分计算,而`quadl`函数则适用于具有奇点的积分计算。
这两个函数使用起来相对简单,只需要输入被积函数和积分区间即可。
例如,计算函数f(x)=x^2在区间[0, 1]上的积分可以使用以下代码:```f = @(x) x^2;integral = quad(f, 0, 1);disp(integral);```这段代码会输出函数f在区间[0, 1]上的积分值。
4. 数值积分的精度与误差控制在使用数值积分方法进行计算时,我们关心的一个重要问题是精度和误差控制。
数值积分的精度可以通过调整分割的区间数目来控制,一般来说,增加小区间的数目可以得到更加精确的结果。
此外,也可以通过提高数值积分方法的阶来提高精度。
Matlab中的`quad`和`quadl`函数具有较高的精度,并且可以通过设置选项来控制误差的允许范围。
5. 数值积分的注意事项在使用Matlab进行数值积分时,需要注意一些问题。
首先是积分区间的选择,需要确保被积函数在整个区间上是光滑的,没有奇点和间断。
如果存在奇点或者间断,需要通过分段积分或者奇点积分方法来处理。
其次是数值积分方法的选择,不同的函数可能适用于不同的数值积分方法,需要结合实际情况来选择最合适的方法。
数值积分的MATLAB实现数值积分是通过数值方法计算定积分的近似值。
MATLAB是一种功能强大的数值计算软件,提供了多种函数和工具箱用于数值积分的实现。
在MATLAB中,常用的数值积分方法包括梯形法则、辛普森法则和龙贝格法。
梯形法则是最简单的数值积分方法之一、它的基本思想是将要积分的区间划分成多个小的梯形并计算每个梯形的面积,然后将这些面积相加得到最终的近似积分值。
在MATLAB中,可以使用trapz函数进行梯形法则的计算。
例如,要计算函数sin(x)在区间[0, pi]的积分,可以使用以下代码:```MATLABx = linspace(0, pi, 1000); % 在[0, pi]区间生成1000个等间隔的点y = sin(x); % 计算函数sin(x)在每个点的值integral_value = trapz(x, y) % 使用梯形法则进行数值积分```辛普森法则是一种更精确的数值积分方法,它使用二次多项式来逼近被积函数。
在MATLAB中,可以使用simpson函数进行辛普森法则的计算。
例如,上面例子中的积分可以改用辛普森法则进行计算:```MATLABintegral_value = simpson(x, y) % 使用辛普森法则进行数值积分```龙贝格法是一种高效的自适应数值积分方法,它通过逐步加密网格和逼近函数来提高积分的精度。
在MATLAB中,可以使用quad和quadl函数进行龙贝格法的计算。
例如,计算函数sin(x)在区间[0, pi]的积分:```MATLAB```除了上述方法外,MATLAB还提供了许多其他的数值积分函数和工具箱,用于处理不同类型的积分问题。
例如,int和integral函数可以用于处理多重积分和奇异积分。
Symbolic Math Toolbox中的函数可以用于计算符号积分。
需要注意的是,数值积分是一种近似方法,计算结果的误差与划分区间的精细程度有关。
M a t l a b数值积分与数值微分Matlab数值积分1.一重数值积分的实现方法变步长辛普森法、高斯-克朗罗德法、梯形积分法1.1变步长辛普森法Matlab提供了quad函数和quadl函数用于实现变步长辛普森法求数值积分.调用格式为:[I,n]=Quad(@fname,a,b,tol,trace)[I,n]=Quadl(@fname,a,b,tol,trace)Fname是函数文件名,a,b分别为积分下限、积分上限;tol为精度控制,默认为1.0×10-6,trace控制是否展开积分过程,若为0则不展开,非0则展开,默认不展开.返回值I为积分数值;n为调用函数的次数.--------------------------------------------------------------------- 例如:求∫e0.5x sin(x+π6)dx3π的值.先建立函数文件fesin.mfunction f=fesin(x)f=exp(-0.5*x).*sin(x+(pi/6));再调用quad函数[I,n]=quad(@fesin,0,3*pi,1e-10)I=0.9008n=365--------------------------------------------------------------------- 例如:分别用quad函数和quadl函数求积分∫e0.5x sin(x+π6)dx3π的近似值,比较函数调用的次数.先建立函数文件fesin.mfunction f=fesin(x)f=exp(-0.5*x).*sin(x+(pi/6));formatlong[I,n]=quadl(@fesin,0,3*pi,1e-10)I=n=198[I,n]=quad(@fesin,0,3*pi,1e-10)I=n=365--------------------------------------------------------------------- 可以发现quadl函数调用原函数的次数比quad少,并且比quad函数求得的数值解更精确.1.2高斯-克朗罗德法Matlab提供了自适应高斯-克朗罗德法的quadgk函数来求震荡函数的定积分,函数的调用格式为:[I,err]=quadgk(@fname,a,b)Err返回近似误差范围,其他参数的意义与quad函数相同,积分上下限可以是-Inf或Inf,也可以是复数,若为复数则在复平面上求积分.--------------------------------------------------------------------- 例如:求积分∫xsinx1+cos2xdx π的数值.先编写被积函数的m文件fsx.mfunction f=fsx(x)f=x.*sin(x)./(1+cos(x).^2);再调用quadgk函数I=quadgk(@fsx,0,pi)I=2.4674--------------------------------------------------------------------- 例如:求积分∫xsinx1+cos2xdx +∞−∞的值.先编写被积函数的m文件fsx.mfunction f=fsx(x)f=x.*sin(x)./(1+cos(x).^2); 再调用quadgk函数I=quadgk(@fsx,-Inf,Inf)I=-9.0671e+017---------------------------------------------------------------------1.3梯形积分法对于一些不知道函数关系的函数问题,只有实验测得的一组组样本点和样本值,由表格定义的函数关系求定积分问题用梯形积分法,其函数是trapz函数,调用格式为:I=Traps(X,Y)X,Y为等长的两组向量,对应着函数关系Y=f(X) X=(x1,x2,…,x n)(x1<x2<…<x n),Y=(y1,y2,…,y n),积分区间是[x1,x n]--------------------------------------------------------------------- 例如:已知某次物理实验测得如下表所示的两组样本点.现已知变量x和变量y满足一定的函数关系,但此关系未知,设y=f(x),求积分13.39∫f(x)dx1.38的数值.X=[1.38,1.56,2.21,3.97,5.51,7.79,9.19,11.12,13.39];Y=[3.35,3.96,5.12,8.98,11.46,17.63,24.41,29.83,32.21];I=trapz(X,Y) I=217.1033---------------------------------------------------------------------例如:用梯形积分法求积分:∫e −x dx 2.51的数值.x=1:0.01:2.5; y=exp(-x); I=trapz(x,y) I= 0.2858---------------------------------------------------------------------2. 多重数值积分的实现重积分的积分函数一般是二元函数f(x,y)或三元函数f(x,y,z);形如:∫∫f (x,y )dxdy ba dc∫∫∫f(x,y,z)dxdydz b a d cf eMatlab 中有dblquad 函数和triplequad 函数来对上述两个积分实现.调用格式为: I=dblquad(@fun,a,b,c,d,tol)I=triplequad(@fun,a,b,c,d,e,f,tol)Fun 为被积函数,[a,b]为x 的积分区间;[c,d]为y 的积分区间;[e,f]为z 的积分区间.Dblquad 函数和triplequad 函数不允许返回调用的次数,如果需要知道函数调用的次数,则在定义被积函数的m 文件中增加一个计数变量,统计出被积函数被调用的次数.---------------------------------------------------------------------例如:计算二重积分I =∫∫√x 2+y 2dxdy π2−π2π2−π2的值.先编写函数文件fxy.mfunction f=fxy(x,y) global k; k=k+1;f=sqrt(x.^2+y.^2);再调用函数dblquadglobalk; k=0;I=dblquad(@fxy,-pi/2,pi/2,-pi/2,pi/2,1.0e-10) I= 11.8629 k k= 37656---------------------------------------------------------------------例如:求三重积分∫∫∫4xze −z2y−x 2dxdydz ππ1的值.编写函数文件fxyz1.mfunction f=fxyz1(x,y,z) global j; j=j+1;f=4*x.*z.*exp(-z.*z.*y-x.*x);调用triplequad函数editglobalj;j=0;I=triplequad(@fxyz1,0,pi,0,pi,0,1,1.0e-10)I=1.7328jj=1340978---------------------------------------------------------------------Matlab数值微分1.数值微分与差商导数的三种极限定义f′(x)=limn→0f(x+h)−f(x)hf′(x)=limn→0f(x)−f(x−h)hf′(x)=limn→0f(x+h2)−f(x−h2)h上述公式中假设h>0,引进记号:?f(x)=f(x+h)−f(x)?f(x)= f(x)−f(x−h)δf(x)= f(x+h2)−f(x−h2)称上述?f(x)、?f(x)、δf(x)为函数在x点处以h(h>0)为步长的向前差分、向后差分、中心差分,当步长h足够小时,有:f′(x)≈?f(x) hf′(x)≈?f(x) hf′(x)≈δf(x) h?f(x) h 、?f(x)h、δf(x)h也分别被称为函数在x点处以h(h>0)为步长的向前差商、向后差商、中心差商.当h足够小时,函数f(x)在x点处的导数接近于在该点的任意一种差商,微分接近于在该点的任意一种差分.2.函数导数的求法2.1用多项式或样条函数g(x)对函数f(x)进行逼近(插值或拟合),然后用逼近函数g(x)在点x处的导数作为f(x)在该点处的导数.2.2用f(x)在点x处的差商作为其导数.3.数值微分的实现方法Matlab中,只有计算向前差分的函数diff,其调用格式为:·DX=diff(X):计算向量X的向前差分,DX(i)=X(i+1)-X(i),i=1,2,…,n-1·DX=diff(X,n):计算向量X的n阶向前差分,例如diff(X,2)=diff(diff(X))·DX=diff(A,n,dim):计算矩阵A的n阶向前差分,dim=1(默认值)按列计算差分,dim=2按行计算差分. --------------------------------------------------------------------- 例如:生成6阶范德蒙德矩阵,然后分别按行、按列计算二阶向前差分A=vander(1:6)A=111111321684212438127931102425664164131256251252551777612962163661D2A1=diff(A,2,1)D2A1=180501220057011018200132019424200255030230200D2A2=diff(A,2,2)D2A2=000084211083612457614436920004008016540090015025--------------------------------------------------------------------- 例如:设f(x)=√x3+2x2−x+12+√(x+5)56+5x+2求函数f(x)的数值导数,并在同一坐标系中作出f’(x)的图像.已知函数f(x)的导函数如下:f′(x)=3x2+4x−12√x3+2x2−x+12+16√(x+5)56+5编辑函数文件fun7.m和fun8.mfunctionf=fun7(x)f=sqrt(x.^3+2*x.^2-x+12)+(x+5).^(1/6)+5*x+2;functionf=fun8(x)f=(3*x.^2+4*x-1)/2./sqrt(x.^3+2*x.^2-x+12)+1/6./(x+5).^(5/6)+5;x=-3:0.01:3;p=polyfit(x,fun7(x),5);用5次多项式拟合曲线dp=polyder(p);对拟合多项式进行求导dpx=polyval(dp,x);对dp在假设点的求函数值dx=diff(fun7([x,3.01]))/0.01;直接对dx求数值导数gx=fun8(x);求函数f的函数在假设点的导数plot(x,dpx,x,dx,'.',x,gx,'-')可以发现,最后得到的三条曲线基本重合.--------------------------------------------------------------------- 练习:A.用高斯-克朗罗德法求积分∫dx1+x2 +∞−∞的值并讨论计算方法的精确度.(该积分值为π)function f=fun9(x)f=1./(1+x.^2);formatlong[I,err]=quadgk(@fun9,-Inf,Inf)I=err=B.设函数f(x)=sin xx+cos2x用不同的办法求该函数的数值导数,并在同一坐标系中作出f′(x)的图像.已知f′(x)=x cos x+cos x cos2x−sin x+2sin x sin2x(x+cos2x)2function f=fun10(x)f=sin(x)./(x+cos(2*x));function f=fun11(x)f=(x.*cos(x)+cos(x).*cos(2*x)-sin(x)-2*sin(x).*sin(2*x))/(x+cos(2*x)).^2;x=-3:0.01:3;p=polyfit(x,fun10(x),5);dp=polyder(p);dpx=polyval(dp,x);dx=diff(fun10([x,3.01]))/0.01;gx=fun11(x);plot(x,dpx,'r:',x,dx,'.g',x,gx,'-k')[文档可能无法思考全面,请浏览后下载,另外祝您生活愉快,工作顺利,万事如意!]11 / 11。
数值积分算法与MATLAB实现本文从网络收集而来,上传到平台为了帮到更多的人,如果您需要使用本文档,请点击下载按钮下载本文档(有偿下载),另外祝您生活愉快,工作顺利,万事如意!摘要:在求一些函数的定积分时,由于原函数十分复杂难以求出或用初等函数表达,导致积分很难精确求出,只能设法求其近似值,因此能够直接借助牛顿-莱布尼兹公式计算定积分的情形是不多的。
数值积分就是解决此类问题的一种行之有效的方法。
积分的数值计算是数值分析的一个重要分支;因此,探讨近似计算的数值积分方法是有着明显的实际意义的。
本文从数值积分问题的产生出发,详细介绍了一些数值积分的重要方法。
本文较详细地介绍了牛顿-科特斯求积公式,以及为了提高积分计算精度的高精度数值积分公式,即龙贝格求积公式和高斯-勒让德求积公式。
除了研究这些数值积分算法的理论外,本文还将这些数值积分算法在计算机上通过MATLAB软件编程实现,并通过实例用各种求积公式进行运算,分析比较了各种求积公式的计算误差。
【关键词】数值积分牛顿-科特斯求积公式高精度求积公式MATLAB软件前言对于定积分,在求某函数的定积分时,在一定条件下,虽然有牛顿-莱布里茨公式可以计算定积分的值,但在很多情况下的原函数不易求出或非常复杂。
被积函数的原函数很难用初等函数表达出来,例如等;有的函数的原函数存在,但其表达式太复杂,计算量太大,有的甚至无法有解析表达式。
因此能够借助牛顿-莱布尼兹公式计算定积分的情形是不多的。
另外,许多实际问题中的被积函数往往是列表函数或其他形式的非连续函数,对这类函数的定积分,也不能用不定积分方法求解,只能设法求其近似值。
因此,探讨近似计算的数值积分方法是有明显的实际意义的,即有必要研究定积分的数值计算方法,以解决定积分的近似计算。
而数值积分就是解决此类问题的一种有效的方法,它的特点是利用被积函数在一些节点上的信息求出定积分的近似值。
微积分的发明是人类科学史上一项伟大的成就,在科学技术中,积分是经常遇到的一个重要计算环节。
Matlab中常用的积分和微分算法解析积分和微分是数学中重要的概念和工具,广泛应用于科学、工程和计算领域。
在Matlab中,提供了丰富的积分和微分算法,可以方便地进行数值计算和符号计算。
在本文中,我们将解析Matlab中常用的积分和微分算法,并探讨其应用。
一、数值积分算法数值积分是通过将求和转化为积分的方式,对函数在一定区间内的近似计算。
在Matlab中,有许多数值积分算法可供选择,包括梯形法则、辛普森法则和高斯求积法等。
1. 梯形法则梯形法则是一种基本的数值积分算法。
它将区间分成多个小梯形,并将每个小梯形的面积近似表示为梯形的面积,然后将这些面积相加得到最终的近似积分值。
在Matlab中,可以使用trapz函数来实现梯形法则的计算。
例如,对函数f(x)在区间[a, b]上进行积分,可以使用如下代码:```matlaba = 0;b = 1;x = linspace(a, b, 100);y = f(x);integral_value = trapz(x, y);```其中,linspace函数用于生成均匀分布的点,f(x)是待积分的函数。
trapz函数可以自动计算积分值。
2. 辛普森法则辛普森法则是一种更精确的数值积分算法。
它将区间分成多个小三角形,并将每个小三角形的面积近似表示为一个带有二次多项式的面积,然后将这些面积相加得到最终的近似积分值。
在Matlab中,可以使用quad函数来实现辛普森法则的计算。
例如,对函数f(x)在区间[a, b]上进行积分,可以使用如下代码:```matlaba = 0;b = 1;integral_value = quad(@f, a, b);```其中,@f表示函数句柄,quad函数可以自动计算积分值。
3. 高斯求积法高斯求积法是一种更高精度的数值积分算法。
它利用多个节点和权重,通过插值的方式来近似积分值。
在Matlab中,可以使用gaussquad函数来实现高斯求积法的计算。
实验10 数值积分实验目的:1.了解数值积分的基本原理; 2.熟练掌握数值积分的MATLAB 实现; 3.会用数值积分方法解决一些实际问题。
实验内容:积分是数学中的一个基本概念,在实际问题中也有很广泛的应用。
同微分一样,在《微积分》中,它也是通过极限定义的,由于实际问题中遇到的函数一般都以列表形式给出,所以常常不能用来直接进行积分。
此外有些函数虽然有解析式,但其原函数不是初等函数,所以仍然得不到积分的精确值,如不定积分⎰10 d sin x x x。
这时我们一般考虑用数值方法计算其近似值,称为数值积分。
10.1 数值微分简介设函数()y f x =在*x 可导,则其导数为hx f h x f x f h )()(lim )(**0*-+='→ (10.1)如果函数()y f x =以列表形式给出(见表10-1),则其精确值无法求得,但可由下式求得其近似值hx f h x f x f )()()(***-+≈' (10.2)表 10-1一般的,步长h 越小,所得结果越精确。
(10.2)式右端项的分子称为函数()y f x =在*x 的差分,分母称为自变量在*x 的差分,所以右端项又称为差商。
数值微分即用差商近似代替微商。
常用的差商公式为:000()()()2f x h f x h f x h +--'≈(10.3)hy y y x f 243)(2100-+-≈' (10.4)hy y y x f nn n n 234)(12+-≈'-- (10.5)其误差均为2()O h ,称为统称三点公式。
10.2 数值微分的MATLAB 实现MATLAB 提供了一个指令求解一阶向前差分,其使用格式为: dx=diff(x) 其中x 是n 维数组,dx 为1n -维数组[]21321,,,n x x x x x x ---,这样基于两点的数值导数可通过指令diff(x)/h 实现。
东北大学秦皇岛分校数值计算课程设计报告数值积分算法及MATLA实现学院数学与统计学院专业信息与计算科学学号5133201姓名_____________ 陈世_____________指导教师姜玉山张建波成绩教师评语:指导教师签字:2015年07月14日1 绪论数值分析是计算数学的一个主要部分,计算数学是数学科学的一个分支,它研究用计算机求解各种数学问题的数值检索方其理论与软件的实现•而数值分析主要研究数值计算•现科学技术的发展与进步提出了越来越多的复杂的数值计算问题,这些问题的圆满解决已远人工手算所能胜任,必须依靠电子计算机快速准确的数据处理能力•这种用计算机处理数值问题的方法,成为科学计算•今天,科学计算的应用范围非常广泛,天气预报、工程设计、流体计算、经济规划和预测以及国防尖端的一些科研项目,如核武器的研制、导弹和火箭的发射等,始终是科学计算最为活跃的领域•1.1数值积分介绍数值积分是数值分析的重要环节,实际问题当中常常需要计算积分,有些数值方法,如微分方程和积分方程的求解,也都和积分计算相联系求某函数的定积分时,在多数情况下,被积函数的原函数很难用初等函数表达出来,因此能够借助微积分学的牛顿-莱布尼兹公式计算定积分的机会是不多的•另外,许多实际问题中的被积函数往往是列表函数或其他形式的非连续函数,对这类函数的定积分,也不能用不定积分方法求解•由于以上原因,数值积分的理论与方法一直是计算数学研究的基本课题•对微积分学做出杰出贡献的数学大师,如I.牛顿、L.欧拉、C.F.高斯、拉格朗日等人都在数值积分这个领域作出了各自的贡献,并奠定了这个分支的理论基础•构造数值积分公式最通常的方法是用积分区间上的n次插值多项式代替被积函数,由此导出的求积公式称为插值型求积公式•特别在节点分布等距的情形称为牛顿-科特斯公式,例如梯形公式(Trapezoidal Approximations)与抛物线公式(Approximatens Using Parabolas)就是最基本的近似公式•但它们的精度较差•龙贝格算法是在区间逐次分半过程中,对梯形公式的近似值进行加权平均获得准确程度较高的积分近似值的一种方法,它具有公式简练、计算结果准确、使用方便、稳定性好等优点,因此在等距情形宜采用龙贝格求积公式(Rhomberg Integration).当用不等距节点进行计算时,常用高斯型求积公式计算,它在节点数目相同情况下,准确程度较高,稳定性好,而且还可以计算无穷积分•数值积分还是微分方程数值解法的重要依据•许多重要公式都可以用数值积分方程导出•现探讨数值积分算法以及运用MATLAB软件的具体实现1.2 MATLAB 软件MATLAB是美国MathWorks公司出品的商业数学软件,用于算法开发、数据可视化、数据分析以及数值计算的高级技术计算语言和交互式环境,主要包括MATLAB和Simulink两大部分.MATLAB是matrix&laboratory两个词的组合,意为矩阵工厂(矩阵实验室).是由美国mathworks公司发布的主要面对科学计算、可视化以及交互式程序设计的高科技计算环境.它将数值分析、矩阵计算、科学数据可视化以及非线性动态系统的建模和仿真等诸多强大功能集成在一个易于使用的视窗环境中,为科学研究、工程设计以及必须进行有效数值计算的众多科学领域提供了一种全面的解决方案,并在很大程度上摆脱了传统非交互式程序设计语言(如C、Fortran)的编辑模式,代表了当今国际科学计算软件的先进水平•MATLAB和Mathematics Maple并称为三大数学软件.它在数学类科技应用软件中在数值计算方面首屈一指.MATLAB可以进行矩阵运算、绘制函数和数据、实现算法、创建用户界面、连接其他编程语言的程序等,主要应用于工程计算、控制设计、信号处理与通讯、图像处理、信号检测、金融建模设计与分析等领域.MATLAB的基本数据单位是矩阵,它的指令表达式与数学、工程中常用的形式十分相似,故用MATLAB来解算问题要比用C,FORTRAN等语言完成相同的事情简捷得多,并且MATLAB也吸收了像Maple等软件的优点,使MATLAB成为一个强大的数学软件.在新的版本中也加入了对C,FORTRAN, C++,JAVA的支持.2数值积分的基本概念一般的,我们可以在区间la,b 1上适当选取某些节点兀,然后用f X k的加权平均得到平均高度f 的近似值,这样构造出的求积公式具有下列形式:a n八A k f X k ,式中X k称为求积节点;A k称为求积系数,亦称伴随节点X k的k =0b f x dx :权.权A k仅仅与节点X k的选取有关,而不依赖于被积函数 f x的具体形式.2.1代数精度的概念如果某个求积公式对于次数不超过m的多项式均能准确的成立,但对于m T次多项式就不准确成立,则称该求积公式具有m次代数精度(或代数精确值)一般地,欲使求积公式具有m次代数精度,只要令它对于 f x =1,x,|||,x m都能准确成立,这就要求:乞A k =b-a,1 2 2为A k x k=2(b -a)‘++-- - m 1 t. m+1 m+1 ,送A k x k =一 b -a .、一m+12.2求积公式的余项b n令求积公式的余项为R【f】,其中R i f ]二J a f (x)dx-送A k f(x J;区间【a,b】可以是k=0有限的或无限的•构造求积公式的问题就是确定X j和A j使得R〔f 1在某种意义下尽可能地小.3数值积分方法及MATLAB实现3.1复合辛普森公式3.1.1插值型求积公式用插值多项式L n(X)替换积分广=[f(XpX中的被积函数f(X),然后计算bI 「L n XdX作为积分的近似值,这样建立的求积公式称为插值型求积公式•用插值多an n项式L n(x)的表达式L n(X)八I k X f X k,代入得I二^ A k f X k,其中:k=0 k=0A = f (X—X。
如何在Matlab中进行数值积分和数值解在数学和工程领域,数值积分和数值解是常见的技术手段,可以帮助我们求解复杂的数学问题和实际工程中的模型。
本文将介绍如何使用Matlab进行数值积分和数值解,以及一些注意事项和常用的方法。
一、数值积分数值积分是计算定积分的近似值的方法,可以通过数值逼近或数值插值来实现。
在Matlab中,有几种常用的函数可以用于数值积分,比如trapz、quad等。
1. trapz函数trapz函数是用梯形法则计算积分的函数。
它的使用方法是将要积分的函数作为输入的第一个参数,x轴上的点作为输入的第二个参数。
例如,要计算函数f(x)在区间[a, b]上的积分,可以使用以下代码:result = trapz(x, f(x));2. quad函数quad函数是使用自适应数值积分算法计算积分的函数。
它的使用方法是将要积分的函数作为输入的第一个参数,积分区间的下限和上限作为输入的第二个和第三个参数。
例如,要计算函数f(x)在区间[a, b]上的积分,可以使用以下代码:result = quad(@(x) f(x), a, b);二、数值解数值解是使用数值方法求解复杂的数学问题或实际工程中的模型的近似解。
在Matlab中,有几种常用的函数可以用于数值解,比如fsolve、ode45等。
1. fsolve函数fsolve函数是用于求解非线性方程组的函数。
它的使用方法是将非线性方程组表示为一个函数,然后将该函数作为输入的第一个参数。
例如,要求解方程组f(x) = 0,可以使用以下代码:x = fsolve(@(x) f(x), x0);其中x0是方程的初始猜测值。
2. ode45函数ode45函数是求解常微分方程初值问题的函数。
它的使用方法是将微分方程表示为一个函数,然后将该函数作为输入的第一个参数。
例如,要求解常微分方程dy/dx = f(x, y),可以使用以下代码:[t, y] = ode45(@(t, y) f(t, y), tspan, y0);其中tspan是时间区间,y0是初始条件。
MATLAB是一种流行的数学软件,用于解决各种数学问题,包括微分方程的数值积分。
微分方程是许多科学和工程问题的数学描述方式,通过数值积分可以得到微分方程的数值解。
本文将介绍在MATLAB中如何进行微分方程的数值积分,以及一些相关的技巧和注意事项。
一、MATLAB中微分方程的数值积分的基本方法1. 常微分方程的数值积分在MATLAB中,常微分方程的数值积分可以使用ode45函数来实现。
ode45是一种常用的数值积分函数,它使用4阶和5阶Runge-Kutta 方法来求解常微分方程。
用户只需要将微分方程表示为函数的形式,并且提供初值条件,ode45就可以自动进行数值积分,并得到微分方程的数值解。
2. 偏微分方程的数值积分对于偏微分方程的数值积分,在MATLAB中可以使用pdepe函数来实现。
pdepe可以求解具有定解条件的一维和二维偏微分方程,用户只需要提供偏微分方程的形式和边界条件,pdepe就可以进行数值积分,并得到偏微分方程的数值解。
二、在MATLAB中进行微分方程数值积分的注意事项1. 数值积分的精度和稳定性在进行微分方程的数值积分时,需要注意数值积分的精度和稳定性。
如果数值积分的精度不够,可能会导致数值解的误差过大;如果数值积分的稳定性差,可能会导致数值解发散。
在选择数值积分方法时,需要根据具体的微分方程来选择合适的数值积分方法,以保证数值解的精度和稳定性。
2. 初值条件的选择初值条件对微分方程的数值解有很大的影响,因此在进行微分方程的数值积分时,需要选择合适的初值条件。
通常可以通过对微分方程进行分析,或者通过试验求解来确定合适的初值条件。
3. 数值积分的时间步长在进行微分方程的数值积分时,需要选择合适的时间步长,以保证数值积分的稳定性和效率。
选择时间步长时,可以通过试验求解来确定合适的时间步长,以得到最优的数值解。
三、MATLAB中微分方程数值积分的实例以下通过一个简单的例子来演示在MATLAB中如何进行微分方程的数值积分。
用matlab求数值积分的方法
数值积分是一种求解定积分近似值的方法。
在实际应用中,很多复杂函数难以通过解析方法求得定积分,因此需要借助数值积分方法来求解。
Matlab作为一种高效的数值计算软件,提供了多种数值积分方法,包括梯形法、辛普森法、高斯积分法等。
下面分别介绍这些方法的具体实现。
梯形法:将积分区间等分成若干个小区间,每个小区间内的积分近似用其两端点的函数值的平均值。
最终将所有小区间的积分结果相加即为整个积分的近似值。
辛普森法:同样将积分区间等分成若干个小区间,每三个小区间内的积分近似用一个二次函数来拟合。
最终将所有小区间的积分结果相加即为整个积分的近似值。
高斯积分法:通过将积分区间变换为[-1,1]区间上的积分,利用预先计算好的高斯积分点和权重,将原函数在[-1,1]区间上积分近似为高斯点的函数值和权重之积的加权和。
以上就是Matlab中求解数值积分的三种常用方法。
不同方法在精度和计算速度上也有所差别,具体使用时可以根据实际需求进行选择。
- 1 -。
毕业设计(论文)设计(论文)题目:数值积分算法与MATLAB实现摘要在求一些函数的定积分时,由于原函数十分复杂难以求出或用初等函数表达,导致积分很难精确求出,只能设法求其近似值,因此能够直接借助牛顿-莱布尼兹公式计算定积分的情形是不多的。
数值积分就是解决此类问题的一种行之有效的方法。
积分的数值计算是数值分析的一个重要分支;因此,探讨近似计算的数值积分方法是有着明显的实际意义的。
本文从数值积分问题的产生出发,详细介绍了一些数值积分的重要方法。
本文较详细地介绍了牛顿-科特斯求积公式,以及为了提高积分计算精度的高精度数值积分公式,即龙贝格求积公式和高斯-勒让德求积公式。
除了研究这些数值积分算法的理论外,本文还将这些数值积分算法在计算机上通过MATLAB软件编程实现,并通过实例用各种求积公式进行运算,分析比较了各种求积公式的计算误差。
【关键词】数值积分牛顿-科特斯求积公式高精度求积公式MATLAB软件ABSTRACTWhen the solution of the definite integral of some function values,because the original function is very complex and difficult to find the elementary function expression, the integral is difficult to accurately calculate, only managed to find the approximate value, and the case is small that allows to direct interface with the Newton - Leibniz formula to calculate the definite integral. Numerical integration is an effective method to solve such problems. The numerical integration is an important branch of numerical analysis; therefore, exploring the approximate calculation of the numerical integration method has obvious practical significance. This article departure from the numerical integration problem, described in detail some important numerical integration methods.This paper has introduced detail the Newton - Coates quadrature formula, and in order to improve the calculation accuracy of numerical integration formulas, More precise formulas have Romberg quadrature formulas and the Gauss - Legendre quadrature formula. In addition to the study of these numerical integration algorithm theory, the article also involve what these numerical integration algorithm be programmed by matlab software on the computer, and an example is calculated with a variety of quadrature formulas, finally analysis and comparison to various quadrature formulas calculation error.【Key words】Numerical integration Newton-Cotes quadratureformula High-precisionquadrature formula Matlab software目录前言 ..................................................................第一章牛顿-科特斯求积公式..............................................第一节数值求积公式的构造...........................................第二节复化求积公式.................................................第三节本章小结.....................................................第二章高精度数值积分算法...............................................第一节梯形法的递推.................................................第二节龙贝格求积公式...............................................第三节高斯求积公式.................................................第四节高斯-勒让德求积公式..........................................第五节复化两点高斯-勒让德求积公式 ..................................第六节本章小结.....................................................第三章各种求积公式的MATLAB编程实现与应用 ...........................第一节几个低次牛顿-科特斯求积公式的MATLAB实现...................第二节复化求积公式的MATLAB实现..................................第三节龙贝格求积公式的MATLAB实现................................第三节高斯-勒让德求积公式的MATLAB实现...........................第五节各种求积算法的分析比较 .......................................第六节本章小结.....................................................结论 ..................................................................致谢 ..................................................................参考文献 ................................................................附录 ..................................................................一、英文原文......................................................二、英文翻译......................................................前言对于定积分,在求某函数的定积分时,在一定条件下,虽然有牛顿-莱布里茨公式可以计算定积分的值,但在很多情况下的原函数不易求出或非常复杂。
matlab 变上限积分二重积分数值积分概述1. 引言1.1 概述在科学计算与数据分析领域,积分是一项非常重要的数学运算方法。
而在实际应用中,经常会遇到需要计算上限变化的积分,即上限取决于某个参数的变化。
此外,二重积分和数值积分也是常见且广泛应用的数值计算方法。
本文将介绍在Matlab环境中如何进行变上限积分、二重积分以及数值积分的概念和方法。
通过对这些方法的了解和掌握,读者将能够更加灵活和高效地解决实际问题。
1.2 文章结构本文内容共分为五个部分。
首先,引言部分对全文进行概述,并介绍了文章的结构;其次,第二部分将详细介绍在Matlab中如何进行变上限积分,并提供两种不同的方法;第三部分将阐述二重积分的基本概念、性质以及其在Matlab中的计算方法;随后,在第四部分中将探讨数值积分的基本原理,并介绍两种常用的数值积分方法;最后,在结论部分对全文内容进行总结回顾,并展望未来研究方向。
1.3 目的本文的主要目的是帮助读者更好地理解Matlab中变上限积分、二重积分和数值积分等概念,并通过介绍不同的计算方法,引导读者能够在实际问题中灵活运用这些方法。
通过阅读本文,读者将能够掌握Matlab中相应函数的使用,以便于进行科学计算和数据分析工作。
同时,本文也旨在为进一步研究和扩展这些数值计算方法提供参考基础。
2. Matlab中的变上限积分:2.1 概述:变上限积分是指在数学求积分时,积分上界是变量的情况。
在Matlab中,有特定的函数可以用于计算变上限积分。
这些函数能够灵活地处理不同类型的变量和不同形式的被积函数。
本节将介绍Matlab中可用于计算变上限积分的方法。
2.2 变上限积分方法一:在Matlab中,可以使用符号运算工具箱来进行符号计算并解析地求解变上限积分。
首先,需要定义一个符号表达式作为被积函数,并将其表示为一个符号对象。
然后,通过调用相关的符号运算函数(如diff和int)来操作该符号对象,从而得到所需的结果。
一.数值积分的实现方法1.变步长辛普生法基于变步长辛普生法,MA TLAB给出了quad函数来求定积分。
该函数的调用格式为:[I,n]=quad('fname',a,b,tol,trace)其中fname是被积函数名。
a和b分别是定积分的下限和上限。
tol用来控制积分精度,缺省时取tol=0.001。
trace控制是否展现积分过程,若取非0则展现积分过程,取0则不展现,缺省时取trace=0。
返回参数I即定积分值,n为被积函数的调用次数。
例8-1 求定积分。
(1) 建立被积函数文件fesin.m。
function f=fesin(x)f=exp(-0.5*x).*sin(x+pi/6);(2) 调用数值积分函数quad求定积分。
[S,n]=quad('fesin',0,3*pi)S = 0.9008n = 772.牛顿-柯特斯法基于牛顿-柯特斯法,MA TLAB给出了quad8函数来求定积分。
该函数的调用格式为:[I,n]=quad8('fname',a,b,tol,trace)其中参数的含义和quad函数相似,只是tol的缺省值取10-6。
•该函数可以更精确地求出定积分的值,且一般情况下函数调用的步数明显小于quad函数,从而保证能以更高的效率求出所需的定积分值。
(1) 被积函数文件fx.m。
function f=fx(x)f=x.*sin(x)./(1+cos(x).*cos(x));(2) 调用函数quad8求定积分。
I=quad8('fx',0,pi)I = 2.4674分别用quad函数和quad8函数求定积分的近似值,并在相同的积分精度下,比较函数的调用次数。
调用函数quad求定积分:format long;fx=inline('exp(-x)');[I,n]=quad(fx,1,2.5,1e-10)I = 0.28579444254766n = 65调用函数quad8求定积分:format long;fx=inline('exp(-x)');[I,n]=quad8(fx,1,2.5,1e-10)I = 0.28579444254754n = 333.被积函数由一个表格定义在MATLAB中,对由表格形式定义的函数关系的求定积分问题用trapz(X,Y)函数。
具体参数的意义我这里不详细说明,大家可以看帮助系统,我们这里只是讨论各大函数的区别比较和注意一、Z = trapz(X,Y,dim)梯形数值积分,通过已知参数x,y按dim维使用梯形公式进行积分例1 计算int(sin(x),0,pi)%by dynamic%all rights reserved by [url][/url]>>x=0:pi/100:2*pi;>>y=sin(x);>>z=trapz(x,y)%或者说使用z = pi/100*trapz(y)z =1.0300e-017>>z = pi/100*trapz(y)二、[q,fcnt]= quad(fun,a,b,tol,trace,p1,p2...)自适应simpson公式数值积分,适用于精度要求低,被积函数平滑性较差的数值积分注意事项:1.被积函数fun必须是函数句柄2.积分限[a,b]必须是有限的,因此不能为inf3.p1为其他需要传递的参数,一般是数值可能警告:1.'Minimum step size reached'意味着子区间的长度与计算机舍入误差相当,无法继续计算了。
原因可能是有不可积的奇点2.'Maximum function count exceeded'意味着积分递归计算超过了10000次。
原因可能是有不可积的奇点3.'Infinite or Not-a-Number function value encountered'意味着在积分计算时,区间内出现了浮点数溢出或者被零除。
例2 计算积分1/(x^3-2*x-p),其中参数p=5,积分区间为[0,2]%by dynamic%all rights reserved by [url][/url]>>F = @(x,n)1./(x.^3-2*x-n);>>Q = quad(@(x)F(x,5),0,2)%或者使用quad(F,0,2,[],[],5)效果是一样的,只是前者使用的函数嵌套Q =-0.4605>>quad(F,0,2,[],[],5)ans =-0.4605三、[q,fcnt] = quadl(fun,a,b,tol,trace,p1,p2...)自适应Lobatto数值积分,适用于精度要求高,被积函数曲线比较平滑的数值积分注意事项:同quad可能警告:同quad例3 计算积分1/(x^3-2*x-p),其中参数p=5,积分区间为[0,2]%by dynamic%all rights reserved by [url][/url]>>F=@(x,p)1./(x.^3-2*x-p);>>Q = quadl(F,0,2,[],[],5)%或者Q = quadl(@(x)F(x,5),0,2)Q =-0.4605四、[q,errbnd] = quadgk(fun,a,b,param1,val1,param2,val2,...)自适应Gauss-Kronrod数值积分,适用于高精度和震荡数值积分,支持无穷区间,并且能够处理端点包含奇点的情况,同时还支持沿着不连续函数积分,复数域线性路径的围道积分法注意事项:1.积分限[a,b]可以是[-inf,inf],但必须快速衰减2.被积函数在端点可以有奇点,如果区间内部有奇点,将以奇点区间划分成多个,也就是说奇点只能出现在端点上3.被积函数可以剧烈震荡4.可以计算不连续积分,此时需要用到'Waypoints'参数,'Waypoints'中的点必须严格单调5.可以计算围道积分,此时需要用到'Waypoints'参数,并且为复数,各点之间使用直线连接6.param,val为函数的其它控制参数,比如上面的'waypoints'就是,具体看帮助出现错误:1.'Reached the limit on the maximum number of intervals in use'2.'Infinite or Not-a-Number function value encountered'例4 计算有奇点积分int(exp(x)*log(x),0,1)%by dynamic%all rights reserved by [url][/url]>>F=@(x)exp(x).*log(x);%奇点必须在端点上,否则请先进行区间划分>>Q = quadgk(F,0,1)Q =-1.3179例5 计算半无限震荡积分int(x^5*exp(-x)*sin(x),0,inf)%by dynamic%all rights reserved by [url][/url]>>F=@(x)x.^5.*exp(-x).*sin(x);>>fplot(F,[0,100])%绘图,看看函数的图形>>[q,errbnd] = quadgk(F,0,inf,'RelTol',1e-8,'AbsTol',1e-12)%积分限中可以有inf,但必须快速收敛q =-15.0000errbnd =9.4386e-009例6 计算不连续积分,积分函数为f(x)=x^5*exp(-x)*sin(x),但是人为定义f(2)=1000,f(5)=-100,积分区间为[1 10]%by dynamic%all rights reserved by [url][/url]>>F=@(x)x.^5.*exp(-x).*sin(x);>>[q,errbnd] = quadgk(F,1,10,'Waypoints',[2 5])%显然2,5为间断点q =-10.9408errbnd =3.2296e-014例7 计算围道积分,在复数域内,积分函数1/(2*z-1),积分路径为由[-1-i 1-i 1+i -1+i -1-i]围成的矩形边框%by dynamic%all rights reserved by [url][/url]>>Waypoints=[-1-i 1-i 1+i -1+i -1-i];>>plot(Waypoints);%绘制积分路径>>xlabel('Real axis');ylabel('Image axis');axis([-1.5 1.5 -1.5 1.5]);grid on;>>Q = quadgk(@(z)1./(2*z - 1),-1-i,-1-i,'Waypoints',[1-i,1+i,-1+i])%注意各点间使用直线连接ans =0.0000 + 3.1416i>> quadgk(@(z)1./(2*z - 1),-1-i,-1-i,'Waypoints',Waypoints)%使用这个的效果也是一样的,就是说始末点可以随便包不包含在Waypoints中ans =0.0000 + 3.1416i五、[Q,fcnt] = quadv(fun,a,b,tol,trace)矢量化自适应simpson数值积分注意事项:1.该函将quad函数矢量化了,就是一次可以计算多个积分2.所有的要求完全与quad相同例8 计算下面积分,分别计算n=1,2...,5时的5个积分值,被积函数1/(n+x),积分限为[0,1]%by dynamic%all rights reserved by [url][/url]>>for k = 1:5, Qs(k) = quadv(@(x)1/(k+x),0,1);end;QsQs =0.6931 0.4055 0.2877 0.2231 0.1823>>F=@(x,n)1./((1:n)+x);%定义被积函数>>quadv(@(x)F(x,5),0,1)%我们可以完全使用quadv函数替换上面循环语句的,建议使用后者ans =0.6931 0.4055 0.2877 0.2231 0.1823六、q = dblquad(fun,xmin,xmax,ymin,ymax,tol,method)矩形区域二重数值积分,一般区域二重积分参见NIT(数值积分工具箱)的quad2dggen函数例9 计算下面二重积分%by dynamic%all rights reserved by [url][/url]>>F = @(x,y)y*sin(x)+x*cos(y);>Q = dblquad(F,pi,2*pi,0,pi)Q =-9.8696七、q=triplequad(fun,xmin,xmax,ymin,ymax,zmin,zmax,tol,method)长方体区域三重数值积分,注意此时没有一般区域的三重积分例10 计算下面三重积分%by dynamic%all rights reserved by [url][/url]>>F = @(x,y,z)y*sin(x)+z*cos(x);>>Q = triplequad(F,0,pi,0,1,-1,1)Q =2.0000八、超维长方体区域多重积分quadndg:NIT工具箱函数,可以解决多重超维长方体边界的定积分问题,但没有现成的一般积分区域求解函数下面总结下:(1)quad:采用自适应变步长simpson方法,速度和精度都是最差的,建议不要使用(2)quad8:使用8阶Newton-Cotes算法,精度和速度均优于quad,但在目前版本下已被取消(3)quadl:采用lobbato算法,精度和速度均较好,建议全部使用该函数(4)quadg:NIT(数值积分)工具箱函数,效率最高,但该工具箱需要另外下载(5)quadv:quad的矢量化函数,可以同时计算多个积分(6)quadgk:很有用的函数,功能在Matlab中最强大(7)quad2dggen:一般区域二重积分,效率很好,需要NIT支持(8)dblquad:长方形区域二重积分(9)triplequadL:长方体区域三重积分(10)quadndg:超维长方体区域积分,需要NIT支持。
数值积分用matlab实现编辑整理:尊敬的读者朋友们:这里是精品文档编辑中心,本文档内容是由我和我的同事精心编辑整理后发布的,发布之前我们对文中内容进行仔细校对,但是难免会有疏漏的地方,但是任然希望(数值积分用matlab实现)的内容能够给您的工作和学习带来便利。
同时也真诚的希望收到您的建议和反馈,这将是我们进步的源泉,前进的动力。
本文可编辑可修改,如果觉得对您有帮助请收藏以便随时查阅,最后祝您生活愉快业绩进步,以下为数值积分用matlab实现的全部内容。
东北大学秦皇岛分校数值计算课程设计报告数值积分及Matlab实现学院数学与统计学院专业信息与计算科学学号5133117姓名楚文玉指导教师张建波姜玉山成绩教师评语:指导教师签字:2015年07月14日1 绪论在科研计算中,经常会碰到一些很难用公式定理直接求出精确解的积分问题,对于这类问题,我们一般转化为数值积分问题,用计算机来实现求解问题. 1.1 课题的背景对于定积分()ba f x dx ⎰在求某函数的定积分时,在一定条件下,虽然有牛顿—莱布里茨公式()()()ba I f x dx Fb F a ==-⎰可以计算定积分的值,但在很多情况下的原函数()f x 不易求出或非常复杂.被积函数的原函数很难用初等函数表达出来,例如2sin (),x x f x e x-=等;有的函数()f x 的原函数()F x 存在,但其表达式太复杂,计算量太大,有的甚至无法有解析表达式.因此能够借助牛顿-莱布尼兹公式计算定积分的情形是不多的.另外,许多实际问题中的被积函数()f x 往往是列表函数或其他形式的非连续函数,对这类函数的定积分,也不能用不定积分方法求解,只能设法求其近似值.因此,探讨近似计算的数值积分方法是有明显的实际意义的,即有必要研究定积分的数值计算方法,以解决定积分的近似计算.而数值积分就是解决此类问题的一种有效的方法,它的特点是利用被积函数在一些节点上的信息求出定积分的近似值.微积分的发明是人类科学史上一项伟大的成就,在科学技术中,积分是经常遇到的一个重要计算环节数值积分是数学上重要的课题之一,是数值分析中重要的内容之一.随着计算机的出现,近几十年来,对于数值积分问题的研究已经成为一个很活跃的研究领域.现在,数值积分在计算机图形学,积分方程,工程计算,金融数学等应用科学领域都有着相当重要的应用,所以研究数值积分问题有着很重要的意义.国内外众多学者在数值积分应用领域也提出了许多新方法.在很多实际应用中,只能知道积分函数在某些特定点的取值,比如天气测量中的气温、湿度、气压等,医学测量中的血压、浓度等等.通过这个课题的研究,我们将会更好地掌握运用数值积分算法求出特殊积分函数的定积分的一些基本方法、理论基础;并且通过Matlab 软件编程的实现,应用于实际生活中. 1.2 课题的主要内容框架1。
编号:审定成绩:重庆邮电大学毕业设计(论文)设计(论文)题目:数值积分算法与MATLAB实现学院名称:数理学院学生姓名:专业:数学与应用数学班级:学号:指导教师:答辩组负责人:填表时间:年月重庆邮电大学教务处制摘要在求一些函数的定积分时,由于原函数十分复杂难以求出或用初等函数表达,导致积分很难精确求出,只能设法求其近似值,因此能够直接借助牛顿-莱布尼兹公式计算定积分的情形是不多的。
数值积分就是解决此类问题的一种行之有效的方法。
积分的数值计算是数值分析的一个重要分支;因此,探讨近似计算的数值积分方法是有着明显的实际意义的。
本文从数值积分问题的产生出发,详细介绍了一些数值积分的重要方法。
本文较详细地介绍了牛顿-科特斯求积公式,以及为了提高积分计算精度的高精度数值积分公式,即龙贝格求积公式和高斯-勒让德求积公式。
除了研究这些数值积分算法的理论外,本文还将这些数值积分算法在计算机上通过MATLAB软件编程实现,并通过实例用各种求积公式进行运算,分析比较了各种求积公式的计算误差。
【关键词】数值积分牛顿-科特斯求积公式高精度求积公式MATLAB软件ABSTRACTWhen the solution of the definite integral of some function values,because the original function is very complex and difficult to find the elementary function expression, the integral is difficult to accurately calculate, only managed to find the approximate value, and the case is small that allows to direct interface with the Newton - Leibniz formula to calculate the definite integral. Numerical integration is an effective method to solve such problems. The numerical integration is an important branch of numerical analysis; therefore, exploring the approximate calculation of the numerical integration method has obvious practical significance. This article departure from the numerical integration problem, described in detail some important numerical integration methods.This paper has introduced detail the Newton - Coates quadrature formula, and in order to improve the calculation accuracy of numerical integration formulas, More precise formulas have Romberg quadrature formulas and the Gauss - Legendre quadrature formula. In addition to the study of these numerical integration algorithm theory, the article also involve what these numerical integration algorithm be programmed by matlab software on the computer, and an example is calculated with a variety of quadrature formulas, finally analysis and comparison to various quadrature formulas calculation error.【Key words】Numerical integration Newton-Cotes quadrature formula High-precision quadrature formula Matlab software目录前言 (1)第一章牛顿-科特斯求积公式 (2)第一节数值求积公式的构造 (2)第二节复化求积公式 (9)第三节本章小结 (12)第二章高精度数值积分算法 (13)第一节梯形法的递推 (13)第二节龙贝格求积公式 (14)第三节高斯求积公式 (17)第四节高斯-勒让德求积公式 (19)第五节复化两点高斯-勒让德求积公式 (22)第六节本章小结 (23)第三章各种求积公式的MATLAB编程实现与应用 (24)第一节几个低次牛顿-科特斯求积公式的MATLAB实现 (24)第二节复化求积公式的MATLAB实现 (28)第三节龙贝格求积公式的MATLAB实现 (33)第三节高斯-勒让德求积公式的MATLAB实现 (34)第五节各种求积算法的分析比较 (36)第六节本章小结 (38)结论 (39)致谢 (40)参考文献 (41)附录 (43)一、英文原文 (43)二、英文翻译 (52)前 言对于定积分()ba f x dx ⎰,在求某函数的定积分时,在一定条件下,虽然有牛顿-莱布里茨公式()()()baI f x dx F b F a ==-⎰可以计算定积分的值,但在很多情况下()f x 的原函数不易求出或非常复杂。
被积函数()f x 的原函数很难用初等函数表达出来,例如2sin (),x x f x e x-=等;有的函数()f x 的原函数()F x 存在,但其表达式太复杂,计算量太大,有的甚至无法有解析表达式。
因此能够借助牛顿-莱布尼兹公式计算定积分的情形是不多的。
另外,许多实际问题中的被积函数往往是列表函数或其他形式的非连续函数,对这类函数的定积分,也不能用不定积分方法求解,只能设法求其近似值。
因此,探讨近似计算的数值积分方法是有明显的实际意义的,即有必要研究定积分的数值计算方法,以解决定积分的近似计算。
而数值积分就是解决此类问题的一种有效的方法,它的特点是利用被积函数()f x 在一些节点上的信息求出定积分的近似值。
微积分的发明是人类科学史上一项伟大的成就,在科学技术中,积分是经常遇到的一个重要计算环节。
数值积分是数学上重要的课题之一,是数值分析中重要的内容之一,也是应用数学研究的重点。
随着计算机的出现,近几十年来,对于数值积分问题的研究已经成为一个很活跃的研究领域。
现在,数值积分在计算机图形学,积分方程,工程计算,金融数学等应用科学领域都有着相当重要的应用,所以研究数值积分问题有着很重要的意义。
国内外众多学者在数值积分应用领域也提出了许多新方法。
在很多实际应用中,只能知道积分函数在某些特定点的取值,比如天气测量中的气温、湿度、气压等,医学测量中的血压、浓度等等。
通过这个课题的研究,我们将会更好地掌握运用数值积分算法求特殊积分函数的定积分的一些基本方法、理论基础;并且通过matlab 软件编程的实现,应用于实际生活中。
第一章 牛顿-科特斯求积公式第一节 数值求积公式的构造大多数实际问题的积分是需要用数值积分方法求出近似结果的。
数值积分原则上可以用于计算各种被积函数的定积分,无论被积函数是解析解形式还是数表形式,其基本原理都是用多项式函数近似代替被积函数,用多项式的积分结果近似代替对被积函数的积分。
由于所选多项式形式的不同,可以有许多种数值积分方法。
而利用插值多项式来构造数值求积公式是最常用的一种方法。
对于积分()ba f x dx ⎰,用一个容易积分的函数()x ϕ去代替被积函数()f x ,这样的()x ϕ自然以多项式()n L x 为最佳,因为多项式能很好的逼近任何连续函数,而且容易求出其原函数。
一、 求积公式的推导在积分区间[,]a b 上取有限个点01n a x x x b ≤<<<≤,作()f x 的n 次插值多项式0()()()nn k k L x f x l x =∑,其中,()(0,1,,)k l x k n =为n 次插值基函数。
用()n L x 近似代替被积函数()f x ,则得()()()()nbb bn k k aaak f x dx L x dx f x l x dx =≈=∑⎰⎰⎰ (1.1)若记011011()()()()()()()()()bbk k n k k aak k k k k k n x x x x x x x x A l x dx dx x x x x x x x x -+-+----==----⎰⎰(1.2)则得数值求积公式()()nbk k ak f x dx A f x =≈∑⎰(1.3)其中k A 称为求积系数,k x 称为求积节点。
则称该求积公式为插值型求积公式。
知道了插值型求积公式以及其构造方法。
为了便于计算与应用,常将积分区间的等分点作为求积节点,这样构造出来的插值型求积公式就称为牛顿-科特斯(Newton-Cotes )求积公式。
在积分区间[,]a b 上取1n +个等距节点k x a k h =+(0,1,)k n =,其中b ah n-=,做n 次拉格朗日插值多项式()n L x ,因为()()()n n f x L x R x =+,所以 ()()()bbbn n aaaf x dx L x dx R x dx =+⎰⎰⎰(1)101()()()()(1)!nb b n k k n a a k f x l x dx f x dx n ξω++=⎡⎤=+⎢⎥⎣⎦+∑⎰⎰ 记11()()()()b bn k k aak n k x A l x dx dx x x x ωω++==-⎰⎰(1.4)[](1)11()()(1)!b n n n a R f f x dx n ξω++=+⎰ (1.5) 截去第二项得()()nbk k ak f x dx A f x =≈∑⎰显然k A 与()f x 无关,只与节点(0,1,,)k x k n =有关。
令x a th =+,则当[],x a b ∈时,[]0,t n ∈,于是111()()(1)(2)()n n n x a th h t t t t n ωω+++=+=--- (1.6)而 10111()()()()()()n k k k k k k k k n x x x x x x x x x x x ω+-+=-----!(1)()!n n k h k n k -=--从而得[][]0(1)(1)(1)(1)()!()!n k nk h A t t t k t k t n dt k n k --=---⨯-+--⎰记[][]()0(1)(1)(1)(1)()!()!n kn n kCt t t k t k t n dtk n k n--=---⨯-+--⎰(1.7)则 ()()n kk A b a C =-故求积公式(1.3)可写成()0()()()nbn k k ak f x dx b a C f x =≈-∑⎰(1.8)这就是牛顿-科特斯求积公式,其中()n k C 称为科特斯系数。