function of a variable obtained from integrating a two variable function

1 次查看(过去 30 天)
I have a function that depends on two variables, say x and y; f(x,y). I want to integrate with respect to x only and get a new function that depends only on y; i.e., g(y) = @(y) integral(@(y)f(x,y),lim1,lim2), where lim1 and lim2 are the limits for for x. I want to use g(y) later to carry out other operations. I cannot find a way around this problem.

采纳的回答

Matt J
Matt J 2014-9-16
编辑:Matt J 2014-9-16
I think you've answered your own question. Why can't you create an anonymous function for g() just as you did in your post
g = @(y) integral(@(x)f(x,y),lim1,lim2)
and carry that around for reuse?
  1 个评论
Mike Hosea
Mike Hosea 2014-9-16
You can make it more general (work with array inputs) like so
g = @(y1)arrayfun(@(y)integral(@(x)f(x,y),lim1,lim2),y1);
For example:
f = @(x,y)exp(-hypot(x,y));
lim1 = -inf;
lim2 = inf;
g = @(y1)arrayfun(@(y)integral(@(x)f(x,y),lim1,lim2),y1);
y = linspace(-10,10);
plot(y,g(y));

请先登录,再进行评论。

更多回答(1 个)

Mauricio
Mauricio 2014-9-16
编辑:Matt J 2014-9-16
Well you are right but I did not expressed myself correctly. The problem is the following: In the code below I have the function "Base(z)" which depends on "z", which I need to integrate with respect to z. This function "Base" depends in turn on another function called RR which I have to integrate with respect to one variable a to obtain "fun", the output of "Base(z)". Unfortunately, I keep on getting the error message you see below. Note: I can evaluate "Base(z)" for any z, but I cannot integrate "Base(z)" with respect to z. Thanks for your help
function out = Princip
clc;
function fun=Base(z)
RR = @(a,b)(z.*3.^a)./(b+1);
fun = integral(@(a)RR(a,5),0,10);
end
out = integral(@Base,1,10);
end
Error Message:
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 Princip (line 18)
out = integral(@Base,1,10);
  2 个评论
Matt J
Matt J 2014-9-16
Set the 'ArrayValued' option to true, as the error message instructs (in all your calls to integral()).
Mike Hosea
Mike Hosea 2014-9-16
Or make the Base function satisfy the requirements of INTEGRAL without the ArrayValued flag, i.e. to accept an array input and return an array of the same size.
function fun=Base(z)
fun = zeros(size(z));
for k = 1:numel(fun)
RR = @(a,b)(z(k).*3.^a)./(b+1);
fun(k) = integral(@(a)RR(a,5),0,10);
end
end

请先登录,再进行评论。

类别

Help CenterFile Exchange 中查找有关 MATLAB 的更多信息

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by