110 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C++
		
	
	
			
		
		
	
	
			110 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C++
		
	
	
| /* ----------------------------------------------------------------------------
 | |
| 
 | |
|  * GTSAM Copyright 2010, Georgia Tech Research Corporation, 
 | |
|  * Atlanta, Georgia 30332-0415
 | |
|  * All Rights Reserved
 | |
|  * Authors: Frank Dellaert, et al. (see THANKS for the full author list)
 | |
| 
 | |
|  * See LICENSE for the license information
 | |
| 
 | |
|  * -------------------------------------------------------------------------- */
 | |
| 
 | |
| /*
 | |
|  *  graph.h
 | |
|  *  @brief Graph algorithm using boost library
 | |
|  *  @author: Kai Ni
 | |
|  *  Created on: Jan 11, 2010
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <map>
 | |
| 
 | |
| #define BOOST_NO_HASH  // to pacify the warnings about depricated headers in boost.graph
 | |
| 
 | |
| #include <boost/graph/graph_traits.hpp>
 | |
| #include <boost/graph/adjacency_list.hpp>
 | |
| #include <boost/shared_ptr.hpp>
 | |
| 
 | |
| namespace gtsam {
 | |
| 
 | |
| 	// type definitions :
 | |
| 
 | |
| 	/**
 | |
| 	 * SDGraph is undirected graph with variable keys and double edge weights
 | |
| 	 */
 | |
| 	template<class Key>
 | |
| 	class SDGraph: public boost::adjacency_list<boost::vecS, boost::vecS, boost::undirectedS,
 | |
| 	boost::property<boost::vertex_name_t, Key>, boost::property<
 | |
| 	boost::edge_weight_t, double> > {
 | |
| 	public:
 | |
| 		typedef typename boost::graph_traits<SDGraph<Key> >::vertex_descriptor Vertex;
 | |
| 	};
 | |
| 
 | |
| 	template<class Key>
 | |
| 	class SGraph : public boost::adjacency_list<boost::vecS, boost::vecS, boost::directedS,
 | |
| 			boost::property<boost::vertex_name_t, Key> > {
 | |
| 	public:
 | |
| 		typedef typename boost::graph_traits<SGraph<Key> >::vertex_descriptor Vertex;
 | |
| 	};
 | |
| 
 | |
| 	//typedef boost::graph_traits<SGraph>::vertex_descriptor SVertex;
 | |
| 
 | |
| 	/**
 | |
| 	 * Map from variable key to parent key
 | |
| 	 */
 | |
| 	template<class Key>
 | |
| 	class PredecessorMap: public std::map<Key, Key> {
 | |
| 	public:
 | |
| 		/** convenience insert so we can pass ints for TypedSymbol keys */
 | |
| 		inline void insert(const Key& key, const Key& parent) {
 | |
| 			std::map<Key, Key>::insert(std::make_pair(key, parent));
 | |
| 		}
 | |
| 	};
 | |
| 
 | |
| 	/**
 | |
| 	 * Generate a list of keys from a spanning tree represented by its predecessor map
 | |
| 	 */
 | |
| 	template<class Key>
 | |
| 	std::list<Key> predecessorMap2Keys(const PredecessorMap<Key>& p_map);
 | |
| 
 | |
| 	/**
 | |
| 	 * Convert the factor graph to an SDGraph
 | |
| 	 * G = Graph type
 | |
| 	 * F = Factor type
 | |
| 	 * Key = Key type
 | |
| 	 */
 | |
|     template<class G, class F, class Key> SDGraph<Key> toBoostGraph(const G& graph);
 | |
| 
 | |
| 	/**
 | |
| 	 * Build takes a predecessor map, and builds a directed graph corresponding to the tree.
 | |
| 	 * G = Graph type
 | |
| 	 * V = Vertex type
 | |
| 	 */
 | |
| 	template<class G, class V, class Key>
 | |
| 	boost::tuple<G, V, std::map<Key,V> >	predecessorMap2Graph(const PredecessorMap<Key>& p_map);
 | |
| 
 | |
| 	/**
 | |
| 	 * Compose the poses by following the chain specified by the spanning tree
 | |
| 	 */
 | |
| 	template<class G, class Factor, class Pose, class Values>
 | |
| 	boost::shared_ptr<Values>
 | |
| 		composePoses(const G& graph, const PredecessorMap<typename Values::Key>& tree, const Pose& rootPose);
 | |
| 
 | |
| 
 | |
| 	/**
 | |
| 	 * find the minimum spanning tree using boost graph library
 | |
| 	 */
 | |
| 	template<class G, class Key, class Factor2>
 | |
| 	PredecessorMap<Key> findMinimumSpanningTree(const G& g) ;
 | |
| 
 | |
| 	/**
 | |
| 	 * Split the graph into two parts: one corresponds to the given spanning tree,
 | |
| 	 * and the other corresponds to the rest of the factors
 | |
| 	 */
 | |
| 	template<class G, class Key, class Factor2>
 | |
| 	void split(const G& g, const PredecessorMap<Key>& tree, G& Ab1, G& Ab2) ;
 | |
| 
 | |
| 
 | |
| } // namespace gtsam
 |