Keypoint detector for detecting corners in 3D (XYZ), 2D (intensity) AND mixed versions of these. More...
#include <pcl/keypoints/harris_6d.h>
Public Types | |
using | Ptr = shared_ptr< HarrisKeypoint6D< PointInT, PointOutT, NormalT > > |
using | ConstPtr = shared_ptr< const HarrisKeypoint6D< PointInT, PointOutT, NormalT > > |
using | PointCloudIn = typename Keypoint< PointInT, PointOutT >::PointCloudIn |
using | PointCloudOut = typename Keypoint< PointInT, PointOutT >::PointCloudOut |
using | KdTree = typename Keypoint< PointInT, PointOutT >::KdTree |
using | PointCloudInConstPtr = typename PointCloudIn::ConstPtr |
Public Types inherited from pcl::Keypoint< PointInT, PointOutT > | |
using | Ptr = shared_ptr< Keypoint< PointInT, PointOutT > > |
using | ConstPtr = shared_ptr< const Keypoint< PointInT, PointOutT > > |
using | BaseClass = PCLBase< PointInT > |
using | KdTree = pcl::search::Search< PointInT > |
using | KdTreePtr = typename KdTree::Ptr |
using | PointCloudIn = pcl::PointCloud< PointInT > |
using | PointCloudInPtr = typename PointCloudIn::Ptr |
using | PointCloudInConstPtr = typename PointCloudIn::ConstPtr |
using | PointCloudOut = pcl::PointCloud< PointOutT > |
using | SearchMethod = std::function< int(pcl::index_t, double, pcl::Indices &, std::vector< float > &)> |
using | SearchMethodSurface = std::function< int(const PointCloudIn &cloud, pcl::index_t index, double, pcl::Indices &, std::vector< float > &)> |
Public Member Functions | |
HarrisKeypoint6D (float radius=0.01, float threshold=0.0) | |
Constructor. More... |
|
virtual | ~HarrisKeypoint6D () |
Empty destructor. More... |
|
void | setRadius (float radius) |
set the radius for normal estimation and non maxima supression. More... |
|
void | setThreshold (float threshold) |
set the threshold value for detecting corners. More... |
|
void | setNonMaxSupression (bool=false) |
whether non maxima suppression should be applied or the response for each point should be returned More... |
|
void | setRefine (bool do_refine) |
whether the detected key points should be refined or not. More... |
|
virtual void | setSearchSurface (const PointCloudInConstPtr &cloud) |
Provide a pointer to the input dataset that we need to estimate features at every point for. More... |
|
void | setNumberOfThreads (unsigned int nr_threads=0) |
Initialize the scheduler and set the number of threads to use. More... |
|
Public Member Functions inherited from pcl::Keypoint< PointInT, PointOutT > | |
Keypoint () | |
Keypoint () | |
Empty constructor. More... |
|
void | harrisCorner (PointInT &output, PointInT &input, const float sigma_d, const float sigma_i, const float alpha, const float thresh) |
void | hessianBlob (PointInT &output, PointInT &input, const float sigma, bool SCALE) |
void | hessianBlob (PointInT &output, PointInT &input, const float start_scale, const float scaling_factor, const int num_scales) |
void | imageElementMultiply (PointInT &output, PointInT &input1, PointInT &input2) |
~Keypoint () | |
Empty destructor. More... |
|
PointCloudInConstPtr | getSearchSurface () |
Get a pointer to the surface point cloud dataset. More... |
|
void | setSearchMethod (const KdTreePtr &tree) |
Provide a pointer to the search object. More... |
|
KdTreePtr | getSearchMethod () |
Get a pointer to the search method used. More... |
|
double | getSearchParameter () |
Get the internal search parameter. More... |
|
void | setKSearch (int k) |
Set the number of k nearest neighbors to use for the feature estimation. More... |
|
int | getKSearch () |
get the number of k nearest neighbors used for the feature estimation. More... |
|
void | setRadiusSearch (double radius) |
Set the sphere radius that is to be used for determining the nearest neighbors used for the key point detection. More... |
|
double | getRadiusSearch () |
Get the sphere radius used for determining the neighbors. More... |
|
pcl::PointIndicesConstPtr | getKeypointsIndices () |
void | compute (PointCloudOut &output) |
Base method for key point detection for all points given in <setInputCloud (), setIndices ()> using the surface in setSearchSurface () and the spatial locator in setSearchMethod () More... |
|
int | searchForNeighbors (pcl::index_t index, double parameter, pcl::Indices &indices, std::vector< float > &distances) const |
Search for k-nearest neighbors using the spatial locator from setSearchmethod, and the given surface from setSearchSurface. More... |
|
Protected Member Functions | |
void | detectKeypoints (PointCloudOut &output) |
void | responseTomasi (PointCloudOut &output) const |
void | refineCorners (PointCloudOut &corners) const |
void | calculateCombinedCovar (const pcl::Indices &neighbors, float *coefficients) const |
Protected Member Functions inherited from pcl::Keypoint< PointInT, PointOutT > | |
virtual bool | initCompute () |
const std::string & | getClassName () const |
Get a string representation of the name of this class. More... |
|
virtual void | detectKeypoints (PointCloudOut &output)=0 |
Abstract key point detection method. More... |
|
Additional Inherited Members | |
Protected Attributes inherited from pcl::Keypoint< PointInT, PointOutT > | |
std::string | name_ |
The key point detection method's name. More... |
|
SearchMethod | search_method_ |
The search method template for indices. More... |
|
SearchMethodSurface | search_method_surface_ |
The search method template for points. More... |
|
PointCloudInConstPtr | surface_ |
An input point cloud describing the surface that is to be used for nearest neighbors estimation. More... |
|
KdTreePtr | tree_ |
A pointer to the spatial search object. More... |
|
double | search_parameter_ |
The actual search parameter (casted from either search_radius_ or k_). More... |
|
double | search_radius_ |
The nearest neighbors search radius for each point. More... |
|
int | k_ |
The number of K nearest neighbors to use for each point. More... |
|
pcl::PointIndicesPtr | keypoints_indices_ |
Indices of the keypoints in the input cloud. More... |
|
Keypoint detector for detecting corners in 3D (XYZ), 2D (intensity) AND mixed versions of these.
Definition at line 49 of file harris_6d.h.
using pcl::HarrisKeypoint6D< PointInT, PointOutT, NormalT >::ConstPtr = shared_ptr<const HarrisKeypoint6D<PointInT, PointOutT, NormalT> > |
Definition at line 53 of file harris_6d.h.
using pcl::HarrisKeypoint6D< PointInT, PointOutT, NormalT >::KdTree = typename Keypoint<PointInT, PointOutT>::KdTree |
Definition at line 57 of file harris_6d.h.
using pcl::HarrisKeypoint6D< PointInT, PointOutT, NormalT >::PointCloudIn = typename Keypoint<PointInT, PointOutT>::PointCloudIn |
Definition at line 55 of file harris_6d.h.
using pcl::HarrisKeypoint6D< PointInT, PointOutT, NormalT >::PointCloudInConstPtr = typename PointCloudIn::ConstPtr |
Definition at line 58 of file harris_6d.h.
using pcl::HarrisKeypoint6D< PointInT, PointOutT, NormalT >::PointCloudOut = typename Keypoint<PointInT, PointOutT>::PointCloudOut |
Definition at line 56 of file harris_6d.h.
using pcl::HarrisKeypoint6D< PointInT, PointOutT, NormalT >::Ptr = shared_ptr<HarrisKeypoint6D<PointInT, PointOutT, NormalT> > |
Definition at line 52 of file harris_6d.h.
| inline |
Constructor.
radius | the radius for normal estimation as well as for non maxima suppression |
threshold | the threshold to filter out weak corners |
Definition at line 75 of file harris_6d.h.
References pcl::Keypoint< PointInT, PointOutT >::name_, and pcl::Keypoint< PointInT, PointOutT >::search_radius_.
| inlinevirtual |
Empty destructor.
Definition at line 88 of file harris_6d.h.
| protected |
Definition at line 75 of file harris_6d.hpp.
| protected |
Definition at line 142 of file harris_6d.hpp.
References pcl::Feature< PointInT, PointOutT >::compute(), pcl::copyPointCloud(), pcl::PointCloud< PointT >::is_dense, pcl::isFinite(), pcl::PointCloud< PointT >::points, pcl::PointCloud< PointT >::resize(), pcl::PCLBase< PointInT >::setInputCloud(), pcl::IntegralImageNormalEstimation< PointInT, PointOutT >::setInputCloud(), pcl::NormalEstimation< PointInT, PointOutT >::setInputCloud(), pcl::FeatureFromNormals< PointInT, PointNT, PointOutT >::setInputNormals(), pcl::IntegralImageNormalEstimation< PointInT, PointOutT >::setNormalEstimationMethod(), pcl::IntegralImageNormalEstimation< PointInT, PointOutT >::setNormalSmoothingSize(), pcl::Feature< PointInT, PointOutT >::setRadiusSearch(), and pcl::PointCloud< PointT >::size().
| protected |
Definition at line 357 of file harris_6d.hpp.
References pcl::search::KdTree< PointT, Tree >::radiusSearch(), and pcl::search::KdTree< PointT, Tree >::setInputCloud().
| protected |
Definition at line 267 of file harris_6d.hpp.
References pcl::isFinite().
void pcl::HarrisKeypoint6D< PointInT, PointOutT, NormalT >::setNonMaxSupression | ( | bool |
nonmax = false
|
) |
whether non maxima suppression should be applied or the response for each point should be returned
nonmax | default is false |
Definition at line 68 of file harris_6d.hpp.
| inline |
Initialize the scheduler and set the number of threads to use.
nr_threads | the number of hardware threads to use (0 sets the value back to automatic) |
Definition at line 124 of file harris_6d.h.
void pcl::HarrisKeypoint6D< PointInT, PointOutT, NormalT >::setRadius | ( | float | radius | ) |
set the radius for normal estimation and non maxima supression.
radius |
Definition at line 56 of file harris_6d.hpp.
void pcl::HarrisKeypoint6D< PointInT, PointOutT, NormalT >::setRefine | ( | bool | do_refine | ) |
whether the detected key points should be refined or not.
If turned of, the key points are a subset of the original point cloud. Otherwise the key points may be arbitrary.
note non maxima supression needs to be on in order to use this feature.
do_refine |
Definition at line 62 of file harris_6d.hpp.
| inlinevirtual |
Provide a pointer to the input dataset that we need to estimate features at every point for.
cloud | the const boost shared pointer to a PointCloud message |
Reimplemented from pcl::Keypoint< PointInT, PointOutT >.
Definition at line 118 of file harris_6d.h.
References pcl::PointCloud< PointT >::clear(), and pcl::Keypoint< PointInT, PointOutT >::surface_.
void pcl::HarrisKeypoint6D< PointInT, PointOutT, NormalT >::setThreshold | ( | float | threshold | ) |
set the threshold value for detecting corners.
This is only evaluated if non maxima suppression is turned on.
note non maxima suppression needs to be activated in order to use this feature.
threshold |
Definition at line 50 of file harris_6d.hpp.
© 2009–2012, Willow Garage, Inc.
© 2012–, Open Perception, Inc.
Licensed under the BSD License.
https://pointclouds.org/documentation/classpcl_1_1_harris_keypoint6_d.html