OctoMap.h
Go to the documentation of this file.
00001 /*
00002 Copyright (c) 2010-2016, Mathieu Labbe - IntRoLab - Universite de Sherbrooke
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 Universite de Sherbrooke 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 THE COPYRIGHT HOLDER OR CONTRIBUTORS 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 
00028 #ifndef SRC_OCTOMAP_H_
00029 #define SRC_OCTOMAP_H_
00030 
00031 #include "rtabmap/core/RtabmapExp.h" // DLL export/import defines
00032 
00033 #include <octomap/ColorOcTree.h>
00034 #include <octomap/OcTreeKey.h>
00035 
00036 #include <pcl/pcl_base.h>
00037 #include <pcl/point_types.h>
00038 
00039 #include <rtabmap/core/Transform.h>
00040 
00041 #include <map>
00042 #include <string>
00043 
00044 namespace rtabmap {
00045 
00046 class OcTreeNodeInfo
00047 {
00048 public:
00049         OcTreeNodeInfo(int nodeRefId, const octomap::OcTreeKey & key, bool isObstacle) :
00050                 nodeRefId_(nodeRefId),
00051                 key_(key),
00052                 isObstacle_(isObstacle) {}
00053         int nodeRefId_;
00054         octomap::OcTreeKey key_;
00055         bool isObstacle_;
00056 };
00057 
00058 class RTABMAP_EXP OctoMap {
00059 public:
00060         OctoMap(float voxelSize = 0.1f);
00061 
00062         const std::map<int, Transform> & addedNodes() const {return addedNodes_;}
00063         void addToCache(int nodeId,
00064                         pcl::PointCloud<pcl::PointXYZRGB>::Ptr & ground,
00065                         pcl::PointCloud<pcl::PointXYZRGB>::Ptr & obstacles);
00066         void update(const std::map<int, Transform> & poses);
00067 
00068         const octomap::ColorOcTree * octree() const {return octree_;}
00069 
00070         pcl::PointCloud<pcl::PointXYZRGB>::Ptr createCloud(
00071                         unsigned int treeDepth = 0,
00072                         std::vector<int> * obstacleIndices = 0,
00073                         std::vector<int> * emptyIndices = 0) const;
00074 
00075         cv::Mat createProjectionMap(
00076                         float & xMin,
00077                         float & yMin,
00078                         float & gridCellSize,
00079                         float minGridSize);
00080 
00081         bool writeBinary(const std::string & path);
00082 
00083         virtual ~OctoMap();
00084         void clear();
00085 
00086 private:
00087         std::map<int, std::pair<pcl::PointCloud<pcl::PointXYZRGB>::Ptr, pcl::PointCloud<pcl::PointXYZRGB>::Ptr> > cache_;
00088         octomap::ColorOcTree * octree_;
00089         std::map<octomap::ColorOcTreeNode*, OcTreeNodeInfo> occupiedCells_;
00090         std::map<int, Transform> addedNodes_;
00091         octomap::KeyRay keyRay_;
00092 };
00093 
00094 } /* namespace rtabmap */
00095 
00096 #endif /* SRC_OCTOMAP_H_ */


rtabmap
Author(s): Mathieu Labbe
autogenerated on Sat Jul 23 2016 11:44:17