【发布时间】:2016-06-09 08:51:04
【问题描述】:
我正在尝试对几个不同的表达式进行数值积分,但它们都有一个指数内的积分,被另一个积分包围,即
我似乎无法使用以下代码解决此问题:
syms s p t
W = 3.18*10^(-22);
b = 10^(-23);
X = 300;
L = 0.374;
intlim = 0.589;
myfuncirc = @(s,p,t) (-W).*sqrt((L.^2)-(s.^2)).*(((-p.*cos(t))+sqrt(1-((p.^2).*((sin(t)).^2)))-sqrt(L.^2-s.^2)).^(-2));
s_min = 0;
s_max = L;
t_min = 0;
t_max = pi;
integral(@(p)(p.*exp(-(integral2(@(s,t) myfuncirc(s,t,p),s_min,s_max,t_min,t_max))/(b.*X))),0,intlim,'Arrayvalued',true)
我收到如下所示的错误消息,但我希望得到一个介于 0 和 1 之间的数字:
警告:遇到无限或非数字值。 在 funfun\private\integralCalc>iterateArrayValued 在 267 在 funfun\private\integralCalc>vadapt 在 130 在 funfun\private\integralCalc 中 75 积分为 88
我也在尝试以下形式的类似集成,但也没有得到预期的答案:
pmax = y;
pmin = 0;
ymax = 1;
ymin = @(x) x;
xmax = 1;
xmin = 0;
integral3(@(x,y,p) (exp(-(integral(@(s)myfun(s,p),0,lam,'ArrayValued',true)./(k.*T)))),xmin,xmax,ymin,ymax,pmin,pmax,'Method','iterated')
警告:遇到无限或非数字值。 > 在 funfun\private\integralCalc>iterateScalarValued at 349 在 funfun\private\integralCalc>vadapt 在 132 在 funfun\private\integralCalc 在 75 在 funfun\private\integral2Calc>@(xi,y1i,y2i)integralCalc(@(y) fun(xiones(size(y)),y),y1i,y2i,opstruct.integralOptions) at 17 在 funfun\private\integral2Calc>@(x)arrayfun(@(xi,y1i,y2i)integralCalc( @(y)fun(xiones(size(y)),y),y1i,y2i,opstruct.integralOptions),x,ymin(x),ymax(x)) 在 17 在 funfun\private\积分Calc>iterateScalarValued at 314 在 funfun\private\integralCalc>vadapt 在 132 在 funfun\private\integralCalc 在 75 在 funfun\private\integral2Calc>integral2i 在 20 在 funfun\private\integral2Calc 在 7 在积分3>innerintegral 在 137 在 funfun\ private\integralCalc>iterateScalarValued at 314 在 funfun\private\integralCalc>vadapt 在 132 在 funfun\private\integralCalc 在 75 在 integral3 在 121 警告:集成不成功。 > 在 125 处积分 3
【问题讨论】:
标签: matlab numerical-integration