How to calculate integral along the boundary of closed curve?
    5 visualizzazioni (ultimi 30 giorni)
  
       Mostra commenti meno recenti
    
    Romuald Kuras
 il 3 Set 2018
  
    
    
    
    
    Commentato: Romuald Kuras
 il 3 Set 2018
            
Hi!
I would like to calculate the area under the curve (in direction to Z axis - see the attachment file), which is formed of discrete values on the edge of a closed curve. I have an idea, but it is a quite arduous method (using 'trapz' function), does anyone have any other suggestions?
Thanks in advance!
4 Commenti
  Torsten
      
      
 il 3 Set 2018
				Take the sum of
sqrt((x(i+1)-x(i))^2+(y(i+1)-y(i))^2)*(z(i)+z(i+1))/2
Best wishes
Torsten.
Risposta accettata
  Dimitris Kalogiros
      
 il 3 Set 2018
        
      Modificato: Dimitris Kalogiros
      
 il 3 Set 2018
  
      Provided than (x,y) points are very dense you can approximate the area you ask, good enough:
clear; clc;
% generation of input data
t=0:0.01:2*pi-0.01;
x=4*cos(t); 
y=2*sin(t);
z=sqrt(abs(x))+y.^2+exp(0.6*x);
stem3(x,y,z,'-b'); hold on;
plot3(x,y,0*z,'-k.'); hold on;
plot3(x,y,z,'r*');
xlabel('x'); ylabel('y'); zlabel('z');
% calculation of area (approximately)
A=0;
for n=1:length(x)-1
    A= A+ sqrt( (x(n+1)-x(n))^2 + (y(n+1)-y(n))^2 ) * (z(n)+z(n+1))/2 ;
end
fprintf('Area is %f \n', A)
If you run this script, you will receive something like this:

Più risposte (0)
Vedere anche
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


