Volume of 3D polyhedron
24 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
slaiyer
el 24 de Ag. de 2014
Comentada: Iila
el 25 de Feb. de 2016
Given a set of 3D coordinates, how can one find the volume of the polyhedron that is not necessarily convex?
7 comentarios
Iila
el 25 de Feb. de 2016
Thank you. But it doesn't. My polyhedra are concave. I also want to calculate the self intersecting volume, if any.
Respuesta aceptada
Mike Garrity
el 24 de Feb. de 2016
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')
Más respuestas (0)
Ver también
Categorías
Más información sobre Bounding Regions en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!