|
Point Cloud Library (PCL)
1.7.2
|
SampleConsensusModelPerpendicularPlane defines a model for 3D plane segmentation using additional angular constraints. More...
#include <pcl/sample_consensus/sac_model_perpendicular_plane.h>
Inheritance diagram for pcl::SampleConsensusModelPerpendicularPlane< PointT >:Public Member Functions | |
| SampleConsensusModelPerpendicularPlane (const PointCloudConstPtr &cloud, bool random=false) | |
| Constructor for base SampleConsensusModelPerpendicularPlane. | |
| SampleConsensusModelPerpendicularPlane (const PointCloudConstPtr &cloud, const std::vector< int > &indices, bool random=false) | |
| Constructor for base SampleConsensusModelPerpendicularPlane. | |
| virtual | ~SampleConsensusModelPerpendicularPlane () |
| Empty destructor. | |
| void | setAxis (const Eigen::Vector3f &ax) |
| Set the axis along which we need to search for a plane perpendicular to. | |
| Eigen::Vector3f | getAxis () |
| Get the axis along which we need to search for a plane perpendicular to. | |
| void | setEpsAngle (const double ea) |
| Set the angle epsilon (delta) threshold. | |
| double | getEpsAngle () |
| Get the angle epsilon (delta) threshold. | |
| void | selectWithinDistance (const Eigen::VectorXf &model_coefficients, const double threshold, std::vector< int > &inliers) |
| Select all the points which respect the given model coefficients as inliers. | |
| virtual int | countWithinDistance (const Eigen::VectorXf &model_coefficients, const double threshold) |
| Count all the points which respect the given model coefficients as inliers. | |
| void | getDistancesToModel (const Eigen::VectorXf &model_coefficients, std::vector< double > &distances) |
| Compute all distances from the cloud data to a given plane model. | |
| pcl::SacModel | getModelType () const |
| Return an unique id for this model (SACMODEL_PERPENDICULAR_PLANE). | |
Public Member Functions inherited from pcl::SampleConsensusModelPlane< PointT > | |
| SampleConsensusModelPlane (const PointCloudConstPtr &cloud, bool random=false) | |
| Constructor for base SampleConsensusModelPlane. | |
| SampleConsensusModelPlane (const PointCloudConstPtr &cloud, const std::vector< int > &indices, bool random=false) | |
| Constructor for base SampleConsensusModelPlane. | |
| virtual | ~SampleConsensusModelPlane () |
| Empty destructor. | |
| bool | computeModelCoefficients (const std::vector< int > &samples, Eigen::VectorXf &model_coefficients) |
| Check whether the given index samples can form a valid plane model, compute the model coefficients from these samples and store them internally in model_coefficients_. | |
| void | optimizeModelCoefficients (const std::vector< int > &inliers, const Eigen::VectorXf &model_coefficients, Eigen::VectorXf &optimized_coefficients) |
| Recompute the plane coefficients using the given inlier set and return them to the user. | |
| void | projectPoints (const std::vector< int > &inliers, const Eigen::VectorXf &model_coefficients, PointCloud &projected_points, bool copy_data_fields=true) |
| Create a new point cloud with inliers projected onto the plane model. | |
| bool | doSamplesVerifyModel (const std::set< int > &indices, const Eigen::VectorXf &model_coefficients, const double threshold) |
| Verify whether a subset of indices verifies the given plane model coefficients. | |
Public Member Functions inherited from pcl::SampleConsensusModel< PointT > | |
| SampleConsensusModel (const PointCloudConstPtr &cloud, bool random=false) | |
| Constructor for base SampleConsensusModel. | |
| SampleConsensusModel (const PointCloudConstPtr &cloud, const std::vector< int > &indices, bool random=false) | |
| Constructor for base SampleConsensusModel. | |
| virtual | ~SampleConsensusModel () |
| Destructor for base SampleConsensusModel. | |
| virtual void | getSamples (int &iterations, std::vector< int > &samples) |
| Get a set of random data samples and return them as point indices. | |
| virtual void | setInputCloud (const PointCloudConstPtr &cloud) |
| Provide a pointer to the input dataset. | |
| PointCloudConstPtr | getInputCloud () const |
| Get a pointer to the input point cloud dataset. | |
| void | setIndices (const boost::shared_ptr< std::vector< int > > &indices) |
| Provide a pointer to the vector of indices that represents the input data. | |
| void | setIndices (const std::vector< int > &indices) |
| Provide the vector of indices that represents the input data. | |
| boost::shared_ptr< std::vector < int > > | getIndices () const |
| Get a pointer to the vector of indices used. | |
| unsigned int | getSampleSize () const |
| Return the size of a sample from which a model is computed. | |
| void | setRadiusLimits (const double &min_radius, const double &max_radius) |
| Set the minimum and maximum allowable radius limits for the model (applicable to models that estimate a radius) | |
| void | getRadiusLimits (double &min_radius, double &max_radius) |
| Get the minimum and maximum allowable radius limits for the model as set by the user. | |
| void | setSamplesMaxDist (const double &radius, SearchPtr search) |
| Set the maximum distance allowed when drawing random samples. | |
| void | getSamplesMaxDist (double &radius) |
| Get maximum distance allowed when drawing random samples. | |
| double | computeVariance (const std::vector< double > &error_sqr_dists) |
| Compute the variance of the errors to the model. | |
| double | computeVariance () |
| Compute the variance of the errors to the model from the internally estimated vector of distances. | |
Protected Member Functions | |
| bool | isModelValid (const Eigen::VectorXf &model_coefficients) |
| Check whether a model is valid given the user constraints. | |
Protected Attributes | |
| Eigen::Vector3f | axis_ |
| The axis along which we need to search for a plane perpendicular to. | |
| double | eps_angle_ |
| The maximum allowed difference between the plane normal and the given axis. | |
Additional Inherited Members | |
Static Protected Attributes inherited from pcl::SampleConsensusModel< PointT > | |
| static const unsigned int | max_sample_checks_ = 1000 |
| The maximum number of samples to try until we get a good one. | |
SampleConsensusModelPerpendicularPlane defines a model for 3D plane segmentation using additional angular constraints.
The plane must be perpendicular to an user-specified axis (setAxis), up to an user-specified angle threshold (setEpsAngle). The model coefficients are defined as:
Code example for a plane model, perpendicular (within a 15 degrees tolerance) with the Z axis:
Definition at line 71 of file sac_model_perpendicular_plane.h.
| typedef SampleConsensusModelPlane<PointT>::PointCloud pcl::SampleConsensusModelPerpendicularPlane< PointT >::PointCloud |
Definition at line 74 of file sac_model_perpendicular_plane.h.
| typedef SampleConsensusModelPlane<PointT>::PointCloudConstPtr pcl::SampleConsensusModelPerpendicularPlane< PointT >::PointCloudConstPtr |
Definition at line 76 of file sac_model_perpendicular_plane.h.
| typedef SampleConsensusModelPlane<PointT>::PointCloudPtr pcl::SampleConsensusModelPerpendicularPlane< PointT >::PointCloudPtr |
Definition at line 75 of file sac_model_perpendicular_plane.h.
| typedef boost::shared_ptr<SampleConsensusModelPerpendicularPlane> pcl::SampleConsensusModelPerpendicularPlane< PointT >::Ptr |
Definition at line 78 of file sac_model_perpendicular_plane.h.
|
inline |
Constructor for base SampleConsensusModelPerpendicularPlane.
| [in] | cloud | the input point cloud dataset |
| [in] | random | if true set the random seed to the current time, else set to 12345 (default: false) |
Definition at line 84 of file sac_model_perpendicular_plane.h.
|
inline |
Constructor for base SampleConsensusModelPerpendicularPlane.
| [in] | cloud | the input point cloud dataset |
| [in] | indices | a vector of point indices to be used from cloud |
| [in] | random | if true set the random seed to the current time, else set to 12345 (default: false) |
Definition at line 97 of file sac_model_perpendicular_plane.h.
|
inlinevirtual |
Empty destructor.
Definition at line 107 of file sac_model_perpendicular_plane.h.
|
virtual |
Count all the points which respect the given model coefficients as inliers.
| [in] | model_coefficients | the coefficients of a model that we need to compute distances to |
| [in] | threshold | maximum admissible distance threshold for determining the inliers from the outliers |
Reimplemented from pcl::SampleConsensusModelPlane< PointT >.
Definition at line 63 of file sac_model_perpendicular_plane.hpp.
|
inline |
Get the axis along which we need to search for a plane perpendicular to.
Definition at line 117 of file sac_model_perpendicular_plane.h.
References pcl::SampleConsensusModelPerpendicularPlane< PointT >::axis_.
Referenced by pcl::SACSegmentation< PointT >::initSACModel().
|
virtual |
Compute all distances from the cloud data to a given plane model.
| [in] | model_coefficients | the coefficients of a plane model that we need to compute distances to |
| [out] | distances | the resultant estimated distances |
Reimplemented from pcl::SampleConsensusModelPlane< PointT >.
Definition at line 75 of file sac_model_perpendicular_plane.hpp.
|
inline |
Get the angle epsilon (delta) threshold.
Definition at line 128 of file sac_model_perpendicular_plane.h.
References pcl::SampleConsensusModelPerpendicularPlane< PointT >::eps_angle_.
Referenced by pcl::SACSegmentation< PointT >::initSACModel().
|
inlinevirtual |
Return an unique id for this model (SACMODEL_PERPENDICULAR_PLANE).
Reimplemented from pcl::SampleConsensusModelPlane< PointT >.
Definition at line 160 of file sac_model_perpendicular_plane.h.
References pcl::SACMODEL_PERPENDICULAR_PLANE.
|
protectedvirtual |
Check whether a model is valid given the user constraints.
| [in] | model_coefficients | the set of model coefficients |
Reimplemented from pcl::SampleConsensusModelPlane< PointT >.
Definition at line 90 of file sac_model_perpendicular_plane.hpp.
References pcl::getAngle3D().
|
virtual |
Select all the points which respect the given model coefficients as inliers.
| [in] | model_coefficients | the coefficients of a plane model that we need to compute distances to |
| [in] | threshold | a maximum admissible distance threshold for determining the inliers from the outliers |
| [out] | inliers | the resultant model inliers |
Reimplemented from pcl::SampleConsensusModelPlane< PointT >.
Definition at line 48 of file sac_model_perpendicular_plane.hpp.
|
inline |
Set the axis along which we need to search for a plane perpendicular to.
| [in] | ax | the axis along which we need to search for a plane perpendicular to |
Definition at line 113 of file sac_model_perpendicular_plane.h.
References pcl::SampleConsensusModelPerpendicularPlane< PointT >::axis_.
Referenced by pcl::SACSegmentation< PointT >::initSACModel().
|
inline |
Set the angle epsilon (delta) threshold.
| [in] | ea | the maximum allowed difference between the plane normal and the given axis. |
Definition at line 124 of file sac_model_perpendicular_plane.h.
References pcl::SampleConsensusModelPerpendicularPlane< PointT >::eps_angle_.
Referenced by pcl::SACSegmentation< PointT >::initSACModel().
|
protected |
The axis along which we need to search for a plane perpendicular to.
Definition at line 170 of file sac_model_perpendicular_plane.h.
Referenced by pcl::SampleConsensusModelPerpendicularPlane< PointT >::getAxis(), and pcl::SampleConsensusModelPerpendicularPlane< PointT >::setAxis().
|
protected |
The maximum allowed difference between the plane normal and the given axis.
Definition at line 173 of file sac_model_perpendicular_plane.h.
Referenced by pcl::SampleConsensusModelPerpendicularPlane< PointT >::getEpsAngle(), and pcl::SampleConsensusModelPerpendicularPlane< PointT >::setEpsAngle().