SampleConsensusModelCylinder defines a model for 3D cylinder segmentation. More...
#include <pcl/sample_consensus/sac_model_cylinder.h>


Classes | |
| struct | OptimizationFunctor |
| Functor for the optimization function. | |
Public Types | |
| typedef SampleConsensusModel < PointT >::PointCloud | PointCloud |
| typedef SampleConsensusModel < PointT >::PointCloudPtr | PointCloudPtr |
| typedef SampleConsensusModel < PointT >::PointCloudConstPtr | PointCloudConstPtr |
| typedef boost::shared_ptr < SampleConsensusModelCylinder > | Ptr |
Public Member Functions | |
| SampleConsensusModelCylinder (const PointCloudConstPtr &cloud, bool random=false) | |
| Constructor for base SampleConsensusModelCylinder. | |
| SampleConsensusModelCylinder (const PointCloudConstPtr &cloud, const std::vector< int > &indices, bool random=false) | |
| Constructor for base SampleConsensusModelCylinder. | |
| SampleConsensusModelCylinder (const SampleConsensusModelCylinder &source) | |
| Copy constructor. | |
| virtual | ~SampleConsensusModelCylinder () |
| Empty destructor. | |
| SampleConsensusModelCylinder & | operator= (const SampleConsensusModelCylinder &source) |
| Copy constructor. | |
| void | setEpsAngle (const double ea) |
| Set the angle epsilon (delta) threshold. | |
| double | getEpsAngle () |
| Get the angle epsilon (delta) threshold. | |
| void | setAxis (const Eigen::Vector3f &ax) |
| Set the axis along which we need to search for a cylinder direction. | |
| Eigen::Vector3f | getAxis () |
| Get the axis along which we need to search for a cylinder direction. | |
| bool | computeModelCoefficients (const std::vector< int > &samples, Eigen::VectorXf &model_coefficients) |
| Check whether the given index samples can form a valid cylinder model, compute the model coefficients from these samples and store them in model_coefficients. | |
| void | getDistancesToModel (const Eigen::VectorXf &model_coefficients, std::vector< double > &distances) |
| Compute all distances from the cloud data to a given cylinder model. | |
| 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 | optimizeModelCoefficients (const std::vector< int > &inliers, const Eigen::VectorXf &model_coefficients, Eigen::VectorXf &optimized_coefficients) |
| Recompute the cylinder 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 cylinder 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 cylinder model coefficients. | |
| pcl::SacModel | getModelType () const |
| Return an unique id for this model (SACMODEL_CYLINDER). | |
Protected Member Functions | |
| double | pointToLineDistance (const Eigen::Vector4f &pt, const Eigen::VectorXf &model_coefficients) |
| Get the distance from a point to a line (represented by a point and a direction). | |
| void | projectPointToLine (const Eigen::Vector4f &pt, const Eigen::Vector4f &line_pt, const Eigen::Vector4f &line_dir, Eigen::Vector4f &pt_proj) |
| Project a point onto a line given by a point and a direction vector. | |
| void | projectPointToCylinder (const Eigen::Vector4f &pt, const Eigen::VectorXf &model_coefficients, Eigen::Vector4f &pt_proj) |
| Project a point onto a cylinder given by its model coefficients (point_on_axis, axis_direction, cylinder_radius_R). | |
| std::string | getName () const |
| Get a string representation of the name of this class. | |
| bool | isModelValid (const Eigen::VectorXf &model_coefficients) |
| Check whether a model is valid given the user constraints. | |
| bool | isSampleGood (const std::vector< int > &samples) const |
| Check if a sample of indices results in a good sample of points indices. | |
SampleConsensusModelCylinder defines a model for 3D cylinder segmentation.
The model coefficients are defined as:
Definition at line 65 of file sac_model_cylinder.h.
| typedef SampleConsensusModel<PointT>::PointCloud pcl::SampleConsensusModelCylinder< PointT, PointNT >::PointCloud |
Reimplemented from pcl::SampleConsensusModel< PointT >.
Definition at line 76 of file sac_model_cylinder.h.
| typedef SampleConsensusModel<PointT>::PointCloudConstPtr pcl::SampleConsensusModelCylinder< PointT, PointNT >::PointCloudConstPtr |
Reimplemented from pcl::SampleConsensusModel< PointT >.
Definition at line 78 of file sac_model_cylinder.h.
| typedef SampleConsensusModel<PointT>::PointCloudPtr pcl::SampleConsensusModelCylinder< PointT, PointNT >::PointCloudPtr |
Reimplemented from pcl::SampleConsensusModel< PointT >.
Definition at line 77 of file sac_model_cylinder.h.
| typedef boost::shared_ptr<SampleConsensusModelCylinder> pcl::SampleConsensusModelCylinder< PointT, PointNT >::Ptr |
Reimplemented from pcl::SampleConsensusModel< PointT >.
Definition at line 80 of file sac_model_cylinder.h.
| pcl::SampleConsensusModelCylinder< PointT, PointNT >::SampleConsensusModelCylinder | ( | const PointCloudConstPtr & | cloud, | |
| bool | random = false | |||
| ) | [inline] |
Constructor for base SampleConsensusModelCylinder.
| [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 86 of file sac_model_cylinder.h.
| pcl::SampleConsensusModelCylinder< PointT, PointNT >::SampleConsensusModelCylinder | ( | const PointCloudConstPtr & | cloud, | |
| const std::vector< int > & | indices, | |||
| bool | random = false | |||
| ) | [inline] |
Constructor for base SampleConsensusModelCylinder.
| [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 100 of file sac_model_cylinder.h.
| pcl::SampleConsensusModelCylinder< PointT, PointNT >::SampleConsensusModelCylinder | ( | const SampleConsensusModelCylinder< PointT, PointNT > & | source | ) | [inline] |
Copy constructor.
| [in] | source | the model to copy into this |
Definition at line 114 of file sac_model_cylinder.h.
| virtual pcl::SampleConsensusModelCylinder< PointT, PointNT >::~SampleConsensusModelCylinder | ( | ) | [inline, virtual] |
Empty destructor.
Definition at line 125 of file sac_model_cylinder.h.
| bool pcl::SampleConsensusModelCylinder< PointT, PointNT >::computeModelCoefficients | ( | const std::vector< int > & | samples, | |
| Eigen::VectorXf & | model_coefficients | |||
| ) | [inline, virtual] |
Check whether the given index samples can form a valid cylinder model, compute the model coefficients from these samples and store them in model_coefficients.
The cylinder coefficients are: point_on_axis, axis_direction, cylinder_radius_R
| [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 57 of file sac_model_cylinder.hpp.
References pcl::SampleConsensusModel< PointT >::input_, pcl::SampleConsensusModelFromNormals< PointT, PointNT >::normals_, pcl::SampleConsensusModel< PointT >::radius_max_, pcl::SampleConsensusModel< PointT >::radius_min_, and pcl::sqrPointToLineDistance().
| int pcl::SampleConsensusModelCylinder< PointT, PointNT >::countWithinDistance | ( | const Eigen::VectorXf & | model_coefficients, | |
| const double | threshold | |||
| ) | [inline, 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 |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 226 of file sac_model_cylinder.hpp.
References pcl::getAngle3D(), pcl::SampleConsensusModel< PointT >::indices_, pcl::SampleConsensusModel< PointT >::input_, pcl::SampleConsensusModelCylinder< PointT, PointNT >::isModelValid(), pcl::SampleConsensusModelFromNormals< PointT, PointNT >::normal_distance_weight_, pcl::SampleConsensusModelFromNormals< PointT, PointNT >::normals_, and pcl::SampleConsensusModelCylinder< PointT, PointNT >::pointToLineDistance().
| bool pcl::SampleConsensusModelCylinder< PointT, PointNT >::doSamplesVerifyModel | ( | const std::set< int > & | indices, | |
| const Eigen::VectorXf & | model_coefficients, | |||
| const double | threshold | |||
| ) | [inline, virtual] |
Verify whether a subset of indices verifies the given cylinder model coefficients.
| [in] | indices | the data indices that need to be tested against the cylinder model |
| [in] | model_coefficients | the cylinder model coefficients |
| [in] | threshold | a maximum admissible distance threshold for determining the inliers from the outliers |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 391 of file sac_model_cylinder.hpp.
References pcl::SampleConsensusModel< PointT >::input_, and pcl::SampleConsensusModelCylinder< PointT, PointNT >::pointToLineDistance().
| Eigen::Vector3f pcl::SampleConsensusModelCylinder< PointT, PointNT >::getAxis | ( | ) | [inline] |
Get the axis along which we need to search for a cylinder direction.
Definition at line 158 of file sac_model_cylinder.h.
Referenced by pcl::SACSegmentationFromNormals< PointT, PointNT >::initSACModel().
| void pcl::SampleConsensusModelCylinder< PointT, PointNT >::getDistancesToModel | ( | const Eigen::VectorXf & | model_coefficients, | |
| std::vector< double > & | distances | |||
| ) | [inline, virtual] |
Compute all distances from the cloud data to a given cylinder model.
| [in] | model_coefficients | the coefficients of a cylinder model that we need to compute distances to |
| [out] | distances | the resultant estimated distances |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 131 of file sac_model_cylinder.hpp.
References pcl::getAngle3D(), pcl::SampleConsensusModel< PointT >::indices_, pcl::SampleConsensusModel< PointT >::input_, pcl::SampleConsensusModelCylinder< PointT, PointNT >::isModelValid(), pcl::SampleConsensusModelFromNormals< PointT, PointNT >::normal_distance_weight_, pcl::SampleConsensusModelFromNormals< PointT, PointNT >::normals_, and pcl::SampleConsensusModelCylinder< PointT, PointNT >::pointToLineDistance().
| double pcl::SampleConsensusModelCylinder< PointT, PointNT >::getEpsAngle | ( | ) | [inline] |
Get the angle epsilon (delta) threshold.
Definition at line 148 of file sac_model_cylinder.h.
Referenced by pcl::SACSegmentationFromNormals< PointT, PointNT >::initSACModel().
| pcl::SacModel pcl::SampleConsensusModelCylinder< PointT, PointNT >::getModelType | ( | ) | const [inline, virtual] |
Return an unique id for this model (SACMODEL_CYLINDER).
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 234 of file sac_model_cylinder.h.
References pcl::SACMODEL_CYLINDER.
| std::string pcl::SampleConsensusModelCylinder< PointT, PointNT >::getName | ( | ) | const [inline, protected] |
Get a string representation of the name of this class.
Definition at line 274 of file sac_model_cylinder.h.
| bool pcl::SampleConsensusModelCylinder< PointT, PointNT >::isModelValid | ( | const Eigen::VectorXf & | model_coefficients | ) | [inline, protected, virtual] |
Check whether a model is valid given the user constraints.
| [in] | model_coefficients | the set of model coefficients |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 444 of file sac_model_cylinder.hpp.
References pcl::getAngle3D(), pcl::SampleConsensusModel< PointT >::radius_max_, and pcl::SampleConsensusModel< PointT >::radius_min_.
Referenced by pcl::SampleConsensusModelCylinder< PointT, PointNT >::countWithinDistance(), pcl::SampleConsensusModelCylinder< PointT, PointNT >::getDistancesToModel(), and pcl::SampleConsensusModelCylinder< PointT, PointNT >::selectWithinDistance().
| bool pcl::SampleConsensusModelCylinder< PointT, PointNT >::isSampleGood | ( | const std::vector< int > & | samples | ) | const [inline, protected, virtual] |
Check if a sample of indices results in a good sample of points indices.
Pure virtual.
| [in] | samples | the resultant index samples |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 50 of file sac_model_cylinder.hpp.
| SampleConsensusModelCylinder& pcl::SampleConsensusModelCylinder< PointT, PointNT >::operator= | ( | const SampleConsensusModelCylinder< PointT, PointNT > & | source | ) | [inline] |
Copy constructor.
| [in] | source | the model to copy into this |
Definition at line 131 of file sac_model_cylinder.h.
| void pcl::SampleConsensusModelCylinder< PointT, PointNT >::optimizeModelCoefficients | ( | const std::vector< int > & | inliers, | |
| const Eigen::VectorXf & | model_coefficients, | |||
| Eigen::VectorXf & | optimized_coefficients | |||
| ) | [inline, virtual] |
Recompute the cylinder 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 optimization |
| [out] | optimized_coefficients | the resultant recomputed coefficients after non-linear optimization |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 266 of file sac_model_cylinder.hpp.
| double pcl::SampleConsensusModelCylinder< PointT, PointNT >::pointToLineDistance | ( | const Eigen::Vector4f & | pt, | |
| const Eigen::VectorXf & | model_coefficients | |||
| ) | [inline, protected] |
Get the distance from a point to a line (represented by a point and a direction).
| [in] | pt | a point |
| [in] | model_coefficients | the line coefficients (a point on the line, line direction) |
Definition at line 416 of file sac_model_cylinder.hpp.
References pcl::sqrPointToLineDistance().
Referenced by pcl::SampleConsensusModelCylinder< PointT, PointNT >::countWithinDistance(), pcl::SampleConsensusModelCylinder< PointT, PointNT >::doSamplesVerifyModel(), pcl::SampleConsensusModelCylinder< PointT, PointNT >::getDistancesToModel(), and pcl::SampleConsensusModelCylinder< PointT, PointNT >::selectWithinDistance().
| void pcl::SampleConsensusModelCylinder< PointT, PointNT >::projectPoints | ( | const std::vector< int > & | inliers, | |
| const Eigen::VectorXf & | model_coefficients, | |||
| PointCloud & | projected_points, | |||
| bool | copy_data_fields = true | |||
| ) | [inline, virtual] |
Create a new point cloud with inliers projected onto the cylinder model.
| [in] | inliers | the data inliers that we want to project on the cylinder model |
| [in] | model_coefficients | the coefficients of a cylinder 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 305 of file sac_model_cylinder.hpp.
References pcl::PointCloud< PointT >::header, pcl::PointCloud< PointT >::height, pcl::SampleConsensusModel< PointT >::input_, pcl::PointCloud< PointT >::is_dense, pcl::PointCloud< PointT >::points, and pcl::PointCloud< PointT >::width.
| void pcl::SampleConsensusModelCylinder< PointT, PointNT >::projectPointToCylinder | ( | const Eigen::Vector4f & | pt, | |
| const Eigen::VectorXf & | model_coefficients, | |||
| Eigen::Vector4f & | pt_proj | |||
| ) | [inline, protected] |
Project a point onto a cylinder given by its model coefficients (point_on_axis, axis_direction, cylinder_radius_R).
| [in] | pt | the input point to project |
| [in] | model_coefficients | the coefficients of the cylinder (point_on_axis, axis_direction, cylinder_radius_R) |
| [out] | pt_proj | the resultant projected point |
Definition at line 426 of file sac_model_cylinder.hpp.
| void pcl::SampleConsensusModelCylinder< PointT, PointNT >::projectPointToLine | ( | const Eigen::Vector4f & | pt, | |
| const Eigen::Vector4f & | line_pt, | |||
| const Eigen::Vector4f & | line_dir, | |||
| Eigen::Vector4f & | pt_proj | |||
| ) | [inline, protected] |
Project a point onto a line given by a point and a direction vector.
| [in] | pt | the input point to project |
| [in] | line_pt | the point on the line (make sure that line_pt[3] = 0 as there are no internal checks!) |
| [in] | line_dir | the direction of the line (make sure that line_dir[3] = 0 as there are no internal checks!) |
| [out] | pt_proj | the resultant projected point |
Definition at line 251 of file sac_model_cylinder.h.
| void pcl::SampleConsensusModelCylinder< PointT, PointNT >::selectWithinDistance | ( | const Eigen::VectorXf & | model_coefficients, | |
| const double | threshold, | |||
| std::vector< int > & | inliers | |||
| ) | [inline, virtual] |
Select all the points which respect the given model coefficients as inliers.
| [in] | model_coefficients | the coefficients of a cylinder 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 |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 174 of file sac_model_cylinder.hpp.
References pcl::SampleConsensusModel< PointT >::error_sqr_dists_, pcl::getAngle3D(), pcl::SampleConsensusModel< PointT >::indices_, pcl::SampleConsensusModel< PointT >::input_, pcl::SampleConsensusModelCylinder< PointT, PointNT >::isModelValid(), pcl::SampleConsensusModelFromNormals< PointT, PointNT >::normal_distance_weight_, pcl::SampleConsensusModelFromNormals< PointT, PointNT >::normals_, and pcl::SampleConsensusModelCylinder< PointT, PointNT >::pointToLineDistance().
| void pcl::SampleConsensusModelCylinder< PointT, PointNT >::setAxis | ( | const Eigen::Vector3f & | ax | ) | [inline] |
Set the axis along which we need to search for a cylinder direction.
| [in] | ax | the axis along which we need to search for a cylinder direction |
Definition at line 154 of file sac_model_cylinder.h.
Referenced by pcl::SACSegmentationFromNormals< PointT, PointNT >::initSACModel().
| void pcl::SampleConsensusModelCylinder< PointT, PointNT >::setEpsAngle | ( | const double | ea | ) | [inline] |
Set the angle epsilon (delta) threshold.
| [in] | ea | the maximum allowed difference between the cyilinder axis and the given axis. |
Definition at line 144 of file sac_model_cylinder.h.
Referenced by pcl::SACSegmentationFromNormals< PointT, PointNT >::initSACModel().