How to calculate integral along the boundary of closed curve?

조회 수: 3 (최근 30일)
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
Torsten
Torsten 2018년 9월 3일
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.
Romuald Kuras
Romuald Kuras 2018년 9월 3일
Thanks a lot! I never dreamed that I would get the answer so quickly :)

댓글을 달려면 로그인하십시오.

채택된 답변

Dimitris Kalogiros
Dimitris Kalogiros 2018년 9월 3일
편집: Dimitris Kalogiros 2018년 9월 3일
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:
  댓글 수: 1
Romuald Kuras
Romuald Kuras 2018년 9월 3일
Thank you so much! I did not expect that I would get the answer so quickly and that someone will create a similar function for the clarity of the problem. Thanks a lot! :)

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Numerical Integration and Differentiation에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by