如何用matlab对这个函数进行积分。

作者&投稿:潭旺 (若有异议请与网页底部的电邮联系)
如何用matlab求积分~

在生活或研究中可能会遇到需要积分运算的情况,比如计算一个不规则图形的面积等等。matlab有很强的数据处理能力,只要给出任意可积的函数和积分上下线,用它可以进行积分运算。具体操作如下:

工具/原料


matlab软件
方法/步骤


以f(x)=e^2x+sin(x+π/3) ,积分下限:a=0,积分上限:b=π/4 为例。

首先,建立被积函数M文件。
点击New,选择Function.

在编辑器中输入指令:
function f=f(x)
f=exp(2*x).*sin(x+pi/3);
(注意,用 .* )

保存函数文件到自己的工作路径,比如G:\matlab\work。
输入指令:
cd G:\matlab\work
是该路径成为当前路径。

matlab中计算积分的两种指令:
1.
F=quad('fname',a,b,tol,trace) Simpson数值积分法
2.
F=quad8('fname',a,b,tol,trace) Newton-Cotes数值积分法
其中:
fname是被积函数表达式或函数名,a,b分别是上下限,tol可以控制积分精度,省略则取0.001;trace=1则用图形表示积分过程,trace=0,没有图形。
两者 比较,quad8精度更高。

调用积分函数squad进行计算。输入指令:
F=quad('f(x)',0,pi/4)
如图,回车后可得到计算结果1.8612。
其他函数,只要修改函数文件中的表达式即可。

1、双击matlab软件图标,打开matlab软件,如下图所示。

2、使用syms命令,创建七个符号变量a、b、c、d、x、y、z,如下图所示。

3、这里进行一个较为复杂的积分举例,使用符号变量a、b、x、y、z,创建多元函数A,其中A=32*a+b^5+sin(7*z)+x*y,如下图所示。

4、使用函数int(A,'a'),求解多元函数A关于变量a的积分,得出答案,如下图所示。

5、使用函数int(A,'b'),求解多元函数A关于变量b的积分,得出答案,如下图所示。

6、使用函数int(A,'z'),求解多元函数A关于变量z的积分,得出答案,如下图所示。

7、使用函数int(A,'x'),求解多元函数A关于变量x的积分,得出答案,如下图所示。



