Point Cloud Library (PCL)
1.14.1-dev
|
The marching cubes surface reconstruction algorithm. More...
#include <pcl/surface/marching_cubes.h>
Public Types | |
using | Ptr = shared_ptr< MarchingCubes< PointNT > > |
using | ConstPtr = shared_ptr< const MarchingCubes< PointNT > > |
using | PointCloudPtr = typename pcl::PointCloud< PointNT >::Ptr |
using | KdTree = pcl::KdTree< PointNT > |
using | KdTreePtr = typename KdTree::Ptr |
Public Types inherited from pcl::SurfaceReconstruction< PointNT > | |
using | Ptr = shared_ptr< SurfaceReconstruction< PointNT > > |
using | ConstPtr = shared_ptr< const SurfaceReconstruction< PointNT > > |
Public Types inherited from pcl::PCLSurfaceBase< PointInT > | |
using | Ptr = shared_ptr< PCLSurfaceBase< PointInT > > |
using | ConstPtr = shared_ptr< const PCLSurfaceBase< PointInT > > |
using | KdTree = pcl::search::Search< PointInT > |
using | KdTreePtr = typename KdTree::Ptr |
Public Types inherited from pcl::PCLBase< PointInT > | |
using | PointCloud = pcl::PointCloud< PointInT > |
using | PointCloudPtr = typename PointCloud::Ptr |
using | PointCloudConstPtr = typename PointCloud::ConstPtr |
using | PointIndicesPtr = PointIndices::Ptr |
using | PointIndicesConstPtr = PointIndices::ConstPtr |
Public Member Functions | |
MarchingCubes (const float percentage_extend_grid=0.0f, const float iso_level=0.0f) | |
Constructor. More... | |
~MarchingCubes () override | |
Destructor. More... | |
void | setIsoLevel (float iso_level) |
Method that sets the iso level of the surface to be extracted. More... | |
float | getIsoLevel () |
Method that returns the iso level of the surface to be extracted. More... | |
void | setGridResolution (int res_x, int res_y, int res_z) |
Method that sets the marching cubes grid resolution. More... | |
void | getGridResolution (int &res_x, int &res_y, int &res_z) |
Method to get the marching cubes grid resolution. More... | |
void | setPercentageExtendGrid (float percentage) |
Method that sets the parameter that defines how much free space should be left inside the grid between the bounding box of the point cloud and the grid limits. More... | |
float | getPercentageExtendGrid () |
Method that gets the parameter that defines how much free space should be left inside the grid between the bounding box of the point cloud and the grid limits, as a percentage of the bounding box. More... | |
Public Member Functions inherited from pcl::SurfaceReconstruction< PointNT > | |
SurfaceReconstruction ()=default | |
Constructor. More... | |
~SurfaceReconstruction () override=default | |
Destructor. More... | |
void | reconstruct (pcl::PolygonMesh &output) override |
Base method for surface reconstruction for all points given in <setInputCloud (), setIndices ()> More... | |
virtual void | reconstruct (pcl::PointCloud< PointNT > &points, std::vector< pcl::Vertices > &polygons) |
Base method for surface reconstruction for all points given in <setInputCloud (), setIndices ()> More... | |
Public Member Functions inherited from pcl::PCLSurfaceBase< PointInT > | |
PCLSurfaceBase () | |
Empty constructor. More... | |
~PCLSurfaceBase () override=default | |
Empty destructor. More... | |
void | setSearchMethod (const KdTreePtr &tree) |
Provide an optional pointer to a search object. More... | |
KdTreePtr | getSearchMethod () |
Get a pointer to the search method used. More... | |
Public Member Functions inherited from pcl::PCLBase< PointInT > | |
PCLBase () | |
Empty constructor. More... | |
PCLBase (const PCLBase &base) | |
Copy constructor. More... | |
virtual | ~PCLBase ()=default |
Destructor. More... | |
virtual void | setInputCloud (const PointCloudConstPtr &cloud) |
Provide a pointer to the input dataset. More... | |
PointCloudConstPtr const | getInputCloud () const |
Get a pointer to the input point cloud dataset. More... | |
virtual void | setIndices (const IndicesPtr &indices) |
Provide a pointer to the vector of indices that represents the input data. More... | |
virtual void | setIndices (const IndicesConstPtr &indices) |
Provide a pointer to the vector of indices that represents the input data. More... | |
virtual void | setIndices (const PointIndicesConstPtr &indices) |
Provide a pointer to the vector of indices that represents the input data. More... | |
virtual void | setIndices (std::size_t row_start, std::size_t col_start, std::size_t nb_rows, std::size_t nb_cols) |
Set the indices for the points laying within an interest region of the point cloud. More... | |
IndicesPtr | getIndices () |
Get a pointer to the vector of indices used. More... | |
IndicesConstPtr const | getIndices () const |
Get a pointer to the vector of indices used. More... | |
const PointInT & | operator[] (std::size_t pos) const |
Override PointCloud operator[] to shorten code. More... | |
Protected Member Functions | |
virtual void | voxelizeData ()=0 |
Convert the point cloud into voxel data. More... | |
void | interpolateEdge (Eigen::Vector3f &p1, Eigen::Vector3f &p2, float val_p1, float val_p2, Eigen::Vector3f &output) |
Interpolate along the voxel edge. More... | |
void | createSurface (const std::vector< float > &leaf_node, const Eigen::Vector3i &index_3d, pcl::PointCloud< PointNT > &cloud) |
Calculate out the corresponding polygons in the leaf node. More... | |
void | getBoundingBox () |
Get the bounding box for the input data points. More... | |
virtual float | getGridValue (Eigen::Vector3i pos) |
Method that returns the scalar value at the given grid position. More... | |
void | getNeighborList1D (std::vector< float > &leaf, Eigen::Vector3i &index3d) |
Method that returns the scalar values of the neighbors of a given 3D position in the grid. More... | |
std::string | getClassName () const override |
Class get name method. More... | |
void | performReconstruction (pcl::PolygonMesh &output) override |
Extract the surface. More... | |
void | performReconstruction (pcl::PointCloud< PointNT > &points, std::vector< pcl::Vertices > &polygons) override |
Extract the surface. More... | |
Protected Member Functions inherited from pcl::PCLBase< PointInT > | |
bool | initCompute () |
This method should get called before starting the actual computation. More... | |
bool | deinitCompute () |
This method should get called after finishing the actual computation. More... | |
Protected Attributes | |
std::vector< float > | grid_ |
The data structure storing the 3D grid. More... | |
int | res_x_ = 32 |
The grid resolution. More... | |
int | res_y_ = 32 |
int | res_z_ = 32 |
Eigen::Array3f | upper_boundary_ |
bounding box More... | |
Eigen::Array3f | lower_boundary_ |
Eigen::Array3f | size_voxel_ |
size of voxels More... | |
float | percentage_extend_grid_ |
Parameter that defines how much free space should be left inside the grid between the bounding box of the point cloud and the grid limits, as a percentage of the bounding box. More... | |
float | iso_level_ |
The iso level to be extracted. More... | |
Protected Attributes inherited from pcl::SurfaceReconstruction< PointNT > | |
bool | check_tree_ |
A flag specifying whether or not the derived reconstruction algorithm needs the search object tree. More... | |
Protected Attributes inherited from pcl::PCLSurfaceBase< PointInT > | |
KdTreePtr | tree_ |
A pointer to the spatial search object. More... | |
Protected Attributes inherited from pcl::PCLBase< PointInT > | |
PointCloudConstPtr | input_ |
The input point cloud dataset. More... | |
IndicesPtr | indices_ |
A pointer to the vector of point indices to use. More... | |
bool | use_indices_ |
Set to true if point indices are used. More... | |
bool | fake_indices_ |
If no set of indices are given, we construct a set of fake indices that mimic the input PointCloud. More... | |
The marching cubes surface reconstruction algorithm.
This is an abstract class that takes a grid and extracts the isosurface as a mesh, based on the original marching cubes paper:
Lorensen W.E., Cline H.E., "Marching cubes: A high resolution 3d surface construction algorithm", SIGGRAPH '87
PointNT | Use pcl::PointNormal or pcl::PointXYZRGBNormal or pcl::PointXYZINormal |
Definition at line 364 of file marching_cubes.h.
using pcl::MarchingCubes< PointNT >::ConstPtr = shared_ptr<const MarchingCubes<PointNT> > |
Definition at line 368 of file marching_cubes.h.
using pcl::MarchingCubes< PointNT >::KdTree = pcl::KdTree<PointNT> |
Definition at line 375 of file marching_cubes.h.
using pcl::MarchingCubes< PointNT >::KdTreePtr = typename KdTree::Ptr |
Definition at line 376 of file marching_cubes.h.
using pcl::MarchingCubes< PointNT >::PointCloudPtr = typename pcl::PointCloud<PointNT>::Ptr |
Definition at line 373 of file marching_cubes.h.
using pcl::MarchingCubes< PointNT >::Ptr = shared_ptr<MarchingCubes<PointNT> > |
Definition at line 367 of file marching_cubes.h.
|
inline |
Constructor.
Definition at line 379 of file marching_cubes.h.
|
overridedefault |
Destructor.
|
protected |
Calculate out the corresponding polygons in the leaf node.
leaf_node | the leaf node to be checked |
index_3d | the 3d index of the leaf node to be checked |
cloud | point cloud to store the vertices of the polygon |
Definition at line 81 of file marching_cubes.hpp.
References pcl::edgeTable, pcl::PointCloud< PointT >::push_back(), and pcl::triTable.
|
protected |
Get the bounding box for the input data points.
Definition at line 50 of file marching_cubes.hpp.
References pcl::getMinMax3D().
|
inlineoverrideprotectedvirtual |
Class get name method.
Reimplemented from pcl::PCLSurfaceBase< PointInT >.
Definition at line 505 of file marching_cubes.h.
|
inline |
Method to get the marching cubes grid resolution.
[in] | res_x | the resolution of the grid along the x-axis |
[in] | res_y | the resolution of the grid along the y-axis |
[in] | res_z | the resolution of the grid along the z-axis |
Definition at line 417 of file marching_cubes.h.
References pcl::MarchingCubes< PointNT >::res_x_, pcl::MarchingCubes< PointNT >::res_y_, and pcl::MarchingCubes< PointNT >::res_z_.
|
protectedvirtual |
Method that returns the scalar value at the given grid position.
[in] | pos | The 3D position in the grid |
TODO what to return?
Definition at line 190 of file marching_cubes.hpp.
|
inline |
Method that returns the iso level of the surface to be extracted.
Definition at line 399 of file marching_cubes.h.
References pcl::MarchingCubes< PointNT >::iso_level_.
|
protected |
Method that returns the scalar values of the neighbors of a given 3D position in the grid.
[in] | index3d | the point in the grid |
[out] | leaf | the set of values |
Definition at line 163 of file marching_cubes.hpp.
|
inline |
Method that gets the parameter that defines how much free space should be left inside the grid between the bounding box of the point cloud and the grid limits, as a percentage of the bounding box.
Definition at line 434 of file marching_cubes.h.
References pcl::MarchingCubes< PointNT >::percentage_extend_grid_.
|
protected |
Interpolate along the voxel edge.
[in] | p1 | The first point on the edge |
[in] | p2 | The second point on the edge |
[in] | val_p1 | The scalar value at p1 |
[in] | val_p2 | The scalar value at p2 |
[out] | output | The interpolated point along the edge |
Definition at line 68 of file marching_cubes.hpp.
|
overrideprotectedvirtual |
Extract the surface.
[out] | points | the points of the extracted mesh |
[out] | polygons | the connectivity between the point of the extracted mesh. |
Implements pcl::SurfaceReconstruction< PointNT >.
Definition at line 218 of file marching_cubes.hpp.
References pcl::PointCloud< PointT >::clear(), pcl::PointCloud< PointT >::points, pcl::PointCloud< PointT >::reserve(), pcl::PointCloud< PointT >::size(), pcl::PointCloud< PointT >::swap(), and pcl::Vertices::vertices.
|
overrideprotectedvirtual |
Extract the surface.
[out] | output | the resultant polygonal mesh |
Implements pcl::SurfaceReconstruction< PointNT >.
Definition at line 206 of file marching_cubes.hpp.
References pcl::PolygonMesh::cloud, pcl::PolygonMesh::polygons, and pcl::toPCLPointCloud2().
|
inline |
Method that sets the marching cubes grid resolution.
[in] | res_x | the resolution of the grid along the x-axis |
[in] | res_y | the resolution of the grid along the y-axis |
[in] | res_z | the resolution of the grid along the z-axis |
Definition at line 408 of file marching_cubes.h.
References pcl::MarchingCubes< PointNT >::res_x_, pcl::MarchingCubes< PointNT >::res_y_, and pcl::MarchingCubes< PointNT >::res_z_.
|
inline |
Method that sets the iso level of the surface to be extracted.
[in] | iso_level | the iso level. |
Definition at line 394 of file marching_cubes.h.
References pcl::MarchingCubes< PointNT >::iso_level_.
|
inline |
Method that sets the parameter that defines how much free space should be left inside the grid between the bounding box of the point cloud and the grid limits.
Does not affect the resolution of the grid, it just changes the voxel size accordingly.
[in] | percentage | the percentage of the bounding box that should be left empty between the bounding box and the grid limits. |
Definition at line 427 of file marching_cubes.h.
References pcl::MarchingCubes< PointNT >::percentage_extend_grid_.
|
protectedpure virtual |
Convert the point cloud into voxel data.
Implemented in pcl::MarchingCubesRBF< PointNT >, and pcl::MarchingCubesHoppe< PointNT >.
|
protected |
The data structure storing the 3D grid.
Definition at line 439 of file marching_cubes.h.
|
protected |
The iso level to be extracted.
Definition at line 456 of file marching_cubes.h.
Referenced by pcl::MarchingCubes< PointNT >::getIsoLevel(), and pcl::MarchingCubes< PointNT >::setIsoLevel().
|
protected |
Definition at line 446 of file marching_cubes.h.
|
protected |
Parameter that defines how much free space should be left inside the grid between the bounding box of the point cloud and the grid limits, as a percentage of the bounding box.
Definition at line 453 of file marching_cubes.h.
Referenced by pcl::MarchingCubes< PointNT >::getPercentageExtendGrid(), and pcl::MarchingCubes< PointNT >::setPercentageExtendGrid().
|
protected |
The grid resolution.
Definition at line 442 of file marching_cubes.h.
Referenced by pcl::MarchingCubes< PointNT >::getGridResolution(), and pcl::MarchingCubes< PointNT >::setGridResolution().
|
protected |
Definition at line 442 of file marching_cubes.h.
Referenced by pcl::MarchingCubes< PointNT >::getGridResolution(), and pcl::MarchingCubes< PointNT >::setGridResolution().
|
protected |
Definition at line 442 of file marching_cubes.h.
Referenced by pcl::MarchingCubes< PointNT >::getGridResolution(), and pcl::MarchingCubes< PointNT >::setGridResolution().
|
protected |
size of voxels
Definition at line 449 of file marching_cubes.h.
|
protected |
bounding box
Definition at line 445 of file marching_cubes.h.