Point Cloud Library (PCL)
1.14.1-dev
|
RadiusOutlierRemoval filters points in a cloud based on the number of neighbors they have. More...
#include <pcl/filters/radius_outlier_removal.h>
Public Types | |
using | Ptr = shared_ptr< RadiusOutlierRemoval< PointT > > |
using | ConstPtr = shared_ptr< const RadiusOutlierRemoval< PointT > > |
Public Types inherited from pcl::FilterIndices< PointT > | |
using | PointCloud = pcl::PointCloud< PointT > |
using | Ptr = shared_ptr< FilterIndices< PointT > > |
using | ConstPtr = shared_ptr< const FilterIndices< PointT > > |
Public Types inherited from pcl::Filter< PointT > | |
using | Ptr = shared_ptr< Filter< PointT > > |
using | ConstPtr = shared_ptr< const Filter< PointT > > |
using | PointCloud = pcl::PointCloud< PointT > |
using | PointCloudPtr = typename PointCloud::Ptr |
using | PointCloudConstPtr = typename PointCloud::ConstPtr |
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 | |
RadiusOutlierRemoval (bool extract_removed_indices=false) | |
Constructor. More... | |
void | setRadiusSearch (double radius) |
Set the radius of the sphere that will determine which points are neighbors. More... | |
double | getRadiusSearch () |
Get the radius of the sphere that will determine which points are neighbors. More... | |
void | setMinNeighborsInRadius (int min_pts) |
Set the number of neighbors that need to be present in order to be classified as an inlier. More... | |
int | getMinNeighborsInRadius () |
Get the number of neighbors that need to be present in order to be classified as an inlier. More... | |
void | setSearchMethod (const SearcherPtr &searcher) |
Provide a pointer to the search object. More... | |
void | setNumberOfThreads (unsigned int nr_threads=0) |
Set the number of threads to use. More... | |
Public Member Functions inherited from pcl::FilterIndices< PointT > | |
FilterIndices (bool extract_removed_indices=false) | |
Constructor. More... | |
void | filter (Indices &indices) |
Calls the filtering method and returns the filtered point cloud indices. More... | |
void | setNegative (bool negative) |
Set whether the regular conditions for points filtering should apply, or the inverted conditions. More... | |
bool | getNegative () const |
Get whether the regular conditions for points filtering should apply, or the inverted conditions. More... | |
void | setKeepOrganized (bool keep_organized) |
Set whether the filtered points should be kept and set to the value given through setUserFilterValue (default: NaN), or removed from the PointCloud, thus potentially breaking its organized structure. More... | |
bool | getKeepOrganized () const |
Get whether the filtered points should be kept and set to the value given through setUserFilterValue (default = NaN), or removed from the PointCloud, thus potentially breaking its organized structure. More... | |
void | setUserFilterValue (float value) |
Provide a value that the filtered points should be set to instead of removing them. More... | |
Public Member Functions inherited from pcl::Filter< PointT > | |
Filter (bool extract_removed_indices=false) | |
Empty constructor. More... | |
IndicesConstPtr const | getRemovedIndices () const |
Get the point indices being removed. More... | |
void | getRemovedIndices (PointIndices &pi) |
Get the point indices being removed. More... | |
void | filter (PointCloud &output) |
Calls the filtering method and returns the filtered dataset in output. 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 Types | |
using | PointCloud = typename FilterIndices< PointT >::PointCloud |
using | PointCloudPtr = typename PointCloud::Ptr |
using | PointCloudConstPtr = typename PointCloud::ConstPtr |
using | SearcherPtr = typename pcl::search::Search< PointT >::Ptr |
Protected Member Functions | |
void | applyFilter (Indices &indices) override |
Filtered results are indexed by an indices array. More... | |
void | applyFilterIndices (Indices &indices) |
Filtered results are indexed by an indices array. More... | |
Protected Member Functions inherited from pcl::FilterIndices< PointT > | |
void | applyFilter (PointCloud &output) override |
Abstract filter method for point cloud. More... | |
Protected Member Functions inherited from pcl::Filter< PointT > | |
const std::string & | getClassName () const |
Get a string representation of the name of this class. More... | |
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... | |
Additional Inherited Members | |
Protected Attributes inherited from pcl::FilterIndices< PointT > | |
bool | negative_ {false} |
False = normal filter behavior (default), true = inverted behavior. More... | |
bool | keep_organized_ {false} |
False = remove points (default), true = redefine points, keep structure. More... | |
float | user_filter_value_ |
The user given value that the filtered point dimensions should be set to (default = NaN). More... | |
Protected Attributes inherited from pcl::Filter< PointT > | |
IndicesPtr | removed_indices_ |
Indices of the points that are removed. More... | |
std::string | filter_name_ |
The filter name. More... | |
bool | extract_removed_indices_ |
Set to true if we want to return the indices of the removed points. 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... | |
RadiusOutlierRemoval filters points in a cloud based on the number of neighbors they have.
Iterates through the entire input once, and for each point, retrieves the number of neighbors within a certain radius. The point will be considered an outlier if it has too few neighbors, as determined by setMinNeighborsInRadius(). The radius can be changed using setRadiusSearch().
The neighbors found for each query point will be found amongst ALL points of setInputCloud(), not just those indexed by setIndices(). The setIndices() method only indexes the points that will be iterated through as search query points.
Usage example:
Definition at line 72 of file radius_outlier_removal.h.
using pcl::RadiusOutlierRemoval< PointT >::ConstPtr = shared_ptr<const RadiusOutlierRemoval<PointT> > |
Definition at line 83 of file radius_outlier_removal.h.
|
protected |
Definition at line 75 of file radius_outlier_removal.h.
|
protected |
Definition at line 77 of file radius_outlier_removal.h.
|
protected |
Definition at line 76 of file radius_outlier_removal.h.
using pcl::RadiusOutlierRemoval< PointT >::Ptr = shared_ptr<RadiusOutlierRemoval<PointT> > |
Definition at line 82 of file radius_outlier_removal.h.
|
protected |
Definition at line 78 of file radius_outlier_removal.h.
|
inline |
Constructor.
[in] | extract_removed_indices | Set to true if you want to be able to extract the indices of points being removed (default = false). |
Definition at line 89 of file radius_outlier_removal.h.
References pcl::Filter< PointT >::filter_name_.
|
inlineoverrideprotectedvirtual |
Filtered results are indexed by an indices array.
[out] | indices | The resultant indices. |
Implements pcl::FilterIndices< PointT >.
Definition at line 179 of file radius_outlier_removal.h.
References pcl::RadiusOutlierRemoval< PointT >::applyFilterIndices().
|
protected |
Filtered results are indexed by an indices array.
[out] | indices | The resultant indices. |
Definition at line 49 of file radius_outlier_removal.hpp.
References pcl::isXYZFinite().
Referenced by pcl::RadiusOutlierRemoval< PointT >::applyFilter().
|
inline |
Get the number of neighbors that need to be present in order to be classified as an inlier.
The number of points within setRadiusSearch() from the query point will need to be equal or greater than this number in order to be classified as an inlier point (i.e. will not be filtered).
Definition at line 135 of file radius_outlier_removal.h.
|
inline |
Get the radius of the sphere that will determine which points are neighbors.
The number of points within this distance from the query point will need to be equal or greater than setMinNeighborsInRadius() in order to be classified as an inlier point (i.e. will not be filtered).
Definition at line 113 of file radius_outlier_removal.h.
|
inline |
Set the number of neighbors that need to be present in order to be classified as an inlier.
The number of points within setRadiusSearch() from the query point will need to be equal or greater than this number in order to be classified as an inlier point (i.e. will not be filtered).
min_pts | The minimum number of neighbors (default = 1). |
Definition at line 124 of file radius_outlier_removal.h.
|
inline |
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 152 of file radius_outlier_removal.h.
|
inline |
Set the radius of the sphere that will determine which points are neighbors.
The number of points within this distance from the query point will need to be equal or greater than setMinNeighborsInRadius() in order to be classified as an inlier point (i.e. will not be filtered).
[in] | radius | The radius of the sphere for nearest neighbor searching. |
Definition at line 102 of file radius_outlier_removal.h.
|
inline |
Provide a pointer to the search object.
Calling this is optional. If not called, the search method will be chosen automatically.
[in] | searcher | a pointer to the spatial search object. |
Definition at line 145 of file radius_outlier_removal.h.