Point Cloud Library (PCL)
1.14.1-dev
|
Implements the Progressive Morphological Filter for segmentation of ground points. More...
#include <pcl/segmentation/approximate_progressive_morphological_filter.h>
Public Types | |
using | PointCloud = pcl::PointCloud< PointT > |
Public Types inherited from pcl::PCLBase< PointT > | |
using | PointCloud = pcl::PointCloud< PointT > |
using | PointCloudPtr = typename PointCloud::Ptr |
using | PointCloudConstPtr = typename PointCloud::ConstPtr |
using | PointIndicesPtr = PointIndices::Ptr |
using | PointIndicesConstPtr = PointIndices::ConstPtr |
Public Member Functions | |
ApproximateProgressiveMorphologicalFilter () | |
Constructor that sets default values for member variables. More... | |
~ApproximateProgressiveMorphologicalFilter () override | |
int | getMaxWindowSize () const |
Get the maximum window size to be used in filtering ground returns. More... | |
void | setMaxWindowSize (int max_window_size) |
Set the maximum window size to be used in filtering ground returns. More... | |
float | getSlope () const |
Get the slope value to be used in computing the height threshold. More... | |
void | setSlope (float slope) |
Set the slope value to be used in computing the height threshold. More... | |
float | getMaxDistance () const |
Get the maximum height above the parameterized ground surface to be considered a ground return. More... | |
void | setMaxDistance (float max_distance) |
Set the maximum height above the parameterized ground surface to be considered a ground return. More... | |
float | getInitialDistance () const |
Get the initial height above the parameterized ground surface to be considered a ground return. More... | |
void | setInitialDistance (float initial_distance) |
Set the initial height above the parameterized ground surface to be considered a ground return. More... | |
float | getCellSize () const |
Get the cell size. More... | |
void | setCellSize (float cell_size) |
Set the cell size. More... | |
float | getBase () const |
Get the base to be used in computing progressive window sizes. More... | |
void | setBase (float base) |
Set the base to be used in computing progressive window sizes. More... | |
bool | getExponential () const |
Get flag indicating whether or not to exponentially grow window sizes? More... | |
void | setExponential (bool exponential) |
Set flag indicating whether or not to exponentially grow window sizes? More... | |
void | setNumberOfThreads (unsigned int nr_threads=0) |
Initialize the scheduler and set the number of threads to use. More... | |
virtual void | extract (Indices &ground) |
This method launches the segmentation algorithm and returns indices of points determined to be ground returns. More... | |
Public Member Functions inherited from pcl::PCLBase< PointT > | |
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 PointT & | operator[] (std::size_t pos) const |
Override PointCloud operator[] to shorten code. More... | |
Protected Attributes | |
int | max_window_size_ {33} |
Maximum window size to be used in filtering ground returns. More... | |
float | slope_ {0.7f} |
Slope value to be used in computing the height threshold. More... | |
float | max_distance_ {10.0f} |
Maximum height above the parameterized ground surface to be considered a ground return. More... | |
float | initial_distance_ {0.15f} |
Initial height above the parameterized ground surface to be considered a ground return. More... | |
float | cell_size_ {1.0f} |
Cell size. More... | |
float | base_ {2.0f} |
Base to be used in computing progressive window sizes. More... | |
bool | exponential_ {true} |
Exponentially grow window sizes? More... | |
unsigned int | threads_ {0} |
Number of threads to be used. More... | |
Protected Attributes inherited from pcl::PCLBase< PointT > | |
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... | |
Additional Inherited Members | |
Protected Member Functions inherited from pcl::PCLBase< PointT > | |
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... | |
Implements the Progressive Morphological Filter for segmentation of ground points.
Description can be found in the article "A Progressive Morphological Filter for Removing Nonground Measurements from Airborne LIDAR Data" by K. Zhang, S. Chen, D. Whitman, M. Shyu, J. Yan, and C. Zhang.
Definition at line 56 of file approximate_progressive_morphological_filter.h.
using pcl::ApproximateProgressiveMorphologicalFilter< PointT >::PointCloud = pcl::PointCloud<PointT> |
Definition at line 60 of file approximate_progressive_morphological_filter.h.
|
default |
Constructor that sets default values for member variables.
|
overridedefault |
|
virtual |
This method launches the segmentation algorithm and returns indices of points determined to be ground returns.
[out] | ground | indices of points determined to be ground returns. |
Definition at line 60 of file approximate_progressive_morphological_filter.hpp.
References pcl::isFinite().
|
inline |
Get the base to be used in computing progressive window sizes.
Definition at line 117 of file approximate_progressive_morphological_filter.h.
|
inline |
Get the cell size.
Definition at line 109 of file approximate_progressive_morphological_filter.h.
|
inline |
Get flag indicating whether or not to exponentially grow window sizes?
Definition at line 125 of file approximate_progressive_morphological_filter.h.
|
inline |
Get the initial height above the parameterized ground surface to be considered a ground return.
Definition at line 101 of file approximate_progressive_morphological_filter.h.
|
inline |
Get the maximum height above the parameterized ground surface to be considered a ground return.
Definition at line 93 of file approximate_progressive_morphological_filter.h.
|
inline |
Get the maximum window size to be used in filtering ground returns.
Definition at line 77 of file approximate_progressive_morphological_filter.h.
|
inline |
Get the slope value to be used in computing the height threshold.
Definition at line 85 of file approximate_progressive_morphological_filter.h.
|
inline |
Set the base to be used in computing progressive window sizes.
Definition at line 121 of file approximate_progressive_morphological_filter.h.
|
inline |
Set the cell size.
Definition at line 113 of file approximate_progressive_morphological_filter.h.
|
inline |
Set flag indicating whether or not to exponentially grow window sizes?
Definition at line 129 of file approximate_progressive_morphological_filter.h.
|
inline |
Set the initial height above the parameterized ground surface to be considered a ground return.
Definition at line 105 of file approximate_progressive_morphological_filter.h.
|
inline |
Set the maximum height above the parameterized ground surface to be considered a ground return.
Definition at line 97 of file approximate_progressive_morphological_filter.h.
|
inline |
Set the maximum window size to be used in filtering ground returns.
Definition at line 81 of file approximate_progressive_morphological_filter.h.
|
inline |
Initialize the scheduler and set the number of threads to use.
nr_threads | the number of hardware threads to use (0 sets the value back to automatic) |
Definition at line 135 of file approximate_progressive_morphological_filter.h.
|
inline |
Set the slope value to be used in computing the height threshold.
Definition at line 89 of file approximate_progressive_morphological_filter.h.
|
protected |
Base to be used in computing progressive window sizes.
Definition at line 162 of file approximate_progressive_morphological_filter.h.
|
protected |
Cell size.
Definition at line 159 of file approximate_progressive_morphological_filter.h.
|
protected |
Exponentially grow window sizes?
Definition at line 165 of file approximate_progressive_morphological_filter.h.
|
protected |
Initial height above the parameterized ground surface to be considered a ground return.
Definition at line 156 of file approximate_progressive_morphological_filter.h.
|
protected |
Maximum height above the parameterized ground surface to be considered a ground return.
Definition at line 153 of file approximate_progressive_morphological_filter.h.
|
protected |
Maximum window size to be used in filtering ground returns.
Definition at line 147 of file approximate_progressive_morphological_filter.h.
|
protected |
Slope value to be used in computing the height threshold.
Definition at line 150 of file approximate_progressive_morphological_filter.h.
|
protected |
Number of threads to be used.
Definition at line 168 of file approximate_progressive_morphological_filter.h.