MATLAB中求积分的解析解只有int(f,v,a,b),f是被积函数,v是被积变量,a,b是积分区间对于一些简单的函数来说使用int()函数是很精确的,而且可以进行定积分和不定积分,但是对于复杂的被积函数来说这么做的执行时间是非常长的,很多时候不是很适合用(因此在实际操作时积分经常采用求近似积分,
常采用以下三种方法
1,是使用sum()函数,根据积分的定义来求积分
2,是使用trapz()函数,采用梯形法求积分
3,使用filter(B,A,X)函数,在设置参数时filter([0,1],[1,-1],X)
eg.求∫ sinx dx(积分区间是0-π/2)的值(各种方法的比较)
○1,d=pi/10;t=0:d:pi/2;y=sin(t);sum(y)*d
得ans=1.1488
○2,d=pi/10;t=0:d:pi/2;y=sin(t);trapz(y)*d
得ans=0.9918
○3 ,int('sin(x)',0,pi/2)
得ans=1
4,syms x;int(‘sin(x)’,x)
得ans =-cos(x)
5 ,d=pi/10;t=0:d:pi/2;y=sin(t);t=filter([0,1],[1,-1],y); t(end)*d
得ans = 0.8347
比较:(1)从精确度而言int()函数最好,但是执行所需时间最大
(2)sum方法和trapz,以及filter方法相比:相同的取值间隔d,trapz方法的精确度要高,而且执行时间非常短;sum法和filter法的精确度相同
(3)filter函数求积分的好处在于,它所得到的结果是一个序列,每个序列都是其前面的积分,在做例如GMSK,MSK的累积相位时可以用filter函数。
所以你这题没办法求解析解,只能根据具体的其他参数的值用以上几种数值求积分的方法来求了,以为我不知道你的其他参数的取值,所以你可以自己做的,有什么不明白的可以找我。

我可以很肯定的告诉你,你的这个积分是无法求出解析解的,你只能是通过数值积分来求解了,这样的话你需要首先得到里面的所有参数的值。
然后你可以使用quad进行积分。

使用quad进行积分


如何用matlab实现对一个dat文件中的数据进行分组?
1、使用load命令,加载dat数据文件,即 A=load('123.dat')2、分别将A中的数据,赋值给(x,y),即 x=A(:,1)y=A(:,2)3、使用for循环语句,显示每组坐标,即 for i=1:length(x)disp(['x=',num2str(x(i)),' y=',num2str(y(i))]);end 4、也可以使用plot函数,绘制(x,y)的...

基于matlab使用聚类和ANFIS对郊区通勤的车辆和人数进行建模
使用MATLAB的聚类和ANFIS技术建模郊区通勤车辆和人数本实例展示了如何运用减法聚类和自适应神经模糊推理系统(ANFIS)来分析从特拉华州纽卡斯尔县获取的交通数据,研究汽车行程数与区域人口特征之间的关系。数据集包含人口、住宅单元数、车辆拥有量、家庭收入中位数和就业人数作为输入,以及汽车行程数作为输出。首先...

MATLAB中怎么对矩阵进行乘除?
这涉及到矩阵的操作。比如A=[3 6 9],B =[1 2 3]要实现对应的元素相除,用这个命令“A.\/B”,即点除。点除就实现了你要的功能。扩展:MATLAB是基于矩阵操作的,对元素的操作都要用到“.”,比如两个矩阵对应元素相乘,即为“A.*B”,相当地方便。在本例中,A.*B=[3 12 27]。如下操...

如何用Matlab编程对一组数据进行对数正态分布拟合
1,把数据直接导入matlab,x=[];y=[](大量数据建议使用txtread),然后点击屏幕左下方start进入toolboxes然后点Curve Fiting Tool ,导入数据 选择Gaussian次数为1,即可得到拟合效果 参数也会出来

用matlab 对一组数据进行拟合后,怎么直接显示拟合函数的图像?_百度...
我利用的是Matlab中的应用程序,Curve fitting,首先将数据导入到工作区中,接下来在菜单栏中的应用程序中找到Curve fitting,点击进去,会弹出一个Curve fitting Tool的页面,在页面的左上方会有选择,x\/y\/z等数据,选择好数据之后,接下来要右边会选择拟合的数学模型,选好之后,正下方会有散点图和...

用matlab如何对空缺数据进行绘图
本视频展示如何用matlab绘制散圆状态图,可用于相关科研数据绘图!

如何使用Matlab,对一组数据进行FFT变换,得到频谱分析,万分感谢。_百度...
Fs=256; %采样频率(Hz)N=256; %采样点数 t=[0:1\/Fs:N\/Fs]; %采样时刻 S=2+3*cos(2*pi*10*t+pi*30\/180)+cos(2*pi*20*t+pi*90\/180);我的调试信号,你自己是电流电压数据的话,最开始通过load指令载入就是 Y = fft(S,N); %做FFT变换 Ayy = abs(Y); %取模 Ayy=Ayy\/...

如何用 matlab对8psk仿真。我这里有qpsk的
EbNo=-5:1:10;%信噪比 for n=1:length(EbNo)for m=1:5 x=round(rand(3000,1));%产生二进制随机数 snr(n)=EbNo(n)+10*log10(k);%Ratio of symbol energy to noise power spectral density xsym=bi2de(reshape(x,k,length(x)\/k).','left-msb');%二进制变为十进制 y=modulate(...

怎么用matlab语言对一个由几个正弦信号组成的信号进行频谱分析_百度...
用fft()函数即可。因为你没提具体的应用要求,所以我把matlab关于fft的例子贴给你,以供参考。Fs = 1000; % Sampling frequency T = 1\/Fs; % Sample time L = 1000; % Length of signal t = (0:L-1)*T; % Time vector Sum of a 50 Hz sinusoid and a 120 Hz sinusoid...

如何使用Matlab,对一组数据进行FFT变换,求得基波分量?十分感谢!_百度知...
x = load('data.dat'); %load 数据 fs=10000; % 采样频率,自己根据实际情况设置 N=length(x); % x 是待分析的数据 n=1:N;1-FFT X=fft(x); % FFT X=X(1:N\/2);Xabs=abs(X);Xabs(1) = 0; %直流分量置0 for i= 1 : m [Amax,index]=max(Xabs);if(Xabs(index-1)...

绛县15553572628: matlab中怎么求函数的积分 -
董福卡马: 用 quad 命令: 具体用法如下:1 2y = @(x)(sin(x)); quad(y,0,pi)

绛县15553572628: 用matlab拟合工具箱拟合函数后,如何求这个函数的积分? -
董福卡马: 复制拟合结果(拟合函数及系数),写成完整的表达式,然后用int()函数计算积分.函数使用格式 int('f(x)') 求不定积分 int('f(x)',a,b) 求定积分

绛县15553572628: 如何用matlab求该函数的积分 -
董福卡马: >> a=1,b=2,c=3;>> syms x>> y=a/x.^5/(exp(b/(c.*x))-1) y =1/(x^5*(exp(2/(3*x)) - 1))>> result=int(y,0,1) Warning: Explicit integral could not be found. result = int(1/(x^5*(exp(2/(3*x)) - 1)), x = 0..1)此函数有错不能进行符号积分>> f=@(x)a./x.^5/(exp(b./(c*x))-1) f =@(x)a./x.^5/(exp(b./(c*x))-1)>> result=quadl(f,0,1)

绛县15553572628: 如何利用matlab进行一次线性函数积分 比如对y=3x+1在x等于2到5上积分,求详细代码及讲解 -
董福卡马: fun = @(x) 3*x+1 ; % 定义函数 I = quad(fun, 2, 5) % 2~5积分

绛县15553572628: matlab中怎样对二元函数中的一个变量做数值积分? -
董福卡马: clear all clc syms va rho tau f=@(va,rho,tau) (2.5-0.1*(va+rho*sin(tau)))./(exp(2.5-0.1*(va+rho*sin(tau)))-1); n = 5000;%当想要结果更精确时,可以把n设置更大 tau = linspace(0,2*pi,n);%自编的简单方法 Tn =@(va,rho) pi/n*(sum(f(va,rho,tau(1:end-...

绛县15553572628: 帮助用matlab求一个函数的积分,谢谢
董福卡马: 求积分函数用 (不定积分) int('filename'); 或(定积分) int(y(x),x,a,b) , 一般的函数积分都可以

绛县15553572628: 我想在matlab中求这个函数的积分 -
董福卡马: 按下列形式更改,就可以了 func=inline('(sqrt(1-(sin(0)*(-0.24049)+0.97065*cos(0).*cos(x)).^2)./(sin(0)*(-0.24049)+0.97065*cos(0).*cos(x))).^2/2','x') %自定义积分函数 f=quad(func,0.549778714,0.811578102) %计算积分 计算结果 f = 0.103125670059353

绛县15553572628: 用matlab 怎么算这种函数的积分? -
董福卡马: y=[1,2,3]; L=@(x)x+1; f=@(x,y) x+y+L(x); Q=integral(@(x)f(x,y),0,1,'ArrayValued',true)

绛县15553572628: matlab已知函数表达式,如何对函数进行积分、取反等运算? -
董福卡马: 求积分用 F = int(f); 求反函数用 ff = finverse(F); P.S.要具有单调性才有反函数

绛县15553572628: Matlab里面怎么求一个分段函数的积分 -
董福卡马: 图像可分段画,如下语句:x0=-1:0.01:0;y0=zeros(size(x0));x1=0:0.01:1;y1=x1;x2=1:0.01:2;y2=-ones(size(x2));x3=2:0.01:3;y3=zeros(size(x3));plot(x0,y0,x1,y1,x2,y2,x3,y3) 积分可分段积分,如下 f=0+int(x,0,1)-1*2+0

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网