【问题标题】:Integral within exponential within integral积分内指数内积分
【发布时间】: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


    【解决方案1】:

    问题1是你定义的

    myfuncirc = @(s,p,t) ...
    

    但是当它被调用时,它被称为

    myfuncirc(s,t,p)
    

    参数的顺序不同。您应该将 myfuncirc 的定义更改为

    myfuncirc = @(s, t, p) ...
    

    第二个更难判断,因为您发布的内容没有给出您打印的结果,它会出错 - 有几个值未定义,例如 myfun 和 k。但是,我 认为 问题在于 pmax 没有被定义为函数句柄,而是作为一个值 - 在分配 pmax 时 y 中的任何内容。我怀疑你想要

    pmax = @(x,y) y;
    

    【讨论】:

      猜你喜欢
      • 2015-01-23
      • 1970-01-01
      • 2012-03-01
      • 1970-01-01
      • 1970-01-01
      • 2015-07-23
      • 1970-01-01
      • 2022-10-05
      • 1970-01-01
      相关资源
      最近更新 更多