|
Point Cloud Library (PCL)
1.6.0
|
SampleConsensusModelParallelPlane defines a model for 3D plane segmentation using additional angular constraints. More...
#include <pcl/sample_consensus/sac_model_parallel_plane.h>


Public Types | |
| typedef SampleConsensusModelPlane < PointT >::PointCloud | PointCloud |
| typedef SampleConsensusModelPlane < PointT >::PointCloudPtr | PointCloudPtr |
| typedef SampleConsensusModelPlane < PointT >::PointCloudConstPtr | PointCloudConstPtr |
| typedef boost::shared_ptr < SampleConsensusModelParallelPlane > | Ptr |
| typedef pcl::search::Search < PointT >::Ptr | SearchPtr |
| typedef boost::shared_ptr < const SampleConsensusModel > | ConstPtr |
Public Member Functions | |
| SampleConsensusModelParallelPlane (const PointCloudConstPtr &cloud) | |
| Constructor for base SampleConsensusModelParallelPlane. | |
| SampleConsensusModelParallelPlane (const PointCloudConstPtr &cloud, const std::vector< int > &indices) | |
| Constructor for base SampleConsensusModelParallelPlane. | |
| 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_PARALLEL_PLANE). | |
| 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. | |
| 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. | |
Friends | |
| class | ProgressiveSampleConsensus< PointT > |
SampleConsensusModelParallelPlane defines a model for 3D plane segmentation using additional angular constraints.
The plane must be parallel to a user-specified axis (setAxis) within an user-specified angle threshold (setEpsAngle).
Code example for a plane model, parallel (within a 15 degrees tolerance) with the Z axis:
SampleConsensusModelParallelPlane<pcl::PointXYZ> model (cloud); model.setAxis (Eigen::Vector3f (0.0, 0.0, 1.0)); model.setEpsAngle (pcl::deg2rad (15));
Definition at line 65 of file sac_model_parallel_plane.h.
typedef boost::shared_ptr<const SampleConsensusModel> pcl::SampleConsensusModel< PointT >::ConstPtr [inherited] |
Definition at line 74 of file sac_model.h.
| typedef SampleConsensusModelPlane<PointT>::PointCloud pcl::SampleConsensusModelParallelPlane< PointT >::PointCloud |
Reimplemented from pcl::SampleConsensusModelPlane< PointT >.
Definition at line 68 of file sac_model_parallel_plane.h.
| typedef SampleConsensusModelPlane<PointT>::PointCloudConstPtr pcl::SampleConsensusModelParallelPlane< PointT >::PointCloudConstPtr |
Reimplemented from pcl::SampleConsensusModelPlane< PointT >.
Definition at line 70 of file sac_model_parallel_plane.h.
| typedef SampleConsensusModelPlane<PointT>::PointCloudPtr pcl::SampleConsensusModelParallelPlane< PointT >::PointCloudPtr |
Reimplemented from pcl::SampleConsensusModelPlane< PointT >.
Definition at line 69 of file sac_model_parallel_plane.h.
| typedef boost::shared_ptr<SampleConsensusModelParallelPlane> pcl::SampleConsensusModelParallelPlane< PointT >::Ptr |
Reimplemented from pcl::SampleConsensusModelPlane< PointT >.
Definition at line 72 of file sac_model_parallel_plane.h.
typedef pcl::search::Search<PointT>::Ptr pcl::SampleConsensusModel< PointT >::SearchPtr [inherited] |
Definition at line 71 of file sac_model.h.
| pcl::SampleConsensusModelParallelPlane< PointT >::SampleConsensusModelParallelPlane | ( | const PointCloudConstPtr & | cloud | ) | [inline] |
Constructor for base SampleConsensusModelParallelPlane.
| [in] | cloud | the input point cloud dataset |
Definition at line 77 of file sac_model_parallel_plane.h.
| pcl::SampleConsensusModelParallelPlane< PointT >::SampleConsensusModelParallelPlane | ( | const PointCloudConstPtr & | cloud, |
| const std::vector< int > & | indices | ||
| ) | [inline] |
Constructor for base SampleConsensusModelParallelPlane.
| [in] | cloud | the input point cloud dataset |
| [in] | indices | a vector of point indices to be used from cloud |
Definition at line 88 of file sac_model_parallel_plane.h.
| bool pcl::SampleConsensusModelPlane< PointT >::computeModelCoefficients | ( | const std::vector< int > & | samples, |
| Eigen::VectorXf & | model_coefficients | ||
| ) | [virtual, inherited] |
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_.
The plane coefficients are: a, b, c, d (ax+by+cz+d=0)
| [in] | samples | the point indices found as possible good candidates for creating a valid model |
| [out] | model_coefficients | the resultant model coefficients |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 65 of file sac_model_plane.hpp.
| int pcl::SampleConsensusModelParallelPlane< PointT >::countWithinDistance | ( | const Eigen::VectorXf & | model_coefficients, |
| const double | threshold | ||
| ) | [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 60 of file sac_model_parallel_plane.hpp.
| bool pcl::SampleConsensusModelPlane< PointT >::doSamplesVerifyModel | ( | const std::set< int > & | indices, |
| const Eigen::VectorXf & | model_coefficients, | ||
| const double | threshold | ||
| ) | [virtual, inherited] |
Verify whether a subset of indices verifies the given plane model coefficients.
| [in] | indices | the data indices that need to be tested against the plane model |
| [in] | model_coefficients | the plane model coefficients |
| [in] | threshold | a maximum admissible distance threshold for determining the inliers from the outliers |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 329 of file sac_model_plane.hpp.
| Eigen::Vector3f pcl::SampleConsensusModelParallelPlane< PointT >::getAxis | ( | ) | [inline] |
Get the axis along which we need to search for a plane perpendicular to.
Definition at line 103 of file sac_model_parallel_plane.h.
| void pcl::SampleConsensusModelParallelPlane< PointT >::getDistancesToModel | ( | const Eigen::VectorXf & | model_coefficients, |
| std::vector< double > & | distances | ||
| ) | [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 72 of file sac_model_parallel_plane.hpp.
| double pcl::SampleConsensusModelParallelPlane< PointT >::getEpsAngle | ( | ) | [inline] |
Get the angle epsilon (delta) threshold.
Definition at line 114 of file sac_model_parallel_plane.h.
| boost::shared_ptr<std::vector<int> > pcl::SampleConsensusModel< PointT >::getIndices | ( | ) | const [inline, inherited] |
Get a pointer to the vector of indices used.
Definition at line 327 of file sac_model.h.
| PointCloudConstPtr pcl::SampleConsensusModel< PointT >::getInputCloud | ( | ) | const [inline, inherited] |
Get a pointer to the input point cloud dataset.
Definition at line 303 of file sac_model.h.
| pcl::SacModel pcl::SampleConsensusModelParallelPlane< PointT >::getModelType | ( | ) | const [inline, virtual] |
Return an unique id for this model (SACMODEL_PARALLEL_PLANE).
Reimplemented from pcl::SampleConsensusModelPlane< PointT >.
Definition at line 146 of file sac_model_parallel_plane.h.
| void pcl::SampleConsensusModel< PointT >::getRadiusLimits | ( | double & | min_radius, |
| double & | max_radius | ||
| ) | [inline, inherited] |
Get the minimum and maximum allowable radius limits for the model as set by the user.
| [out] | min_radius | the resultant minimum radius model |
| [out] | max_radius | the resultant maximum radius model |
Definition at line 363 of file sac_model.h.
| void pcl::SampleConsensusModel< PointT >::getSamples | ( | int & | iterations, |
| std::vector< int > & | samples | ||
| ) | [inline, inherited] |
Get a set of random data samples and return them as point indices.
Pure virtual.
| [out] | iterations | the internal number of iterations used by SAC methods |
| [out] | samples | the resultant model samples |
Definition at line 163 of file sac_model.h.
| unsigned int pcl::SampleConsensusModel< PointT >::getSampleSize | ( | ) | const [inline, inherited] |
Return the size of a sample from which a model is computed.
Definition at line 335 of file sac_model.h.
| void pcl::SampleConsensusModel< PointT >::getSamplesMaxDist | ( | double & | radius | ) | [inline, inherited] |
Get maximum distance allowed when drawing random samples.
| [out] | radius | the maximum distance (L2 norm) |
Definition at line 384 of file sac_model.h.
| void pcl::SampleConsensusModelPlane< PointT >::optimizeModelCoefficients | ( | const std::vector< int > & | inliers, |
| const Eigen::VectorXf & | model_coefficients, | ||
| Eigen::VectorXf & | optimized_coefficients | ||
| ) | [virtual, inherited] |
Recompute the plane coefficients using the given inlier set and return them to the user.
| [in] | inliers | the data inliers found as supporting the model |
| [in] | model_coefficients | the initial guess for the model coefficients |
| [out] | optimized_coefficients | the resultant recomputed coefficients after non-linear optimization |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 202 of file sac_model_plane.hpp.
| void pcl::SampleConsensusModelPlane< PointT >::projectPoints | ( | const std::vector< int > & | inliers, |
| const Eigen::VectorXf & | model_coefficients, | ||
| PointCloud & | projected_points, | ||
| bool | copy_data_fields = true |
||
| ) | [virtual, inherited] |
Create a new point cloud with inliers projected onto the plane model.
| [in] | inliers | the data inliers that we want to project on the plane model |
| [in] | model_coefficients | the *normalized* coefficients of a plane model |
| [out] | projected_points | the resultant projected points |
| [in] | copy_data_fields | set to true if we need to copy the other data fields |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 245 of file sac_model_plane.hpp.
| void pcl::SampleConsensusModelParallelPlane< PointT >::selectWithinDistance | ( | const Eigen::VectorXf & | model_coefficients, |
| const double | threshold, | ||
| std::vector< int > & | inliers | ||
| ) | [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 45 of file sac_model_parallel_plane.hpp.
| void pcl::SampleConsensusModelParallelPlane< PointT >::setAxis | ( | const Eigen::Vector3f & | ax | ) | [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 99 of file sac_model_parallel_plane.h.
| void pcl::SampleConsensusModelParallelPlane< PointT >::setEpsAngle | ( | const double | ea | ) | [inline] |
Set the angle epsilon (delta) threshold.
| [in] | ea | the maximum allowed difference between the plane normal and the given axis. |
Definition at line 110 of file sac_model_parallel_plane.h.
| void pcl::SampleConsensusModel< PointT >::setIndices | ( | const boost::shared_ptr< std::vector< int > > & | indices | ) | [inline, inherited] |
Provide a pointer to the vector of indices that represents the input data.
| [in] | indices | a pointer to the vector of indices that represents the input data. |
Definition at line 309 of file sac_model.h.
| void pcl::SampleConsensusModel< PointT >::setIndices | ( | const std::vector< int > & | indices | ) | [inline, inherited] |
Provide the vector of indices that represents the input data.
| [out] | indices | the vector of indices that represents the input data. |
Definition at line 319 of file sac_model.h.
| virtual void pcl::SampleConsensusModel< PointT >::setInputCloud | ( | const PointCloudConstPtr & | cloud | ) | [inline, virtual, inherited] |
Provide a pointer to the input dataset.
| [in] | cloud | the const boost shared pointer to a PointCloud message |
Reimplemented in pcl::SampleConsensusModelRegistration< PointT >.
Definition at line 286 of file sac_model.h.
| void pcl::SampleConsensusModel< PointT >::setRadiusLimits | ( | const double & | min_radius, |
| const double & | max_radius | ||
| ) | [inline, inherited] |
Set the minimum and maximum allowable radius limits for the model (applicable to models that estimate a radius)
| [in] | min_radius | the minimum radius model |
| [in] | max_radius | the maximum radius model |
Definition at line 350 of file sac_model.h.
| void pcl::SampleConsensusModel< PointT >::setSamplesMaxDist | ( | const double & | radius, |
| SearchPtr | search | ||
| ) | [inline, inherited] |
Set the maximum distance allowed when drawing random samples.
| [in] | radius | the maximum distance (L2 norm) |
Definition at line 373 of file sac_model.h.
friend class ProgressiveSampleConsensus< PointT > [friend, inherited] |
Definition at line 389 of file sac_model.h.
1.7.6.1