2个回答
展开全部
计算无穷限积分的函数,用Matlab实现。
1、函数quadFromInf用于计算从负无穷大到一个确定值a的积分
%name:quadFromInf.m
function Isum = quadFromInf(fun,a,dx0,tol,method)
if nargin < 2 ,a=0 ;end
if nargin < 3 ,dx0=0.5 ;end
if nargin < 4 ,tol = 5e-4 ;end
if nargin < 5 ,method = 1 ;end
j=0;dx = dx0;Isum = 0;x2 = a; maxint = 35;
%fprintf('\n j dx x2 I_j Isum\n');
while j<maxint
x1 = x2 - dx;
switch method
case 1, I = quad(fun,x1,x2);
case 2, I = quadl(fun,x1,x2);
otherwise, error(sprintf('method = %d not allowed',method));
end
Isum = Isum + I;
%fprintf('%4d %8.1f %8.1f %12.8f %12.8f\n',j,dx,x2,I,Isum);
if j>5 & abs(I/Isum) < tol,break; end
j = j+1;x2 = x1;dx = 2*dx;
end
2、函数quadToInf用于计算从一个确定值a到正无穷大的积分。
%name:quadToInf.m
function Isum = quadToInf(fun,a,dx0,tol,method)
if nargin < 2 ,a=0 ;end
if nargin < 3 ,dx0=0.5 ;end
if nargin < 4 ,tol = 5e-4 ;end
if nargin < 5 ,method = 1 ;end
j=0;dx
Isum = Isum + I;
%fprintf('%4d %8.1f %8.1f %12.8f %12.8f\n',j,dx,x2,I,Isum);
if j>5 & abs(I/Isum) < tol,break; end
j = j+1;x1 = x2;dx = 2*dx;
1、函数quadFromInf用于计算从负无穷大到一个确定值a的积分
%name:quadFromInf.m
function Isum = quadFromInf(fun,a,dx0,tol,method)
if nargin < 2 ,a=0 ;end
if nargin < 3 ,dx0=0.5 ;end
if nargin < 4 ,tol = 5e-4 ;end
if nargin < 5 ,method = 1 ;end
j=0;dx = dx0;Isum = 0;x2 = a; maxint = 35;
%fprintf('\n j dx x2 I_j Isum\n');
while j<maxint
x1 = x2 - dx;
switch method
case 1, I = quad(fun,x1,x2);
case 2, I = quadl(fun,x1,x2);
otherwise, error(sprintf('method = %d not allowed',method));
end
Isum = Isum + I;
%fprintf('%4d %8.1f %8.1f %12.8f %12.8f\n',j,dx,x2,I,Isum);
if j>5 & abs(I/Isum) < tol,break; end
j = j+1;x2 = x1;dx = 2*dx;
end
2、函数quadToInf用于计算从一个确定值a到正无穷大的积分。
%name:quadToInf.m
function Isum = quadToInf(fun,a,dx0,tol,method)
if nargin < 2 ,a=0 ;end
if nargin < 3 ,dx0=0.5 ;end
if nargin < 4 ,tol = 5e-4 ;end
if nargin < 5 ,method = 1 ;end
j=0;dx
Isum = Isum + I;
%fprintf('%4d %8.1f %8.1f %12.8f %12.8f\n',j,dx,x2,I,Isum);
if j>5 & abs(I/Isum) < tol,break; end
j = j+1;x1 = x2;dx = 2*dx;
展开全部
直接求不定积分即可。试一下int函数能否求解
简写为exp(-k1*x)*exp(-k2*(t-x))*k3^(x/Tin)*k4^((t-x)/Tin)
简写为exp(-k1*x)*exp(-k2*(t-x))*k3^(x/Tin)*k4^((t-x)/Tin)
更多追问追答
追答
syms k1 k2 k3 k4 Tin t x
int(exp(-k1*x)*exp(-k2*(t-x))*k3^(x/Tin)*k4^((t-x)/Tin))
ans =
-Tin/(log(k4)+k1*Tin-log(k3)-k2*Tin)*exp(-k1*x)*exp(-k2*(t-x))*exp(x/Tin*log(k3))*exp((t-x)/Tin*log(k4))
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询