| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file    FGConfig.h | 
					
						
							|  |  |  |  * @brief   Factor Graph Configuration | 
					
						
							|  |  |  |  * @author  Carlos Nieto | 
					
						
							|  |  |  |  * @author  Christian Potthast | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // \callgraph
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <map>
 | 
					
						
							|  |  |  | #include <boost/serialization/map.hpp>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  | #include "Testable.h"
 | 
					
						
							|  |  |  | #include "Vector.h"
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  |   /** Factor Graph Configuration */ | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  |   class FGConfig : public Testable<FGConfig> { | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   protected: | 
					
						
							|  |  |  |     /** Map from string indices to values */ | 
					
						
							|  |  |  |     std::map<std::string, Vector> values; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   public: | 
					
						
							|  |  |  |     typedef std::map<std::string, Vector>::iterator iterator; | 
					
						
							|  |  |  |     typedef std::map<std::string, Vector>::const_iterator const_iterator; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  |     FGConfig():Testable<FGConfig>() {} | 
					
						
							|  |  |  |     FGConfig(const FGConfig& cfg_in) : Testable<FGConfig>(), values(cfg_in.values) {} | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  |     virtual ~FGConfig() {} | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** return all the nodes in the graph **/ | 
					
						
							| 
									
										
										
										
											2009-08-28 23:38:27 +08:00
										 |  |  |     std::vector<std::string> get_names() const { | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |       std::vector<std::string> names; | 
					
						
							| 
									
										
										
										
											2009-08-28 23:38:27 +08:00
										 |  |  |       for(const_iterator it=values.begin(); it!=values.end(); it++) | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |         names.push_back(it->first); | 
					
						
							|  |  |  |       return names; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Insert a value into the configuration with a given index */ | 
					
						
							|  |  |  |     FGConfig& insert(const std::string& name, const Vector& val) { | 
					
						
							|  |  |  |       values.insert(std::make_pair(name,val)); | 
					
						
							|  |  |  |       return *this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  |      * Add a delta config, needed for use in NonlinearOptimizer | 
					
						
							|  |  |  |      * For FGConfig, this is just addition. | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  |     FGConfig exmap(const FGConfig & delta) const; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   | 
					
						
							| 
									
										
										
										
											2009-08-29 04:06:29 +08:00
										 |  |  |     const_iterator begin() const {return values.begin();} | 
					
						
							|  |  |  |     const_iterator end()   const {return values.end();} | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** get a vector in the configuration by name */ | 
					
						
							|  |  |  |     Vector get(const std::string& name) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** operator[] syntax for get */ | 
					
						
							|  |  |  |     inline Vector operator[](const std::string& name) const { return get(name); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     bool contains(const std::string& name) const { | 
					
						
							|  |  |  |       const_iterator it = values.find(name); | 
					
						
							|  |  |  |       if (it==values.end()) | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  |       return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** size of the configurations */ | 
					
						
							|  |  |  |     size_t size() const { | 
					
						
							|  |  |  |       return values.size(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** print */ | 
					
						
							|  |  |  |     void print(const std::string& name = "") const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** equals, for unit testing */ | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  |     bool equals(const FGConfig& expected, double tol=1e-9) const; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     void clear() {values.clear();} | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |   private: | 
					
						
							|  |  |  |     /** Serialization function */ | 
					
						
							|  |  |  |     friend class boost::serialization::access; | 
					
						
							|  |  |  |     template<class Archive> | 
					
						
							|  |  |  |       void serialize(Archive & ar, const unsigned int version) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       ar & BOOST_SERIALIZATION_NVP(values); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | } |