| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file    FactorGraph.h | 
					
						
							|  |  |  |  * @brief   Factor Graph Base Class | 
					
						
							|  |  |  |  * @author  Carlos Nieto | 
					
						
							|  |  |  |  * @author  Christian Potthast | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // \callgraph
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/shared_ptr.hpp>
 | 
					
						
							| 
									
										
										
										
											2009-10-29 12:11:23 +08:00
										 |  |  | #include <boost/serialization/map.hpp>
 | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | #include <boost/serialization/list.hpp>
 | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | #include <boost/serialization/vector.hpp>
 | 
					
						
							|  |  |  | #include <boost/serialization/shared_ptr.hpp>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-25 07:14:14 +08:00
										 |  |  | #include "Testable.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-05 12:56:59 +08:00
										 |  |  | #include "BayesNet.h"
 | 
					
						
							| 
									
										
										
										
											2009-10-25 07:14:14 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | namespace gtsam { | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-13 12:13:03 +08:00
										 |  |  | 	class Ordering; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * A factor graph is a bipartite graph with factor nodes connected to variable nodes. | 
					
						
							|  |  |  | 	 * In this class, however, only factor nodes are kept around. | 
					
						
							| 
									
										
										
										
											2009-10-07 02:25:04 +08:00
										 |  |  | 	 *  | 
					
						
							|  |  |  | 	 * Templated on the type of factors and configuration. | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2009-10-29 12:11:23 +08:00
										 |  |  | 	template<class Factor> class FactorGraph: public Testable<FactorGraph<Factor> > { | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 	public: | 
					
						
							| 
									
										
										
										
											2009-09-13 12:13:03 +08:00
										 |  |  | 		typedef typename boost::shared_ptr<Factor> shared_factor; | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 		typedef typename std::vector<shared_factor>::iterator iterator; | 
					
						
							|  |  |  | 		typedef typename std::vector<shared_factor>::const_iterator const_iterator; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	protected: | 
					
						
							|  |  |  | 		/** Collection of factors */ | 
					
						
							|  |  |  | 		std::vector<shared_factor> factors_; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-23 05:33:00 +08:00
										 |  |  | 		/** For each variable a list of factor indices connected to it  */ | 
					
						
							|  |  |  | 		typedef std::map<std::string, std::list<int> > Indices; | 
					
						
							|  |  |  | 		Indices indices_; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 	public: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 12:56:59 +08:00
										 |  |  | 		/** Default constructor */ | 
					
						
							|  |  |  | 		FactorGraph() {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/** convert from Bayes net */ | 
					
						
							|  |  |  | 		template<class Conditional> | 
					
						
							|  |  |  | 		FactorGraph(const BayesNet<Conditional>& bayesNet); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-26 06:27:18 +08:00
										 |  |  | 		/** print out graph */ | 
					
						
							|  |  |  | 		void print(const std::string& s = "FactorGraph") const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/** Check equality */ | 
					
						
							|  |  |  | 		bool equals(const FactorGraph& fg, double tol = 1e-9) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 		/** STL like, return the iterator pointing to the first factor */ | 
					
						
							| 
									
										
										
										
											2009-10-26 06:27:18 +08:00
										 |  |  | 		inline const_iterator begin() const { | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 			return factors_.begin(); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/** STL like, return the iterator pointing to the last factor */ | 
					
						
							| 
									
										
										
										
											2009-10-26 06:27:18 +08:00
										 |  |  | 		inline const_iterator end() const { | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 			return factors_.end(); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/** clear the factor graph */ | 
					
						
							| 
									
										
										
										
											2009-10-26 06:27:18 +08:00
										 |  |  | 		inline void clear() { | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 			factors_.clear(); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/** Get a specific factor by index */ | 
					
						
							| 
									
										
										
										
											2009-10-26 06:27:18 +08:00
										 |  |  | 		inline shared_factor operator[](size_t i) const { | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 			return factors_[i]; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-29 12:11:23 +08:00
										 |  |  | 		/** return the number of factors and NULLS */ | 
					
						
							|  |  |  | 	  inline size_t size() const { return factors_.size();} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/** return the number valid factors */ | 
					
						
							|  |  |  | 	  size_t nrFactors() const; | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/** Add a factor */ | 
					
						
							| 
									
										
										
										
											2009-10-23 05:33:00 +08:00
										 |  |  | 		void push_back(shared_factor factor); | 
					
						
							| 
									
										
										
										
											2009-08-31 10:40:26 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-13 12:13:03 +08:00
										 |  |  | 		/**
 | 
					
						
							|  |  |  | 		 * Compute colamd ordering | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		Ordering getOrdering() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-29 12:49:13 +08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Return indices for all factors that involve the given node | 
					
						
							|  |  |  |      * @param key the key for the given node | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     std::list<int> factors(const std::string& key) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-29 12:11:23 +08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * find all the factors that involve the given node and remove them | 
					
						
							|  |  |  |      * from the factor graph | 
					
						
							|  |  |  |      * @param key the key for the given node | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-10-29 13:39:13 +08:00
										 |  |  | 		std::vector<shared_factor> findAndRemoveFactors(const std::string& key); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * extract and combine all the factors that involve a given node | 
					
						
							|  |  |  |      * @param key the key for the given node | 
					
						
							|  |  |  |      * @return the combined linear factor | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     shared_factor removeAndCombineFactors(const std::string& key); | 
					
						
							| 
									
										
										
										
											2009-10-29 12:11:23 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-29 22:34:34 +08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Eliminate a single node yielding a Conditional | 
					
						
							|  |  |  |      * Eliminates the factors from the factor graph through findAndRemoveFactors | 
					
						
							|  |  |  |      * and adds a new factor on the separator to the factor graph | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 		template<class Conditional> | 
					
						
							|  |  |  | 		boost::shared_ptr<Conditional> eliminateOne(const std::string& key); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-05 12:56:59 +08:00
										 |  |  | 		/**
 | 
					
						
							|  |  |  | 		 * eliminate factor graph using the given (not necessarily complete) | 
					
						
							|  |  |  | 		 * ordering, yielding a chordal Bayes net and (partially eliminated) FG | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		template<class Conditional> | 
					
						
							| 
									
										
										
										
											2009-11-05 14:30:10 +08:00
										 |  |  | 		boost::shared_ptr<BayesNet<Conditional> > eliminate(boost::shared_ptr<BayesNet<Conditional> > bayesNet, const Ordering& ordering); | 
					
						
							| 
									
										
										
										
											2009-11-05 12:56:59 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-31 12:13:57 +08:00
										 |  |  | 	private: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/** Serialization function */ | 
					
						
							|  |  |  | 		friend class boost::serialization::access; | 
					
						
							|  |  |  | 		template<class Archive> | 
					
						
							|  |  |  | 		void serialize(Archive & ar, const unsigned int version) { | 
					
						
							|  |  |  | 			ar & BOOST_SERIALIZATION_NVP(factors_); | 
					
						
							| 
									
										
										
										
											2009-10-29 12:11:23 +08:00
										 |  |  | 			ar & BOOST_SERIALIZATION_NVP(indices_); | 
					
						
							| 
									
										
										
										
											2009-08-31 12:13:57 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	}; // FactorGraph
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | } // namespace gtsam
 | 
					
						
							| 
									
										
										
										
											2009-10-07 02:25:04 +08:00
										 |  |  | 
 |