Sum of both negative - positive part of a Peak

3 次查看(过去 30 天)
Dear ALL,
I have a peak that I woud like to take the integral of it, however, this peak has a positive (> 0 baseline) and negative part (< 0 beaseline).
So, is it any function in MATLAB that automatically sums both parts?
Please see attached the example...peak.png

采纳的回答

Star Strider
Star Strider 2019-11-25
Try this:
x = linspace(6.622, 9.644);
y = exp(-(x-mean(x)).^2/0.5) - 0.1;
Lv = y>=0;
PosPart = trapz(x(Lv), y(Lv))
NegPart = trapz(x(~Lv), y(~Lv))
SumParts = PosPart - NegPart
figure
plot(x, y)
Experiment to get different results.
  2 个评论
abaza
abaza 2019-11-25
Thank you so much for your quick response!
I will try to implement what you suggested in my "real work data", and I will come back to you for "accepting you answer"!
Cheers!
Star Strider
Star Strider 2019-11-25
编辑:Star Strider 2019-11-25
My pleasure!
EDIT — (25 Nov 2019 at 22:10)
Depending on what you want to do, this may be more accurate:
Lv = y>=0;
PosPart = trapz(x(Lv), y(Lv))
LT0 = trapz(x(~Lv), ones(size(x(~Lv)))*min(y))
NegPart = LT0 - trapz(x(~Lv), y(~Lv))
SumParts = PosPart - NegPart

请先登录,再进行评论。

更多回答(1 个)

Image Analyst
Image Analyst 2019-11-25
What if you sum the absolute value of the signal?
area = sum(abs(signal));
That will be the difference between the signal and the y axis.

Community Treasure Hunt

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

Start Hunting!

Translated by