Point Cloud Library (PCL)  1.7.2
List of all members | Public Types | Public Member Functions | Protected Member Functions
pcl::VoxelGridLabel Class Reference

#include <pcl/filters/voxel_grid_label.h>

+ Inheritance diagram for pcl::VoxelGridLabel:

Public Types

typedef boost::shared_ptr
< VoxelGridLabel
Ptr
typedef boost::shared_ptr
< const VoxelGridLabel
ConstPtr

Public Member Functions

 VoxelGridLabel ()
 Constructor.
- Public Member Functions inherited from pcl::VoxelGrid< pcl::PointXYZRGBL >
 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 setMinimumPointsNumberPerVoxel (unsigned int min_points_per_voxel)
 Set the minimum number of points required for a voxel to be used.
unsigned int getMinimumPointsNumberPerVoxel ()
 Return the minimum number of points required for a voxel to be used.
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 (const pcl::PointXYZRGBL &p)
 Returns the index in the resulting downsampled cloud of the specified point.
std::vector< int > getNeighborCentroidIndices (const pcl::PointXYZRGBL &reference_point, 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 > 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).
- Public Member Functions inherited from pcl::Filter< pcl::PointXYZRGBL >
 Filter (bool extract_removed_indices=false)
 Empty constructor.
virtual ~Filter ()
 Empty destructor.
IndicesConstPtr const getRemovedIndices ()
 Get the point indices being removed.
void getRemovedIndices (PointIndices &pi)
 Get the point indices being removed.
void filter (PointCloud &output)
 Calls the filtering method and returns the filtered dataset in output.
- Public Member Functions inherited from pcl::PCLBase< pcl::PointXYZRGBL >
 PCLBase ()
 Empty constructor.
 PCLBase (const PCLBase &base)
 Copy constructor.
virtual ~PCLBase ()
 Destructor.
virtual void setInputCloud (const PointCloudConstPtr &cloud)
 Provide a pointer to the input dataset.
PointCloudConstPtr const getInputCloud () const
 Get a pointer to the input point cloud dataset.
virtual void setIndices (const IndicesPtr &indices)
 Provide a pointer to the vector of indices that represents the input data.
virtual void setIndices (const IndicesConstPtr &indices)
 Provide a pointer to the vector of indices that represents the input data.
virtual void setIndices (const PointIndicesConstPtr &indices)
 Provide a pointer to the vector of indices that represents the input data.
virtual void setIndices (size_t row_start, size_t col_start, size_t nb_rows, size_t nb_cols)
 Set the indices for the points laying within an interest region of the point cloud.
IndicesPtr const getIndices ()
 Get a pointer to the vector of indices used.
IndicesConstPtr const getIndices () const
 Get a pointer to the vector of indices used.
const pcl::PointXYZRGBLoperator[] (size_t pos) const
 Override PointCloud operator[] to shorten code.

Protected Member Functions

void applyFilter (PointCloud &output)
 Filter cloud and initializes voxel structure.

Additional Inherited Members

- Protected Types inherited from pcl::VoxelGrid< pcl::PointXYZRGBL >
typedef Filter
< pcl::PointXYZRGBL >
::PointCloud 
PointCloud
typedef PointCloud::Ptr PointCloudPtr
typedef PointCloud::ConstPtr PointCloudConstPtr
typedef boost::shared_ptr
< VoxelGrid< pcl::PointXYZRGBL > > 
Ptr
typedef boost::shared_ptr
< const VoxelGrid
< pcl::PointXYZRGBL > > 
ConstPtr
typedef pcl::traits::fieldList
< pcl::PointXYZRGBL >::type 
FieldList
- Protected Attributes inherited from pcl::VoxelGrid< pcl::PointXYZRGBL >
Eigen::Vector4f leaf_size_
 The size of a leaf.
Eigen::Array4f inverse_leaf_size_
 Internal leaf sizes stored as 1/leaf_size_ for efficiency reasons.
bool downsample_all_data_
 Set to true if all fields need to be downsampled, or false if just XYZ.
bool save_leaf_layout_
 Set to true if leaf layout information needs to be saved in leaf_layout_.
std::vector< int > leaf_layout_
 The leaf layout information for fast access to cells relative to current position.
Eigen::Vector4i min_b_
 The minimum and maximum bin coordinates, the number of divisions, and the division multiplier.
Eigen::Vector4i max_b_
Eigen::Vector4i div_b_
Eigen::Vector4i divb_mul_
std::string filter_field_name_
 The desired user filter field name.
double filter_limit_min_
 The minimum allowed filter value a point will be considered from.
double filter_limit_max_
 The maximum allowed filter value a point will be considered from.
bool filter_limit_negative_
 Set to true if we want to return the data outside (filter_limit_min_;filter_limit_max_).
unsigned int min_points_per_voxel_
 Minimum number of points per voxel for the centroid to be computed.

Detailed Description

Author
Christian Potthast (potth.nosp@m.ast@.nosp@m.usc.e.nosp@m.du)

Definition at line 51 of file voxel_grid_label.h.

Member Typedef Documentation

typedef boost::shared_ptr< const VoxelGridLabel > pcl::VoxelGridLabel::ConstPtr

Definition at line 56 of file voxel_grid_label.h.

typedef boost::shared_ptr< VoxelGridLabel > pcl::VoxelGridLabel::Ptr

Definition at line 55 of file voxel_grid_label.h.

Constructor & Destructor Documentation

pcl::VoxelGridLabel::VoxelGridLabel ( )
inline

Constructor.

Sets leaf_size_ to 0 and searchable_ to false.

Definition at line 62 of file voxel_grid_label.h.

Member Function Documentation

void pcl::VoxelGridLabel::applyFilter ( PointCloud output)
protectedvirtual

Filter cloud and initializes voxel structure.

Parameters
[out]outputcloud containing centroids of voxels containing a sufficient number of points

Reimplemented from pcl::VoxelGrid< pcl::PointXYZRGBL >.


The documentation for this class was generated from the following file: