SampleConsensusModelCone defines a model for 3D cone segmentation. The model coefficients are defined as: More...
#include <sac_model_cone.h>
Classes | |
struct | OptimizationFunctor |
Functor for the optimization function. More... | |
Public Types | |
typedef SampleConsensusModel < PointT >::PointCloud | PointCloud |
typedef SampleConsensusModel < PointT >::PointCloudConstPtr | PointCloudConstPtr |
typedef SampleConsensusModel < PointT >::PointCloudPtr | PointCloudPtr |
typedef boost::shared_ptr < SampleConsensusModelCone > | Ptr |
Public Member Functions | |
bool | computeModelCoefficients (const std::vector< int > &samples, Eigen::VectorXf &model_coefficients) |
Check whether the given index samples can form a valid cone model, compute the model coefficients from these samples and store them in model_coefficients. The cone coefficients are: apex, axis_direction, opening_angle. | |
virtual int | countWithinDistance (const Eigen::VectorXf &model_coefficients, const double threshold) |
Count all the points which respect the given model coefficients as inliers. | |
bool | doSamplesVerifyModel (const std::set< int > &indices, const Eigen::VectorXf &model_coefficients, const double threshold) |
Verify whether a subset of indices verifies the given cone model coefficients. | |
Eigen::Vector3f | getAxis () const |
Get the axis along which we need to search for a cone direction. | |
void | getDistancesToModel (const Eigen::VectorXf &model_coefficients, std::vector< double > &distances) |
Compute all distances from the cloud data to a given cone model. | |
double | getEpsAngle () const |
Get the angle epsilon (delta) threshold. | |
void | getMinMaxOpeningAngle (double &min_angle, double &max_angle) const |
Get the opening angle which we need minumum to validate a cone model. | |
pcl::SacModel | getModelType () const |
Return an unique id for this model (SACMODEL_CONE). | |
SampleConsensusModelCone & | operator= (const SampleConsensusModelCone &source) |
Copy constructor. | |
void | optimizeModelCoefficients (const std::vector< int > &inliers, const Eigen::VectorXf &model_coefficients, Eigen::VectorXf &optimized_coefficients) |
Recompute the cone 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 cone model. | |
SampleConsensusModelCone (const PointCloudConstPtr &cloud, bool random=false) | |
Constructor for base SampleConsensusModelCone. | |
SampleConsensusModelCone (const PointCloudConstPtr &cloud, const std::vector< int > &indices, bool random=false) | |
Constructor for base SampleConsensusModelCone. | |
SampleConsensusModelCone (const SampleConsensusModelCone &source) | |
Copy constructor. | |
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. | |
void | setAxis (const Eigen::Vector3f &ax) |
Set the axis along which we need to search for a cone direction. | |
void | setEpsAngle (double ea) |
Set the angle epsilon (delta) threshold. | |
void | setMinMaxOpeningAngle (const double &min_angle, const double &max_angle) |
Set the minimum and maximum allowable opening angle for a cone model given from a user. | |
virtual | ~SampleConsensusModelCone () |
Empty destructor. | |
Protected Member Functions | |
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. Pure virtual. | |
double | pointToAxisDistance (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) | |
Private 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. | |
double | max_angle_ |
double | min_angle_ |
The minimum and maximum allowed opening angles of valid cone model. | |
const std::vector< int > * | tmp_inliers_ |
temporary pointer to a list of given indices for optimizeModelCoefficients () |
SampleConsensusModelCone defines a model for 3D cone segmentation. The model coefficients are defined as:
Definition at line 65 of file sac_model_cone.h.
typedef SampleConsensusModel<PointT>::PointCloud pcl::SampleConsensusModelCone< PointT, PointNT >::PointCloud |
Reimplemented from pcl::SampleConsensusModel< PointT >.
Definition at line 76 of file sac_model_cone.h.
typedef SampleConsensusModel<PointT>::PointCloudConstPtr pcl::SampleConsensusModelCone< PointT, PointNT >::PointCloudConstPtr |
Reimplemented from pcl::SampleConsensusModel< PointT >.
Definition at line 78 of file sac_model_cone.h.
typedef SampleConsensusModel<PointT>::PointCloudPtr pcl::SampleConsensusModelCone< PointT, PointNT >::PointCloudPtr |
Reimplemented from pcl::SampleConsensusModel< PointT >.
Definition at line 77 of file sac_model_cone.h.
typedef boost::shared_ptr<SampleConsensusModelCone> pcl::SampleConsensusModelCone< PointT, PointNT >::Ptr |
Reimplemented from pcl::SampleConsensusModel< PointT >.
Definition at line 80 of file sac_model_cone.h.
pcl::SampleConsensusModelCone< PointT, PointNT >::SampleConsensusModelCone | ( | const PointCloudConstPtr & | cloud, |
bool | random = false |
||
) | [inline] |
Constructor for base SampleConsensusModelCone.
[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_cone.h.
pcl::SampleConsensusModelCone< PointT, PointNT >::SampleConsensusModelCone | ( | const PointCloudConstPtr & | cloud, |
const std::vector< int > & | indices, | ||
bool | random = false |
||
) | [inline] |
Constructor for base SampleConsensusModelCone.
[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 102 of file sac_model_cone.h.
pcl::SampleConsensusModelCone< PointT, PointNT >::SampleConsensusModelCone | ( | const SampleConsensusModelCone< PointT, PointNT > & | source | ) | [inline] |
Copy constructor.
[in] | source | the model to copy into this |
Definition at line 118 of file sac_model_cone.h.
virtual pcl::SampleConsensusModelCone< PointT, PointNT >::~SampleConsensusModelCone | ( | ) | [inline, virtual] |
Empty destructor.
Definition at line 127 of file sac_model_cone.h.
bool pcl::SampleConsensusModelCone< PointT, PointNT >::computeModelCoefficients | ( | const std::vector< int > & | samples, |
Eigen::VectorXf & | model_coefficients | ||
) | [virtual] |
Check whether the given index samples can form a valid cone model, compute the model coefficients from these samples and store them in model_coefficients. The cone coefficients are: apex, axis_direction, opening_angle.
[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 55 of file sac_model_cone.hpp.
int pcl::SampleConsensusModelCone< PointT, PointNT >::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 |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 255 of file sac_model_cone.hpp.
bool pcl::SampleConsensusModelCone< PointT, PointNT >::doSamplesVerifyModel | ( | const std::set< int > & | indices, |
const Eigen::VectorXf & | model_coefficients, | ||
const double | threshold | ||
) | [virtual] |
Verify whether a subset of indices verifies the given cone model coefficients.
[in] | indices | the data indices that need to be tested against the cone model |
[in] | model_coefficients | the cone model coefficients |
[in] | threshold | a maximum admissible distance threshold for determining the inliers from the outliers |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 438 of file sac_model_cone.hpp.
Eigen::Vector3f pcl::SampleConsensusModelCone< PointT, PointNT >::getAxis | ( | ) | const [inline] |
Get the axis along which we need to search for a cone direction.
Definition at line 162 of file sac_model_cone.h.
void pcl::SampleConsensusModelCone< PointT, PointNT >::getDistancesToModel | ( | const Eigen::VectorXf & | model_coefficients, |
std::vector< double > & | distances | ||
) | [virtual] |
Compute all distances from the cloud data to a given cone model.
[in] | model_coefficients | the coefficients of a cone model that we need to compute distances to |
[out] | distances | the resultant estimated distances |
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 137 of file sac_model_cone.hpp.
double pcl::SampleConsensusModelCone< PointT, PointNT >::getEpsAngle | ( | ) | const [inline] |
Get the angle epsilon (delta) threshold.
Definition at line 152 of file sac_model_cone.h.
void pcl::SampleConsensusModelCone< PointT, PointNT >::getMinMaxOpeningAngle | ( | double & | min_angle, |
double & | max_angle | ||
) | const [inline] |
Get the opening angle which we need minumum to validate a cone model.
[out] | min_angle | the minimum allwoable opening angle of a cone model |
[out] | max_angle | the maximum allwoable opening angle of a cone model |
Definition at line 181 of file sac_model_cone.h.
pcl::SacModel pcl::SampleConsensusModelCone< PointT, PointNT >::getModelType | ( | ) | const [inline, virtual] |
Return an unique id for this model (SACMODEL_CONE).
Implements pcl::SampleConsensusModel< PointT >.
Definition at line 262 of file sac_model_cone.h.
std::string pcl::SampleConsensusModelCone< PointT, PointNT >::getName | ( | ) | const [inline, protected] |
Get a string representation of the name of this class.
Definition at line 274 of file sac_model_cone.h.
bool pcl::SampleConsensusModelCone< PointT, PointNT >::isModelValid | ( | const Eigen::VectorXf & | model_coefficients | ) | [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 491 of file sac_model_cone.hpp.
bool pcl::SampleConsensusModelCone< PointT, PointNT >::isSampleGood | ( | const std::vector< int > & | samples | ) | const [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 48 of file sac_model_cone.hpp.
SampleConsensusModelCone& pcl::SampleConsensusModelCone< PointT, PointNT >::operator= | ( | const SampleConsensusModelCone< PointT, PointNT > & | source | ) | [inline] |
Copy constructor.
[in] | source | the model to copy into this |
Definition at line 133 of file sac_model_cone.h.
void pcl::SampleConsensusModelCone< PointT, PointNT >::optimizeModelCoefficients | ( | const std::vector< int > & | inliers, |
const Eigen::VectorXf & | model_coefficients, | ||
Eigen::VectorXf & | optimized_coefficients | ||
) | [virtual] |
Recompute the cone 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 309 of file sac_model_cone.hpp.
double pcl::SampleConsensusModelCone< PointT, PointNT >::pointToAxisDistance | ( | const Eigen::Vector4f & | pt, |
const Eigen::VectorXf & | model_coefficients | ||
) | [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 481 of file sac_model_cone.hpp.
void pcl::SampleConsensusModelCone< PointT, PointNT >::projectPoints | ( | const std::vector< int > & | inliers, |
const Eigen::VectorXf & | model_coefficients, | ||
PointCloud & | projected_points, | ||
bool | copy_data_fields = true |
||
) | [virtual] |
Create a new point cloud with inliers projected onto the cone model.
[in] | inliers | the data inliers that we want to project on the cone model |
[in] | model_coefficients | the coefficients of a cone 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 342 of file sac_model_cone.hpp.
void pcl::SampleConsensusModelCone< PointT, PointNT >::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 cone 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 189 of file sac_model_cone.hpp.
void pcl::SampleConsensusModelCone< PointT, PointNT >::setAxis | ( | const Eigen::Vector3f & | ax | ) | [inline] |
Set the axis along which we need to search for a cone direction.
[in] | ax | the axis along which we need to search for a cone direction |
Definition at line 158 of file sac_model_cone.h.
void pcl::SampleConsensusModelCone< PointT, PointNT >::setEpsAngle | ( | double | ea | ) | [inline] |
Set the angle epsilon (delta) threshold.
[in] | ea | the maximum allowed difference between the cone's axis and the given axis. |
Definition at line 148 of file sac_model_cone.h.
void pcl::SampleConsensusModelCone< PointT, PointNT >::setMinMaxOpeningAngle | ( | const double & | min_angle, |
const double & | max_angle | ||
) | [inline] |
Set the minimum and maximum allowable opening angle for a cone model given from a user.
[in] | min_angle | the minimum allwoable opening angle of a cone model |
[in] | max_angle | the maximum allwoable opening angle of a cone model |
Definition at line 170 of file sac_model_cone.h.
Eigen::Vector3f pcl::SampleConsensusModelCone< PointT, PointNT >::axis_ [private] |
The axis along which we need to search for a plane perpendicular to.
Definition at line 292 of file sac_model_cone.h.
double pcl::SampleConsensusModelCone< PointT, PointNT >::eps_angle_ [private] |
The maximum allowed difference between the plane normal and the given axis.
Definition at line 295 of file sac_model_cone.h.
double pcl::SampleConsensusModelCone< PointT, PointNT >::max_angle_ [private] |
Definition at line 299 of file sac_model_cone.h.
double pcl::SampleConsensusModelCone< PointT, PointNT >::min_angle_ [private] |
The minimum and maximum allowed opening angles of valid cone model.
Definition at line 298 of file sac_model_cone.h.
const std::vector<int>* pcl::SampleConsensusModelCone< PointT, PointNT >::tmp_inliers_ [private] |
temporary pointer to a list of given indices for optimizeModelCoefficients ()
Definition at line 302 of file sac_model_cone.h.