| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file    LinearFactorGraph.h | 
					
						
							|  |  |  |  * @brief   Linear Factor Graph where all factors are Gaussians | 
					
						
							|  |  |  |  * @author  Kai Ni | 
					
						
							|  |  |  |  * @author  Christian Potthast | 
					
						
							|  |  |  |  * @author  Alireza Fathi | 
					
						
							|  |  |  |  */  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // $Id: LinearFactorGraph.h,v 1.24 2009/08/14 20:48:51 acunning Exp $
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // \callgraph
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/shared_ptr.hpp>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "LinearFactor.h"
 | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  | #include "VectorConfig.h"
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | #include "FactorGraph.h"
 | 
					
						
							| 
									
										
										
										
											2009-10-21 02:57:33 +08:00
										 |  |  | #include "ChordalBayesNet.h"
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-07 02:25:04 +08:00
										 |  |  |   /**
 | 
					
						
							|  |  |  |    * A Linear Factor Graph is a factor graph where all factors are Gaussian, i.e. | 
					
						
							|  |  |  |    *   Factor == LinearFactor | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |    *   VectorConfig = A configuration of vectors | 
					
						
							| 
									
										
										
										
											2009-10-07 02:25:04 +08:00
										 |  |  |    * Most of the time, linear factor graphs arise by linearizing a non-linear factor graph. | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2009-10-29 12:11:23 +08:00
										 |  |  |   class LinearFactorGraph : public FactorGraph<LinearFactor> { | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   public: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Default constructor  | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     LinearFactorGraph() {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Constructor that receives a Chordal Bayes Net and returns a LinearFactorGraph | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-08-23 06:01:17 +08:00
										 |  |  |     LinearFactorGraph(const ChordalBayesNet& CBN); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-29 12:11:23 +08:00
										 |  |  | 		/** unnormalized error */ | 
					
						
							|  |  |  | 		double error(const VectorConfig& c) const { | 
					
						
							|  |  |  | 			double total_error = 0.; | 
					
						
							|  |  |  | 			// iterate over all the factors_ to accumulate the log probabilities
 | 
					
						
							|  |  |  | 			for (const_iterator factor = factors_.begin(); factor != factors_.end(); factor++) | 
					
						
							|  |  |  | 				total_error += (*factor)->error(c); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			return total_error; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/** Unnormalized probability. O(n) */ | 
					
						
							|  |  |  | 		double probPrime(const VectorConfig& c) const { | 
					
						
							|  |  |  | 			return exp(-0.5 * error(c)); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * given a chordal bayes net, sets the linear factor graph identical to that CBN | 
					
						
							|  |  |  |      * FD: imperative !! | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-08-23 06:01:17 +08:00
										 |  |  |     void setCBN(const ChordalBayesNet& CBN); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * find the separator, i.e. all the nodes that have at least one | 
					
						
							|  |  |  |      * common factor with the given node. FD: not used AFAIK. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     std::set<std::string> find_separator(const std::string& key) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * eliminate factor graph in place(!) in the given order, yielding | 
					
						
							|  |  |  |      * a chordal Bayes net | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-10-07 02:25:04 +08:00
										 |  |  |     boost::shared_ptr<ChordalBayesNet> eliminate(const Ordering& ordering); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 		 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Same as eliminate but allows for passing an incomplete ordering | 
					
						
							|  |  |  |      * that does not completely eliminate the graph | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-10-07 02:25:04 +08:00
										 |  |  |     boost::shared_ptr<ChordalBayesNet> eliminate_partially(const Ordering& ordering); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 		 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * optimize a linear factor graph | 
					
						
							|  |  |  |      * @param ordering fg in order | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |     VectorConfig optimize(const Ordering& ordering); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2009-08-25 10:36:30 +08:00
										 |  |  |      * static function that combines two factor graphs | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |      * @param const &lfg1 Linear factor graph | 
					
						
							|  |  |  |      * @param const &lfg2 Linear factor graph | 
					
						
							|  |  |  |      * @return a new combined factor graph | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-08-25 10:36:30 +08:00
										 |  |  |     static LinearFactorGraph combine2(const LinearFactorGraph& lfg1, | 
					
						
							|  |  |  | 				const LinearFactorGraph& lfg2); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 		 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * combine two factor graphs | 
					
						
							|  |  |  |      * @param *lfg Linear factor graph | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-08-25 00:54:22 +08:00
										 |  |  |     void combine(const LinearFactorGraph &lfg); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Find all variables and their dimensions | 
					
						
							|  |  |  |      * @return The set of all variable/dimension pairs | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     VariableSet variables() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Add zero-mean i.i.d. Gaussian prior terms to each variable | 
					
						
							|  |  |  |      * @param sigma Standard deviation of Gaussian | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     LinearFactorGraph add_priors(double sigma) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Return (dense) matrix associated with factor graph | 
					
						
							|  |  |  |      * @param ordering of variables needed for matrix column order | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     std::pair<Matrix,Vector> matrix (const Ordering& ordering) const; | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |