W3cubDocs

/PointCloudLibrary

Implementation of the median filter. More...

#include <pcl/filters/median_filter.h>

Public Member Functions

MedianFilter ()
Empty constructor. More...
void setWindowSize (int window_size)
Set the window size of the filter. More...
int getWindowSize () const
Get the window size of the filter. More...
void setMaxAllowedMovement (float max_allowed_movement)
Set the largest value one dexel is allowed to move. More...
float getMaxAllowedMovement () const
Get the maximum distance one point is allowed to move along the z-axis. More...
void applyFilter (PointCloud &output) override
Filter the input data and store the results into output. More...
- Public Member Functions inherited from pcl::Filter< PointT >
Filter (bool extract_removed_indices=false)
Empty constructor. More...
const IndicesConstPtr 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...
const PointCloudConstPtr 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...
const IndicesConstPtr 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 window_size_
float max_allowed_movement_
- 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...

Additional Inherited Members

- 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
- 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...

Detailed Description

template<typename PointT>
class pcl::MedianFilter< PointT >

Implementation of the median filter.

The median filter is one of the simplest and wide-spread image processing filters. It is known to perform well with "shot"/impulse noise (some individual pixels having extreme values), it does not reduce contrast across steps in the function (as compared to filters based on averaging), and it is robust to outliers. Furthermore, it is simple to implement and efficient, as it requires a single pass over the image. It consists of a moving window of fixed size that replaces the pixel in the center with the median inside the window.

Note
This algorithm filters only the depth (z-component) of organized and untransformed (i.e., in camera coordinates) point clouds. An error will be outputted if an unorganized cloud is given to the class instance.
Author
Alexandru E. Ichim

Definition at line 60 of file median_filter.h.

Constructor & Destructor Documentation

MedianFilter()

template<typename PointT >
pcl::MedianFilter< PointT >::MedianFilter ( )
inline

Empty constructor.

Definition at line 67 of file median_filter.h.

Member Function Documentation

applyFilter()

template<typename PointT >
void pcl::MedianFilter< PointT >::applyFilter ( PointCloud & output )
overridevirtual

Filter the input data and store the results into output.

Parameters
[out] output the result point cloud

Implements pcl::Filter< PointT >.

Definition at line 46 of file median_filter.hpp.

References pcl::copyPointCloud(), pcl::PointCloud< PointT >::height, pcl::isFinite(), and pcl::PointCloud< PointT >::width.

getMaxAllowedMovement()

template<typename PointT >
float pcl::MedianFilter< PointT >::getMaxAllowedMovement ( ) const
inline

Get the maximum distance one point is allowed to move along the z-axis.

Returns
the maximum distance a dexel is allowed to move

Definition at line 97 of file median_filter.h.

References pcl::MedianFilter< PointT >::max_allowed_movement_.

getWindowSize()

template<typename PointT >
int pcl::MedianFilter< PointT >::getWindowSize ( ) const
inline

Get the window size of the filter.

Returns
the window size of the filter

Definition at line 83 of file median_filter.h.

References pcl::MedianFilter< PointT >::window_size_.

setMaxAllowedMovement()

template<typename PointT >
void pcl::MedianFilter< PointT >::setMaxAllowedMovement ( float max_allowed_movement )
inline

Set the largest value one dexel is allowed to move.

Parameters
[in] max_allowed_movement maximum value a dexel is allowed to move during filtering

Definition at line 90 of file median_filter.h.

References pcl::MedianFilter< PointT >::max_allowed_movement_.

setWindowSize()

template<typename PointT >
void pcl::MedianFilter< PointT >::setWindowSize ( int window_size )
inline

Set the window size of the filter.

Parameters
[in] window_size the new window size

Definition at line 76 of file median_filter.h.

References pcl::MedianFilter< PointT >::window_size_.

Member Data Documentation

max_allowed_movement_

template<typename PointT >
float pcl::MedianFilter< PointT >::max_allowed_movement_
protected

window_size_

template<typename PointT >
int pcl::MedianFilter< PointT >::window_size_
protected

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

© 2009–2012, Willow Garage, Inc.
© 2012–, Open Perception, Inc.
Licensed under the BSD License.
https://pointclouds.org/documentation/classpcl_1_1_median_filter.html