00001 /* 00002 * Software License Agreement (BSD License) 00003 * 00004 * Point Cloud Library (PCL) - www.pointclouds.org 00005 * Copyright (c) 2010-2011, Willow Garage, Inc. 00006 * 00007 * All rights reserved. 00008 * 00009 * Redistribution and use in source and binary forms, with or without 00010 * modification, are permitted provided that the following conditions 00011 * are met: 00012 * 00013 * * Redistributions of source code must retain the above copyright 00014 * notice, this list of conditions and the following disclaimer. 00015 * * Redistributions in binary form must reproduce the above 00016 * copyright notice, this list of conditions and the following 00017 * disclaimer in the documentation and/or other materials provided 00018 * with the distribution. 00019 * * Neither the name of Willow Garage, Inc. nor the names of its 00020 * contributors may be used to endorse or promote products derived 00021 * from this software without specific prior written permission. 00022 * 00023 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 00024 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 00025 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 00026 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 00027 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 00028 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 00029 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 00030 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 00031 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 00032 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 00033 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00034 * POSSIBILITY OF SUCH DAMAGE. 00035 * 00036 * 00037 */ 00038 00039 #ifndef PCL_REGISTRATION_CORRESPONDENCE_ESTIMATION_H_ 00040 #define PCL_REGISTRATION_CORRESPONDENCE_ESTIMATION_H_ 00041 00042 #include <string> 00043 00044 #include <pcl/pcl_base.h> 00045 #include <pcl/kdtree/kdtree.h> 00046 #include <pcl/kdtree/kdtree_flann.h> 00047 #include <pcl/pcl_macros.h> 00048 00049 #include <pcl/registration/correspondence_types.h> 00050 00051 namespace pcl 00052 { 00053 namespace registration 00054 { 00061 template <typename PointSource, typename PointTarget> 00062 class CorrespondenceEstimation : public PCLBase<PointSource> 00063 { 00064 public: 00065 using PCLBase<PointSource>::initCompute; 00066 using PCLBase<PointSource>::deinitCompute; 00067 using PCLBase<PointSource>::input_; 00068 using PCLBase<PointSource>::indices_; 00069 00070 typedef typename pcl::KdTree<PointTarget> KdTree; 00071 typedef typename pcl::KdTree<PointTarget>::Ptr KdTreePtr; 00072 00073 typedef pcl::PointCloud<PointSource> PointCloudSource; 00074 typedef typename PointCloudSource::Ptr PointCloudSourcePtr; 00075 typedef typename PointCloudSource::ConstPtr PointCloudSourceConstPtr; 00076 00077 typedef pcl::PointCloud<PointTarget> PointCloudTarget; 00078 typedef typename PointCloudTarget::Ptr PointCloudTargetPtr; 00079 typedef typename PointCloudTarget::ConstPtr PointCloudTargetConstPtr; 00080 00081 typedef typename KdTree::PointRepresentationConstPtr PointRepresentationConstPtr; 00082 00084 CorrespondenceEstimation () : 00085 corr_name_ (), 00086 tree_ (new pcl::KdTreeFLANN<PointTarget>), 00087 target_ (), 00088 point_representation_ () 00089 { 00090 } 00091 00096 virtual inline void 00097 setInputTarget (const PointCloudTargetConstPtr &cloud); 00098 00100 inline PointCloudTargetConstPtr const 00101 getInputTarget () { return (target_ ); } 00102 00106 inline void 00107 setPointRepresentation (const PointRepresentationConstPtr &point_representation) 00108 { 00109 point_representation_ = point_representation; 00110 } 00111 00116 virtual void 00117 determineCorrespondences (pcl::Correspondences &correspondences, 00118 float max_distance = std::numeric_limits<float>::max ()); 00119 00123 virtual void 00124 determineReciprocalCorrespondences (pcl::Correspondences &correspondences); 00125 00126 protected: 00128 std::string corr_name_; 00129 00131 KdTreePtr tree_; 00132 00134 PointCloudTargetConstPtr target_; 00135 00137 inline const std::string& 00138 getClassName () const { return (corr_name_); } 00139 00140 private: 00142 PointRepresentationConstPtr point_representation_; 00143 }; 00144 } 00145 } 00146 00147 #include <pcl/registration/impl/correspondence_estimation.hpp> 00148 00149 #endif /* PCL_REGISTRATION_CORRESPONDENCE_ESTIMATION_H_ */