Integrating piecewise function

4 ビュー (過去 30 日間)
Susan
Susan 2011 年 5 月 25 日
I'm following up on this q&a:
I typed in the following code and I don't understand the result:
syms a x y p
p=2;
fint = int(heaviside(y-a)*(y-a)^p,y,a,x)
subs(fint,{a,x},{sym(0),sym(-3)})
fint =
-(a - x)^3/3
ans =
-9
I guess I'm being dense here, but it seems that the heaviside function has had no effect. Shouldn't answers for x<a be zero? Why isn't fint a piecewise function?
Thanks,
Susan
  1 件のコメント
Andrew Newell
Andrew Newell 2011 年 5 月 26 日
I have corrected the original answer.

サインインしてコメントする。

回答 (3 件)

Walter Roberson
Walter Roberson 2011 年 5 月 25 日
It would be easier to read (and might even solve the problem) if you were to explicitly specify the variable of integration in the int() call instead of just specifying the bounds and having it try to deduce the variable.
  3 件のコメント
Susan
Susan 2011 年 5 月 25 日
Interestingly, the following change gets me the right answer (though it's not as general as the original case):
p=2;
fint = int(heaviside(y-a)*(y-a)^p,y,0,x)
subs(fint,{a,x},{sym(0),sym(-3)})
fint =
(a^3*heaviside(-a))/3 - (heaviside(x - a)*(a - x)^3)/3
ans =
0
So there is some problem with simultaneously using a in the heaviside argument and as a limit of integration. The original result still seems wrong to me though.
Walter Roberson
Walter Roberson 2011 年 5 月 25 日
Just to check: are you using the Maple based symbolic toolbox (older versions) or the MuPad based one (newer versions) ?
When I try this out in Maple directly, the answer I get after substitution is
limit(-Heaviside(y)*y^(p+1)/(p+1)+3^(p+1)/(p+1), y = 0, right)
which simplifies to
-(limit(Heaviside(y)*y^(p+1)-3^(p+1), y = 0, right))/(p+1)
The piecewise() equivalent of this is (in Maple notation)
piecewise(y < 0, 3^(p+1)/(p+1), y = 0, -(limit(-3^(p+1)+y^(p+1)*undefined, y = 0, right))/(p+1), 0 < y, -(limit(-3^(p+1)+y^(p+1), y = 0, right))/(p+1))
Maple's "undefined" is pretty much equivalent to NaN -- that is, Heaviside is not defined when its argument is 0.

サインインしてコメントする。


Susan
Susan 2011 年 5 月 25 日
So it looks to me that, if I'm careful, I can get the right answer:
%%what does fint(x) look like for fixed a?
% define a separate lower limit of integration
syms a x y p x0
p=2; % power
a=1; % function is zero-valued below a
x0=0;% start integrating here
fint = int(heaviside(y-a)*(y-a)^p,y,x0,x)
% ezplot(fint) % doesn't work for piecewise syms?
xx = linspace(-3,6,100);
yy = subs(fint,x,xx);
plot(xx,yy);
% great, exactly what I think is right
fint =
piecewise([x < 1, 0], [1 <= x, (heaviside(x - 1)*(x - 1)^3)/3])
But for some lower limits of integration, the need for a piecewise solution is missed entirely:
%%what if x0 ==2?
x0=2;% start integrating here
fint = int(heaviside(y-a)*(y-a)^p,y,x0,x)
% ezplot(fint) % doesn't work for piecewise syms?
xx = linspace(-3,6,100);
yy = subs(fint,x,xx);
plot(xx,yy);
% eww. Wrong answer!
fint =
((x - 2)*(x^2 - x + 1))/3
  2 件のコメント
Walter Roberson
Walter Roberson 2011 年 5 月 25 日
If you mentally add the assumption that x >= x0, then when you use an x0 that is greater than your a, then x < a is going to be false so you fall over to just the heaviside portion.
Susan
Susan 2011 年 6 月 2 日
So this assumption is obvious? I guess the lesson is that mupad will make assumptions and the user needs to be wary of them.

サインインしてコメントする。


Christopher Creutzig
Christopher Creutzig 2011 年 5 月 30 日
When integrating from a to x, int makes the implicit assumption that a ≤ y ≤ x and thus a ≤ x, unless that is obviously wrong, in which case the interval borders are swapped. This is a side-effect of restricting the variable of integration to the interval given.
  1 件のコメント
Susan
Susan 2011 年 6 月 2 日
Same comment as above to Walter: I guess the lesson is that mupad will make assumptions and the user needs to be wary of them.

サインインしてコメントする。

カテゴリ

Help Center および File ExchangeNumeric Solvers についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by