Effacer les filtres
Effacer les filtres

How to calculate partial area under a graph?

1 vue (au cours des 30 derniers jours)
friet
friet le 29 Nov 2016
Commenté : Star Strider le 10 Mai 2017
Hello,
I am trying to find the area as a part of a graph( Red area in the picture below). I am asking here a simplified question of my complext problem. The area is definitely 0.5. However, when I am using "trapz" function, It is giving me 4.5.
x=[0 1 2 3 4 5 10 15 20];
y=[0 -1 -2 -3 -4 -5 0 5 0];
plot(x,y)
area=trapz(4:5)
Thanks, Frite
  2 commentaires
KSSV
KSSV le 29 Nov 2016
Modifié(e) : Walter Roberson le 30 Nov 2016
friet
friet le 29 Nov 2016
Modifié(e) : John Kelly le 12 Déc 2016
I ask another simplified version of the previous question.

Connectez-vous pour commenter.

Réponse acceptée

Star Strider
Star Strider le 29 Nov 2016
You are not coding the integration correctly to integrate the area you want.
Explore this and experiment with it:
x=[0 1 2 3 4 5 10 15 20];
y=[0 -1 -2 -3 -4 -5 0 5 0];
yi = interp1(x, y, [4:5]);
shaded_area = trapz([4:5],yi+5)
plot(x,y)
hold on
patch([4 5 5 4], [yi -5 -5], 'r')
hold off
shaded_area =
500.0000e-003
  2 commentaires
Namira
Namira le 10 Mai 2017
I was looking your code. Why did you add 5 with yi in line 4? I can't understand it. Sorry I am not good at Matlab coding.
Star Strider
Star Strider le 10 Mai 2017
I added 5 because the area to be integrated goes from -5 to the line. The trapz function would otherwise integrate from 0 to the line. The offset ‘resets’ the 0 reference to -5.

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Numerical Integration and Differentiation dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by