フィルターのクリア

PERIMETER OF A 3D POLYGON WHICH DOES NOT LIE IN THE X-Y PLANE

2 ビュー (過去 30 日間)
Francesca Danielli
Francesca Danielli 2022 年 7 月 5 日
編集済み: Torsten 2022 年 7 月 5 日
Hi everyone,
I have the spatial coordinates (x,y,z) of a cloud of points.
To date, I am able to calculate the area of the polygon in space obtained interpolating these points. Any suggestions abou how to calculate the perimeter?
Thank you in advance
  6 件のコメント
Francesca Danielli
Francesca Danielli 2022 年 7 月 5 日
yes
I used this function
h=fnplt(cscvn(p(:,[1:end 1])),'g',2)
where p is a 3x10 array (number of row 3 for spatial coordinates x,y,z and coloumn 10 for the available points)
It returns h, a 3xN array (with N number of additionally points for a better interpolation)
Bjorn Gustavsson
Bjorn Gustavsson 2022 年 7 月 5 日
@Torsten: In 3-D it isn't obvious that a cloud of points are flat. There would still be a "natural" area from the convex hull, but I wasn't sure there would be a unique perimeter. But now I see that the points seem to lie in a plane - or near enough.

サインインしてコメントする。

採用された回答

Torsten
Torsten 2022 年 7 月 5 日
The code should apply to your case:
x = 3*cos(0:pi/20:2*pi);
y = 3*sin(0:pi/20:2*pi);
fn = cscvn([x;y]);
% Compute enclosed area
fnprime = fnder(fn);
Kofs = @(s) [1 -1]*(fnval(fn,s) .* flipud(fnval(fnprime,s)));
A = 1/2*integral(Kofs,fn.breaks(1),fn.breaks(end))
A = 28.2726
pi*3^2
ans = 28.2743
% Compute curve length
Lfun = @(s) sqrt(sum(fnval(fnprime,s).^2,1));
L = integral(Lfun,fn.breaks(1),fn.breaks(end))
L = 18.8491
2*pi*3
ans = 18.8496
  2 件のコメント
Francesca Danielli
Francesca Danielli 2022 年 7 月 5 日
I tried and it works for the perimeter! I compared the obtained results with an expected one from raw analytical calculations!
I am currently having problems with the calcualtion of the area you suggested, but I am trying to face it! In anycase, I have another method for the area calculation!
Thanks so much for your help
Torsten
Torsten 2022 年 7 月 5 日
編集済み: Torsten 2022 年 7 月 5 日
I just noticed that the area calculation only works for closed curves in the x-y plane.
For closed curves in 3d lying in a plane, things will become more complicated.
But you said that you have already determined the enclosed area :-)

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeComputational Geometry についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by