| 
									
										
										
										
											2010-01-02 18:33:33 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file    VectorConfig.cpp | 
					
						
							|  |  |  |  * @brief   Pose2Graph Configuration | 
					
						
							|  |  |  |  * @author  Frank Dellaert | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/foreach.hpp>
 | 
					
						
							|  |  |  | #include "VectorConfig.h"
 | 
					
						
							|  |  |  | #include "Pose2Config.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // trick from some reading group
 | 
					
						
							|  |  |  | #define FOREACH_PAIR( KEY, VAL, COL) BOOST_FOREACH (boost::tie(KEY,VAL),COL)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | using namespace std; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ************************************************************************* */ | 
					
						
							|  |  |  | 	const Pose2& Pose2Config::get(std::string key) const { | 
					
						
							|  |  |  | 		std::map<std::string, Pose2>::const_iterator it = values_.find(key); | 
					
						
							|  |  |  | 		if (it == values_.end()) throw std::invalid_argument("invalid key"); | 
					
						
							|  |  |  | 		return it->second; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ************************************************************************* */ | 
					
						
							|  |  |  | 	void Pose2Config::insert(const std::string& name, const Pose2& val) { | 
					
						
							|  |  |  | 		values_.insert(make_pair(name, val)); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ************************************************************************* */ | 
					
						
							|  |  |  | 	bool Pose2Config::equals(const Pose2Config& expected, double tol) const { | 
					
						
							|  |  |  | 		if (values_.size() != expected.values_.size()) return false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// iterate over all nodes
 | 
					
						
							|  |  |  | 		string j; | 
					
						
							|  |  |  | 		Pose2 pj; | 
					
						
							|  |  |  | 		FOREACH_PAIR(j, pj, values_) | 
					
						
							|  |  |  | 			if(!pj.equals(expected.get(j),tol)) | 
					
						
							|  |  |  | 				return false; | 
					
						
							|  |  |  | 		return true; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ************************************************************************* */ | 
					
						
							|  |  |  | 	void Pose2Config::print(const std::string &s) const { | 
					
						
							|  |  |  | 		std::cout << "Pose2Config " << s << ", size " << values_.size() << "\n"; | 
					
						
							|  |  |  | 		std::string j; Pose2 pj; | 
					
						
							|  |  |  | 		FOREACH_PAIR(j, pj, values_) | 
					
						
							|  |  |  | 			pj.print(j + ": "); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  | 	Pose2Config expmap(const Pose2Config& c, const VectorConfig& delta) { | 
					
						
							| 
									
										
										
										
											2010-01-02 18:33:33 +08:00
										 |  |  | 		Pose2Config newConfig; | 
					
						
							|  |  |  | 		std::string j; Pose2 pj; | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  | 		FOREACH_PAIR(j, pj, c.values_) { | 
					
						
							| 
									
										
										
										
											2010-01-02 18:33:33 +08:00
										 |  |  | 			if (delta.contains(j)) { | 
					
						
							|  |  |  | 				const Vector& dj = delta[j]; | 
					
						
							|  |  |  | 				//check_size(j,vj,dj);
 | 
					
						
							| 
									
										
										
										
											2010-01-08 08:40:17 +08:00
										 |  |  | 				newConfig.insert(j, expmap(pj,dj)); | 
					
						
							| 
									
										
										
										
											2010-01-02 18:33:33 +08:00
										 |  |  | 			} else | 
					
						
							|  |  |  | 				newConfig.insert(j, pj); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return newConfig; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ************************************************************************* */ | 
					
						
							|  |  |  | } // namespace
 |