frame_projector.h
Go to the documentation of this file.
00001 /*
00002 Copyright (c) 2013, Alex Teichman and Stephen Miller (Stanford University)
00003 All rights reserved.
00004 
00005 Redistribution and use in source and binary forms, with or without
00006 modification, are permitted provided that the following conditions are met:
00007     * Redistributions of source code must retain the above copyright
00008       notice, this list of conditions and the following disclaimer.
00009     * Redistributions in binary form must reproduce the above copyright
00010       notice, this list of conditions and the following disclaimer in the
00011       documentation and/or other materials provided with the distribution.
00012     * Neither the name of the <organization> nor the
00013       names of its contributors may be used to endorse or promote products
00014       derived from this software without specific prior written permission.
00015 
00016 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
00017 ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
00018 WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00019 DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
00020 DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
00021 (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00022 LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
00023 ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00024 (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
00025 SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00026 
00027 RTAB-Map integration: Mathieu Labbe
00028 */
00029 
00030 #ifndef FRAME_PROJECTOR_H
00031 #define FRAME_PROJECTOR_H
00032 
00033 #include <pcl/point_cloud.h>
00034 #include <pcl/point_types.h>
00035 #include <opencv2/core/core.hpp>
00036 #include <rtabmap/core/CameraModel.h>
00037 #include "rtabmap/core/RtabmapExp.h" // DLL export/import defines
00038 
00039 #define MAX_MULT 1.3
00040 #define MIN_MULT 0.7
00041 
00042 namespace clams
00043 {
00044 
00048   class ProjectivePoint
00049   {
00050   public:
00051           ProjectivePoint() :
00052                   u_(0),
00053                   v_(0),
00054                   z_(0.0f) {}
00055 
00056     int u_;
00057     int v_;
00058     float z_; // in meters
00059   };
00060 
00063   class RTABMAP_EXP FrameProjector
00064   {
00065   public:
00066     // For storing z values in meters.  This is not Euclidean distance.
00067     typedef std::vector< std::vector< std::vector<double> > > RangeIndex;
00068 
00069     FrameProjector(const rtabmap::CameraModel & model);
00070 
00071     RangeIndex cloudToRangeIndex(const pcl::PointCloud<pcl::PointXYZ>::Ptr & pcd) const;
00075     cv::Mat estimateMapDepth(
00076                 const pcl::PointCloud<pcl::PointXYZ>::Ptr & map,
00077                 const rtabmap::Transform & transform,
00078                         const cv::Mat & measurement,
00079                         double coneRadius = 0.02,
00080                         double coneStdevThresh = 0.03) const;
00081                           
00082     pcl::PointXYZ project(const ProjectivePoint& ppt) const;
00083     ProjectivePoint reproject(const pcl::PointXYZ& pt) const;
00084 
00085   protected:
00086     bool coneFit(const cv::Size& imageSize, const RangeIndex& rindex,
00087                  int uc, int vc, double radius, double measurement_depth,
00088                  double* mean, double* stdev) const;
00089 
00090   private:
00091     rtabmap::CameraModel model_;
00092   };
00093 
00094 }  // namespace clams
00095 
00096 #endif // FRAME_PROJECTOR_H


rtabmap
Author(s): Mathieu Labbe
autogenerated on Thu Jun 6 2019 21:59:20