使用匿名函数进行多维集成时出错

时间:2017-03-01 15:53:27

标签: matlab integration anonymous-function

我正在尝试使用以下算法执行多维集成:

y= @(a,b,c) a+b+c; %function - 3 dim
y1=@(a,b) integral(@(c) y(a,b,c),-20,20); % L,H - limits for  c`
y2=@(a) integral(@(b) y1(a,b),-20,20); % L,H - limits for b
y3=integral(@(a) y2(a),-20,20); % L,H - limits for a

但是这会出现以下错误:

Error using integralCalc/finalInputChecks (line 515)
Output of the function must be the same size as the input. 
If FUN is an array-valued integrand, set the 'ArrayValued' option to true.

Error in integralCalc/iterateScalarValued (line 315)
                finalInputChecks(x,fx);

Error in integralCalc/vadapt (line 132)
            [q,errbnd] = iterateScalarValued(u,tinterval,pathlen);

Error in integralCalc (line 75)
        [q,errbnd] = vadapt(@AtoBInvTransform,interval);

Error in integral (line 88)
Q = integralCalc(fun,a,b,opstruct);

Error in @(a)integral(@(b)y1(a,b),-20,20)


Error in integralCalc/iterateScalarValued (line 314)
                fx = FUN(t);

Error in integralCalc/vadapt (line 132)
            [q,errbnd] = iterateScalarValued(u,tinterval,pathlen);

Error in integralCalc (line 75)
        [q,errbnd] = vadapt(@AtoBInvTransform,interval);

Error in integral (line 88)
Q = integralCalc(fun,a,b,opstruct);

有人可以帮助我理解并解决我的错误,或建议更好的方法吗?

P.S。
我知道integral3函数,但我需要这个方法,因为我稍后会尝试4,5,6 ....维度。

2 个答案:

答案 0 :(得分:1)

我不确定这是否适用于任何可能的情况,但它适用于这个简单的情况。只需使用符号数学。

syms a b c
y=a+b+c;
y1=int(y,c,-20,20)
y2=int(y1,b,-20,20)
y3=int(y2,a,-20,20)

但是,小心创建变量。不要动态创建yn

答案 1 :(得分:1)

要了解为什么您收到此错误,请使用"常规"重写您的代码。功能:

function q42536274
  y3(-20,20);
end

function out = y(a,b,c)
  out = a + b + c;
  % The result of the above is some [1x150 double] vector. No problem here.
end

function out = y1(a,b,L,H)
  out = integral(@(c)y(a,b,c),L,H);
  % The result of the above is the scalar [-1.421085471520200e-14]. Problem!
end

function out = y2(a,L,H)
  out = integral(@(b)y1(a,b,L,H),L,H);
end

function out = y3(L,H)
  out = integral(@(a)y2(a,L,H),L,H);
end

这是错误发生时工作区的样子:

Workspace when the error appears

现在我们可以看到MATLAB抱怨的内容:fxx中的元素数量不同! MATLAB如何在这种情况下进行数值积分? 0 - 订单近似值?这是不明确的。

我们需要告诉MATLAB如何摆脱这种混乱局面。我们可以做到的一种方式是:

function out = y1(a,b,L,H)
  out = ones(size(a))*integral(@(c)y(a,b,c),L,H);
  % Now the result of the above is also a [1x150 double] vector. Yey!
end

function out = y2(a,L,H)
  out = ones(size(a))*integral(@(b)y1(a,b,L,H),L,H);
  % Same as above...
end

因此我们得到的输出-2.2737e-11非常接近"正确回答0