首页 > 编程知识 正文

matlab表示多项式微分积分(matlab多重数值积分,Matlab数值积分和微分(一重、多重都有),简单实用。)

时间:2023-05-06 06:55:54 阅读:121323 作者:4301

第八章MATLAB数值积分与微分

8.1数值积分

8.2数值微分

8.1数值积分

8.1.1数值积分的基本原理

求定积分的方法多种多样,如简单的梯形法、传统的篮球(Simpson )法、TMD QC (Newton-cotes )法等是常用的方法。 这些基本思想都是将整个积分区间[a,b]分为n个子区间[xi,xi 1],I=1,2,…,n。 这里,x1=a,xn 1=b。 这样求定积分问题就分解为求和问题。

8.1.2数值积分的实现方法

1 .循序渐进的传统篮球法

基于变步长的传统篮球法,MATLAB给出四叉函数求定积分。 函数的调用格式如下:

[I,n ]=四个(' fname ',a,b,tol,trace ) )。

这里,fname是被积函数名。 a和b分别是定积分的下限和上限。 tol用于控制积分精度,缺省情况下tol=0.001。 trace控制是否表示积分过程,取0以外表示积分过程,取0则不表示,默认取trace=0。 返回参数I即定积分值,n是被积函数的调用次数。

例8-1求定积分。

(1)建立被积函数文件fesin.m。

函数f=FeS in (x )

f=exp(-0.5*x ).*sin ) xpi/6 );

)2)调用数值积分函数quad求定积分。

([S,n ]=四进制(FeS in ),0,3 * pi () ) ) ) ) ) ) 652

S=0.9008

n=77

2.tmdqc法

基于tmdqc方法,MATLAB给出quad8函数求定积分。 函数的调用格式如下:

([I,n]=quad8(fname )、a、b、tol、trace ) ) ) ) ) ) )。

其中参数的含义与四元函数类似,但tol的默认值为10-6。 该函数可以更准确地求出定积分的值,而且一般函数调用的步数明显小于quad函数,保证了以更高的效率求出所需的定积分值。

例8-2求定积分。

(1)被积函数文件fx.m。

函数f=FX (x )

f=x.*sin(x ).1cos ) x ).*cos(x ) x );

)2)调用函数quad8求定积分。

I=quad8(FX ),0,pi ) ) ) ) ) ) )。

I=2.4674

例8-3分别用quad函数和quad8函数求定积分的近似值,用相同积分精度比较函数的调用次数。

调用函数quad求定积分:

格式长;

FX=inline('exp )-x );

[I,n ]=四边形(FX,1,2.5,1e-10 ) ) ) ) ) )。

I=0.28579444254766

n=65

调用函数quad8求定积分:

格式长;

FX=inline('exp )-x );

[I,n]=quad8(FX,1,2.5,1e-10 ) ) ) )。

I=0.28579444254754

n=33

3 .被积函数由一个表定义

在MATLAB中,对于用表形式定义的函数关系的求积分问题,使用trapz(x,y )函数。 这里,向量x、y定义函数关系y=f(x )。

例8-4用trapz函数计算定积分。

命令如下:

X=1:0.01:2.5;

y=exp(-x; %函数生成关系数据向量

陷阱(x,y ) )。

ans=0.28579682416393

8.1.3双定积分的数值求解

使用MATLAB提供的dblquad函数,可以直接求出上述双重定积分的数值解。 函数的调用格式如下:

I=DBLquad(f、a、b、c、d、tol、trace ) )。

该函数求出f(x,y )在[a,b][c,d]区域的双重定积分。 参数tol,trace的使用方法与函数quad完全相同。

例8-5双重定积分的计算

(1)创建函数文件fxy.m :

功能f=fxy (x,y ) ) )。

全球钥匙;

ki=ki 1; %ki用于计数被积函数的调用次数

f=exp(-x.^2/2).*sin ) x.^2y );

)2)调用dblquad函数进行求解。

全球钥匙; ki=0;

I=DBLquad('fxy '、- 2、2、- 1、1 ) ) ) )。

ki

I=1.57449318974494

ki=1038

8.2数值微分

8.2.1数值差分和差分商

8.2.2数值微分的实现

MATLAB没有直接提供计算数值导数的函数,只有计算前向差分的函数diff,其调用格式如下:

dx=diff(x ) :计算向量x的前向差分,dx(I ) dx(I )dx(I ),I=1,2,…,n-1。

dx=diff(x,n ) :计算x的n阶前向差分。 例如,diff(X(x,2 )=diff (diff ) ) x )。

dx=diff(a,n,dim ) :计算矩阵a的n阶差分(dim=1时) (默认状态),按列计算差分; dim=2,逐行计算差分。

例8-6生成基于向量v=[1、2、3、4、5、6]的范数矩阵,对每列进行差分运算。

命令如下:

v=vander(1:6 ) )

计算dv=diff(v ) %v的一次差分

例8-7用不同的方法求出函数f(x )的数值导数,在同一坐标系中制作f ) )的图像。

步骤如下。

f=inline(sqrt ) x.^32*x.^2-x12 ) x 5 ).^ )1/6)5*x 2 ' );

g=inline (()3*x.^24*x-1 )./sqrt ) x.^32*x.^2-x12 )/2 )1/6./(X5 ) ) ^(5/6) )

x=-3:0.01:3;

p=polyfit(x,f ) x ),5 ); 用%5次多项式p拟合f(x )

DP=polyder(p; 对%拟合多项式p求导数dp

dpx=polyval(DP,x ); 求出%DP的假说点下的函数值

dx=diff(f ) [x,3.01] )/0.01; %直接对f(x )求数值导数

GX=g(x; %求函数f的导数g在拟定点的导数

plot(x,dpx,x,dx,'.',x,gx,'-'; %绘图

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。