topological_map.h
Go to the documentation of this file.
00001 /*
00002  * Copyright (c) 2008, Willow Garage, Inc.
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  *
00008  *     * Redistributions of source code must retain the above copyright
00009  *       notice, this list of conditions and the following disclaimer.
00010  *     * Redistributions in binary form must reproduce the above copyright
00011  *       notice, this list of conditions and the following disclaimer in the
00012  *       documentation and/or other materials provided with the distribution.
00013  *     * Neither the name of the Willow Garage, Inc. nor the names of its
00014  *       contributors may be used to endorse or promote products derived from
00015  *       this software without specific prior written permission.
00016  *
00017  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00018  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00019  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00020  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
00021  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00022  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00023  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00024  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00025  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00026  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00027  * POSSIBILITY OF SUCH DAMAGE.
00028  *
00029  */
00030 
00040 #ifndef TOPOLOGICAL_MAP_2D_TOPOLOGICAL_MAP_H
00041 #define TOPOLOGICAL_MAP_2D_TOPOLOGICAL_MAP_H
00042 
00043 #include <topological_nav_msgs/TopologicalMapNode.h>
00044 #include <topological_nav_msgs/TopologicalMapEdge.h>
00045 #include <map>
00046 
00047 #define BOOST_NO_HASH
00048 #include <boost/graph/adjacency_list.hpp>
00049 #include <boost/graph/graph_traits.hpp>
00050 
00051 namespace topological_map_2d
00052 {
00053 
00054 namespace msg=topological_nav_msgs;
00055 
00056 typedef boost::adjacency_list<boost::listS, boost::listS, boost::undirectedS,
00057                               msg::TopologicalMapNode,
00058                               msg::TopologicalMapEdge> Graph;
00059 typedef boost::graph_traits<Graph>::edge_descriptor GraphEdge;
00060 typedef boost::graph_traits<Graph>::vertex_descriptor GraphVertex;
00061 
00062 
00070 class TopologicalMap : public Graph
00071 {
00072 public:
00073 
00074   typedef msg::TopologicalMapNode Node;
00075   typedef msg::TopologicalMapEdge Edge;
00076 
00078   TopologicalMap ();
00079 
00081   TopologicalMap (const TopologicalMap& g);
00082 
00084   TopologicalMap& operator= (const TopologicalMap& g);
00085 
00088   GraphVertex node (unsigned id) const;
00089 
00092   GraphEdge edge (unsigned id) const;
00093 
00096   Node& nodeInfo (unsigned id);
00097 
00100   Edge& edgeInfo (unsigned id);
00101 
00104   const Node& nodeInfo (unsigned id) const;
00105 
00108   const Edge& edgeInfo (unsigned id) const;
00109 
00114   GraphVertex addNode (const Node& info);
00115 
00121   GraphEdge addEdge (const Edge& info);
00122 
00126   void removeNode (unsigned id);
00127   
00131   void removeEdge (unsigned id);
00132 
00133 private:
00134 
00136   void recomputeIndices ();
00137 
00138   std::map<unsigned, GraphVertex> vertex_map_;
00139   std::map<unsigned, GraphEdge> edge_map_;
00140 
00141 };
00142 
00144 std::string gridFrame (const unsigned g);
00145 
00148 unsigned frameGrid (const std::string& frame);
00149 
00150 } // namespace
00151 
00152 #endif // include guard


topological_map_2d
Author(s): Bhaskara Marthi
autogenerated on Sun Jan 5 2014 11:39:24