Volume of 3D polyhedron

15 ビュー (過去 30 日間)
slaiyer
slaiyer 2014 年 8 月 24 日
コメント済み: Iila 2016 年 2 月 25 日
Given a set of 3D coordinates, how can one find the volume of the polyhedron that is not necessarily convex?
  7 件のコメント
Matt J
Matt J 2016 年 2 月 24 日
Iila
Iila 2016 年 2 月 25 日
Thank you. But it doesn't. My polyhedra are concave. I also want to calculate the self intersecting volume, if any.

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

採用された回答

Mike Garrity
Mike Garrity 2016 年 2 月 24 日
One option you might look at is alphaShape. It's similar to convhull, but more general. It will create non-convex shapes.
You use it like this. First I need a simple cloud of points.
npts = 75;
pts = randn(npts,3);
scatter3(pts(:,1),pts(:,2),pts(:,3),'filled')
Then I create my alphaShape, and plot it.
shp = alphaShape(pts);
h = plot(shp);
But the reason this might be useful for you, is that it has a method that will return the volume of the shape:
volume(shp)
ans =
27.3914
And another method which will tell you whether other points are inside the shape.
testpts = randn(150,3);
inmask = inShape(shp,testpts);
h.FaceColor = [.75 .75 .75];
h.FaceAlpha = .25;
hold on
scatter3(testpts(inmask,1),testpts(inmask,2),testpts(inmask,3),'.','MarkerEdgeColor','green')
scatter3(testpts(~inmask,1),testpts(~inmask,2),testpts(~inmask,3),'.','MarkerEdgeColor','red')
  1 件のコメント
slaiyer
slaiyer 2016 年 2 月 24 日
This seems to be exactly what I was looking for back then. Thanks a lot for your input; cheers!

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

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeBounding Regions についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by