Area under curve of data points (no function) with x and y boundary

4 views (last 30 days)
Hello, how can I compute the area under a curve (see green area) of data points with a x and a y boundary? The x boundary = 70 and y=0.05. I tried trapz but I don't know how to use this with an x and an y boundary. The curve is made up of data points imported from excel:
x= xlsread(datafile, 'x-axis', 'B5:MI5');
y=xmid = xlsread(datafile, 'y-axis', 'B5:MI5');
area = trapz(x,y) %this gives the whole area under the red curve, but I only want the green area
I hope someone can help me, thanks!

Accepted Answer

Ameer Hamza
Ameer Hamza on 18 Oct 2020
Edited: Ameer Hamza on 18 Oct 2020
Something like this
mask = x > 70;
xv = x(mask);
yv = y(mask);
trapz(xv, yv-0.05); % if all the points are above x-axis then just subtracting 0.05 is enough.
  4 Comments
Noa Hoogeweg
Noa Hoogeweg on 20 Oct 2020
I modified it a bit, and I think this works better in general:
mask = x >= 70;
xv = x(mask);
yv = y(mask);
trapz(xv(yv>=0.05), yv(yv>=0.05));
Correct me if I'm wrong :)
Ameer Hamza
Ameer Hamza on 20 Oct 2020
Yes, If you only want to integrate when y is above 0.05 then it is correct.

Sign in to comment.

More Answers (0)

Categories

Find more on Just for fun in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!