|
Point Cloud Library (PCL)
1.6.0
|
VoxelGrid assembles a local 3D grid over a given PointCloud, and downsamples + filters the data. More...
#include <pcl/filters/voxel_grid.h>


Public Types | |
| typedef PointIndices::Ptr | PointIndicesPtr |
| typedef PointIndices::ConstPtr | PointIndicesConstPtr |
Public Member Functions | |
| VoxelGrid () | |
| Empty constructor. | |
| virtual | ~VoxelGrid () |
| Destructor. | |
| void | setLeafSize (const Eigen::Vector4f &leaf_size) |
| Set the voxel grid leaf size. | |
| void | setLeafSize (float lx, float ly, float lz) |
| Set the voxel grid leaf size. | |
| Eigen::Vector3f | getLeafSize () |
| Get the voxel grid leaf size. | |
| void | setDownsampleAllData (bool downsample) |
| Set to true if all fields need to be downsampled, or false if just XYZ. | |
| bool | getDownsampleAllData () |
| Get the state of the internal downsampling parameter (true if all fields need to be downsampled, false if just XYZ). | |
| void | setSaveLeafLayout (bool save_leaf_layout) |
| Set to true if leaf layout information needs to be saved for later access. | |
| bool | getSaveLeafLayout () |
| Returns true if leaf layout information will to be saved for later access. | |
| Eigen::Vector3i | getMinBoxCoordinates () |
| Get the minimum coordinates of the bounding box (after filtering is performed). | |
| Eigen::Vector3i | getMaxBoxCoordinates () |
| Get the minimum coordinates of the bounding box (after filtering is performed). | |
| Eigen::Vector3i | getNrDivisions () |
| Get the number of divisions along all 3 axes (after filtering is performed). | |
| Eigen::Vector3i | getDivisionMultiplier () |
| Get the multipliers to be applied to the grid coordinates in order to find the centroid index (after filtering is performed). | |
| int | getCentroidIndex (float x, float y, float z) |
| Returns the index in the resulting downsampled cloud of the specified point. | |
| std::vector< int > | getNeighborCentroidIndices (float x, float y, float z, const Eigen::MatrixXi &relative_coordinates) |
| Returns the indices in the resulting downsampled cloud of the points at the specified grid coordinates, relative to the grid coordinates of the specified point (or -1 if the cell was empty/out of bounds). | |
| std::vector< int > | getNeighborCentroidIndices (float x, float y, float z, const std::vector< Eigen::Vector3i > &relative_coordinates) |
| Returns the indices in the resulting downsampled cloud of the points at the specified grid coordinates, relative to the grid coordinates of the specified point (or -1 if the cell was empty/out of bounds). | |
| std::vector< int > | getLeafLayout () |
| Returns the layout of the leafs for fast access to cells relative to current position. | |
| Eigen::Vector3i | getGridCoordinates (float x, float y, float z) |
| Returns the corresponding (i,j,k) coordinates in the grid of point (x,y,z). | |
| int | getCentroidIndexAt (const Eigen::Vector3i &ijk) |
| Returns the index in the downsampled cloud corresponding to a given set of coordinates. | |
| void | setFilterFieldName (const std::string &field_name) |
| Provide the name of the field to be used for filtering data. | |
| std::string const | getFilterFieldName () |
| Get the name of the field used for filtering. | |
| void | setFilterLimits (const double &limit_min, const double &limit_max) |
| Set the field filter limits. | |
| void | getFilterLimits (double &limit_min, double &limit_max) |
| Get the field filter limits (min/max) set by the user. | |
| void | setFilterLimitsNegative (const bool limit_negative) |
| Set to true if we want to return the data outside the interval specified by setFilterLimits (min, max). | |
| void | getFilterLimitsNegative (bool &limit_negative) |
| Get whether the data outside the interval (min/max) is to be returned (true) or inside (false). | |
| bool | getFilterLimitsNegative () |
| Get whether the data outside the interval (min/max) is to be returned (true) or inside (false). | |
| IndicesConstPtr const | getRemovedIndices () |
| Get the point indices being removed. | |
| void | filter (PointCloud2 &output) |
| Calls the filtering method and returns the filtered dataset in output. | |
| void | setInputCloud (const PointCloud2ConstPtr &cloud) |
| Provide a pointer to the input dataset. | |
| PointCloud2ConstPtr const | getInputCloud () |
| Get a pointer to the input point cloud dataset. | |
| void | setIndices (const IndicesPtr &indices) |
| Provide a pointer to the vector of indices that represents the input data. | |
| void | setIndices (const PointIndicesConstPtr &indices) |
| Provide a pointer to the vector of indices that represents the input data. | |
| IndicesPtr const | getIndices () |
| Get a pointer to the vector of indices used. | |
VoxelGrid assembles a local 3D grid over a given PointCloud, and downsamples + filters the data.
The VoxelGrid class creates a *3D voxel grid* (think about a voxel grid as a set of tiny 3D boxes in space) over the input point cloud data. Then, in each *voxel* (i.e., 3D box), all the points present will be approximated (i.e., *downsampled*) with their centroid. This approach is a bit slower than approximating them with the center of the voxel, but it represents the underlying surface more accurately.
Definition at line 476 of file voxel_grid.h.
typedef PointIndices::ConstPtr pcl::PCLBase< sensor_msgs::PointCloud2 >::PointIndicesConstPtr [inherited] |
Definition at line 280 of file pcl_base.h.
typedef PointIndices::Ptr pcl::PCLBase< sensor_msgs::PointCloud2 >::PointIndicesPtr [inherited] |
Definition at line 279 of file pcl_base.h.
| pcl::VoxelGrid< sensor_msgs::PointCloud2 >::VoxelGrid | ( | ) | [inline] |
Empty constructor.
Definition at line 487 of file voxel_grid.h.
| virtual pcl::VoxelGrid< sensor_msgs::PointCloud2 >::~VoxelGrid | ( | ) | [inline, virtual] |
Destructor.
Definition at line 506 of file voxel_grid.h.
| void pcl::Filter< sensor_msgs::PointCloud2 >::filter | ( | PointCloud2 & | output | ) | [inherited] |
Calls the filtering method and returns the filtered dataset in output.
| [out] | output | the resultant filtered point cloud dataset |
Reimplemented in pcl::FilterIndices< sensor_msgs::PointCloud2 >.
| int pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getCentroidIndex | ( | float | x, |
| float | y, | ||
| float | z | ||
| ) | [inline] |
Returns the index in the resulting downsampled cloud of the specified point.
| [in] | x | the X point coordinate to get the index at |
| [in] | y | the Y point coordinate to get the index at |
| [in] | z | the Z point coordinate to get the index at |
Definition at line 598 of file voxel_grid.h.
| int pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getCentroidIndexAt | ( | const Eigen::Vector3i & | ijk | ) | [inline] |
Returns the index in the downsampled cloud corresponding to a given set of coordinates.
| [in] | ijk | the coordinates (i,j,k) in the grid (-1 if empty) |
Definition at line 678 of file voxel_grid.h.
| Eigen::Vector3i pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getDivisionMultiplier | ( | ) | [inline] |
Get the multipliers to be applied to the grid coordinates in order to find the centroid index (after filtering is performed).
Definition at line 588 of file voxel_grid.h.
| bool pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getDownsampleAllData | ( | ) | [inline] |
Get the state of the internal downsampling parameter (true if all fields need to be downsampled, false if just XYZ).
Definition at line 554 of file voxel_grid.h.
| std::string const pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getFilterFieldName | ( | ) | [inline] |
Get the name of the field used for filtering.
Definition at line 702 of file voxel_grid.h.
| void pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getFilterLimits | ( | double & | limit_min, |
| double & | limit_max | ||
| ) | [inline] |
Get the field filter limits (min/max) set by the user.
The default values are -FLT_MAX, FLT_MAX.
| [out] | limit_min | the minimum allowed field value |
| [out] | limit_max | the maximum allowed field value |
Definition at line 723 of file voxel_grid.h.
| void pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getFilterLimitsNegative | ( | bool & | limit_negative | ) | [inline] |
Get whether the data outside the interval (min/max) is to be returned (true) or inside (false).
| [out] | limit_negative | true if data outside the interval [min; max] is to be returned, false otherwise |
Definition at line 743 of file voxel_grid.h.
| bool pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getFilterLimitsNegative | ( | ) | [inline] |
Get whether the data outside the interval (min/max) is to be returned (true) or inside (false).
Definition at line 752 of file voxel_grid.h.
| Eigen::Vector3i pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getGridCoordinates | ( | float | x, |
| float | y, | ||
| float | z | ||
| ) | [inline] |
Returns the corresponding (i,j,k) coordinates in the grid of point (x,y,z).
| [in] | x | the X point coordinate to get the (i, j, k) index at |
| [in] | y | the Y point coordinate to get the (i, j, k) index at |
| [in] | z | the Z point coordinate to get the (i, j, k) index at |
Definition at line 667 of file voxel_grid.h.
| IndicesPtr const pcl::PCLBase< sensor_msgs::PointCloud2 >::getIndices | ( | ) | [inline, inherited] |
Get a pointer to the vector of indices used.
Definition at line 329 of file pcl_base.h.
| PointCloud2ConstPtr const pcl::PCLBase< sensor_msgs::PointCloud2 >::getInputCloud | ( | ) | [inline, inherited] |
Get a pointer to the input point cloud dataset.
Definition at line 303 of file pcl_base.h.
| std::vector<int> pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getLeafLayout | ( | ) | [inline] |
Returns the layout of the leafs for fast access to cells relative to current position.
Definition at line 659 of file voxel_grid.h.
| Eigen::Vector3f pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getLeafSize | ( | ) | [inline] |
Get the voxel grid leaf size.
Definition at line 542 of file voxel_grid.h.
| Eigen::Vector3i pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getMaxBoxCoordinates | ( | ) | [inline] |
Get the minimum coordinates of the bounding box (after filtering is performed).
Definition at line 576 of file voxel_grid.h.
| Eigen::Vector3i pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getMinBoxCoordinates | ( | ) | [inline] |
Get the minimum coordinates of the bounding box (after filtering is performed).
Definition at line 570 of file voxel_grid.h.
| std::vector<int> pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getNeighborCentroidIndices | ( | float | x, |
| float | y, | ||
| float | z, | ||
| const Eigen::MatrixXi & | relative_coordinates | ||
| ) | [inline] |
Returns the indices in the resulting downsampled cloud of the points at the specified grid coordinates, relative to the grid coordinates of the specified point (or -1 if the cell was empty/out of bounds).
| [in] | x | the X coordinate of the reference point (corresponding cell is allowed to be empty/out of bounds) |
| [in] | y | the Y coordinate of the reference point (corresponding cell is allowed to be empty/out of bounds) |
| [in] | z | the Z coordinate of the reference point (corresponding cell is allowed to be empty/out of bounds) |
| [out] | relative_coordinates | matrix with the columns being the coordinates of the requested cells, relative to the reference point's cell |
Definition at line 616 of file voxel_grid.h.
| std::vector<int> pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getNeighborCentroidIndices | ( | float | x, |
| float | y, | ||
| float | z, | ||
| const std::vector< Eigen::Vector3i > & | relative_coordinates | ||
| ) | [inline] |
Returns the indices in the resulting downsampled cloud of the points at the specified grid coordinates, relative to the grid coordinates of the specified point (or -1 if the cell was empty/out of bounds).
| [in] | x | the X coordinate of the reference point (corresponding cell is allowed to be empty/out of bounds) |
| [in] | y | the Y coordinate of the reference point (corresponding cell is allowed to be empty/out of bounds) |
| [in] | z | the Z coordinate of the reference point (corresponding cell is allowed to be empty/out of bounds) |
| [out] | relative_coordinates | vector with the elements being the coordinates of the requested cells, relative to the reference point's cell |
Definition at line 645 of file voxel_grid.h.
| Eigen::Vector3i pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getNrDivisions | ( | ) | [inline] |
Get the number of divisions along all 3 axes (after filtering is performed).
Definition at line 582 of file voxel_grid.h.
| IndicesConstPtr const pcl::Filter< sensor_msgs::PointCloud2 >::getRemovedIndices | ( | ) | [inline, inherited] |
Get the point indices being removed.
Reimplemented in pcl::FilterIndices< sensor_msgs::PointCloud2 >.
| bool pcl::VoxelGrid< sensor_msgs::PointCloud2 >::getSaveLeafLayout | ( | ) | [inline] |
Returns true if leaf layout information will to be saved for later access.
Definition at line 564 of file voxel_grid.h.
| void pcl::VoxelGrid< sensor_msgs::PointCloud2 >::setDownsampleAllData | ( | bool | downsample | ) | [inline] |
Set to true if all fields need to be downsampled, or false if just XYZ.
| [in] | downsample | the new value (true/false) |
Definition at line 548 of file voxel_grid.h.
| void pcl::VoxelGrid< sensor_msgs::PointCloud2 >::setFilterFieldName | ( | const std::string & | field_name | ) | [inline] |
Provide the name of the field to be used for filtering data.
In conjunction with setFilterLimits, points having values outside this interval will be discarded.
| [in] | field_name | the name of the field that contains values used for filtering |
Definition at line 695 of file voxel_grid.h.
| void pcl::VoxelGrid< sensor_msgs::PointCloud2 >::setFilterLimits | ( | const double & | limit_min, |
| const double & | limit_max | ||
| ) | [inline] |
Set the field filter limits.
All points having field values outside this interval will be discarded.
| [in] | limit_min | the minimum allowed field value |
| [in] | limit_max | the maximum allowed field value |
Definition at line 712 of file voxel_grid.h.
| void pcl::VoxelGrid< sensor_msgs::PointCloud2 >::setFilterLimitsNegative | ( | const bool | limit_negative | ) | [inline] |
Set to true if we want to return the data outside the interval specified by setFilterLimits (min, max).
Default: false.
| [in] | limit_negative | return data inside the interval (false) or outside (true) |
Definition at line 734 of file voxel_grid.h.
| void pcl::PCLBase< sensor_msgs::PointCloud2 >::setIndices | ( | const IndicesPtr & | indices | ) | [inline, inherited] |
Provide a pointer to the vector of indices that represents the input data.
| indices | a pointer to the vector of indices that represents the input data. |
Definition at line 309 of file pcl_base.h.
| void pcl::PCLBase< sensor_msgs::PointCloud2 >::setIndices | ( | const PointIndicesConstPtr & | indices | ) | [inline, inherited] |
Provide a pointer to the vector of indices that represents the input data.
| indices | a pointer to the vector of indices that represents the input data. |
Definition at line 320 of file pcl_base.h.
| void pcl::PCLBase< sensor_msgs::PointCloud2 >::setInputCloud | ( | const PointCloud2ConstPtr & | cloud | ) | [inherited] |
Provide a pointer to the input dataset.
| cloud | the const boost shared pointer to a PointCloud message |
| void pcl::VoxelGrid< sensor_msgs::PointCloud2 >::setLeafSize | ( | const Eigen::Vector4f & | leaf_size | ) | [inline] |
Set the voxel grid leaf size.
| [in] | leaf_size | the voxel grid leaf size |
Definition at line 514 of file voxel_grid.h.
| void pcl::VoxelGrid< sensor_msgs::PointCloud2 >::setLeafSize | ( | float | lx, |
| float | ly, | ||
| float | lz | ||
| ) | [inline] |
Set the voxel grid leaf size.
| [in] | lx | the leaf size for X |
| [in] | ly | the leaf size for Y |
| [in] | lz | the leaf size for Z |
Definition at line 530 of file voxel_grid.h.
| void pcl::VoxelGrid< sensor_msgs::PointCloud2 >::setSaveLeafLayout | ( | bool | save_leaf_layout | ) | [inline] |
Set to true if leaf layout information needs to be saved for later access.
| [in] | save_leaf_layout | the new value (true/false) |
Definition at line 560 of file voxel_grid.h.
1.7.6.1