| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  *  @file  planarSLAM.h | 
					
						
							|  |  |  |  *  @brief: bearing/range measurements in 2D plane | 
					
						
							|  |  |  |  *  @authors Frank Dellaert | 
					
						
							|  |  |  |  **/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "Key.h"
 | 
					
						
							|  |  |  | #include "Pose2.h"
 | 
					
						
							|  |  |  | #include "Point2.h"
 | 
					
						
							|  |  |  | #include "NonlinearFactor.h"
 | 
					
						
							|  |  |  | #include "TupleConfig.h"
 | 
					
						
							|  |  |  | #include "NonlinearEquality.h"
 | 
					
						
							| 
									
										
										
										
											2010-02-19 10:48:47 +08:00
										 |  |  | #include "PriorFactor.h"
 | 
					
						
							| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  | #include "BetweenFactor.h"
 | 
					
						
							|  |  |  | #include "NonlinearFactorGraph.h"
 | 
					
						
							|  |  |  | #include "NonlinearOptimizer.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // We use gtsam namespace for generally useful factors
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Binary factor for a bearing measurement | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	template<class Config, class PoseKey, class PointKey> | 
					
						
							|  |  |  | 	class BearingFactor: public NonlinearFactor2<Config, PoseKey, Pose2, | 
					
						
							|  |  |  | 			PointKey, Point2> { | 
					
						
							|  |  |  | 	private: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		Rot2 z_; /** measurement */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		typedef NonlinearFactor2<Config, PoseKey, Pose2, PointKey, Point2> Base; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	public: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		BearingFactor(); /* Default constructor */ | 
					
						
							|  |  |  | 		BearingFactor(const PoseKey& i, const PointKey& j, const Rot2& z, | 
					
						
							| 
									
										
										
										
											2010-01-23 01:36:57 +08:00
										 |  |  | 				const SharedGaussian& model) : | 
					
						
							| 
									
										
										
										
											2010-01-18 13:38:53 +08:00
										 |  |  | 			Base(model, i, j), z_(z) { | 
					
						
							| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/** h(x)-z -> between(z,h(x)) for Rot2 manifold */ | 
					
						
							|  |  |  | 		Vector evaluateError(const Pose2& pose, const Point2& point, | 
					
						
							|  |  |  | 				boost::optional<Matrix&> H1, boost::optional<Matrix&> H2) const { | 
					
						
							|  |  |  | 			Rot2 hx = bearing(pose, point, H1, H2); | 
					
						
							|  |  |  | 			return logmap(between(z_, hx)); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	}; // BearingFactor
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Binary factor for a range measurement | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	template<class Config, class PoseKey, class PointKey> | 
					
						
							|  |  |  | 	class RangeFactor: public NonlinearFactor2<Config, PoseKey, Pose2, PointKey, | 
					
						
							|  |  |  | 			Point2> { | 
					
						
							|  |  |  | 	private: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		double z_; /** measurement */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		typedef NonlinearFactor2<Config, PoseKey, Pose2, PointKey, Point2> Base; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	public: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		RangeFactor(); /* Default constructor */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-18 13:38:53 +08:00
										 |  |  | 		RangeFactor(const PoseKey& i, const PointKey& j, double z, | 
					
						
							| 
									
										
										
										
											2010-01-23 01:36:57 +08:00
										 |  |  | 				const SharedGaussian& model) : | 
					
						
							| 
									
										
										
										
											2010-01-18 13:38:53 +08:00
										 |  |  | 			Base(model, i, j), z_(z) { | 
					
						
							| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/** h(x)-z */ | 
					
						
							|  |  |  | 		Vector evaluateError(const Pose2& pose, const Point2& point, | 
					
						
							|  |  |  | 				boost::optional<Matrix&> H1, boost::optional<Matrix&> H2) const { | 
					
						
							|  |  |  | 			double hx = gtsam::range(pose, point, H1, H2); | 
					
						
							|  |  |  | 			return Vector_(1, hx - z_); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	}; // RangeFactor
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Use planarSLAM namespace for specific SLAM instance
 | 
					
						
							|  |  |  | 	namespace planarSLAM { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Keys and Config
 | 
					
						
							| 
									
										
										
										
											2010-01-18 03:34:57 +08:00
										 |  |  | 		typedef TypedSymbol<Pose2, 'x'> PoseKey; | 
					
						
							|  |  |  | 		typedef TypedSymbol<Point2, 'l'> PointKey; | 
					
						
							| 
									
										
										
										
											2010-02-20 08:28:10 +08:00
										 |  |  | 		typedef LieConfig<PoseKey, Pose2> PoseConfig; | 
					
						
							|  |  |  | 		typedef LieConfig<PointKey, Point2> PointConfig; | 
					
						
							| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  | 		typedef PairConfig<PoseKey, Pose2, PointKey, Point2> Config; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Factors
 | 
					
						
							|  |  |  | 		typedef NonlinearEquality<Config, PoseKey, Pose2> Constraint; | 
					
						
							| 
									
										
										
										
											2010-02-19 10:48:47 +08:00
										 |  |  | 		typedef PriorFactor<Config, PoseKey, Pose2> Prior; | 
					
						
							| 
									
										
										
										
											2010-01-18 13:38:53 +08:00
										 |  |  | 		typedef BetweenFactor<Config, PoseKey, Pose2> Odometry; | 
					
						
							| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  | 		typedef BearingFactor<Config, PoseKey, PointKey> Bearing; | 
					
						
							|  |  |  | 		typedef RangeFactor<Config, PoseKey, PointKey> Range; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Graph
 | 
					
						
							|  |  |  | 		struct Graph: public NonlinearFactorGraph<Config> { | 
					
						
							| 
									
										
										
										
											2010-02-19 10:48:47 +08:00
										 |  |  | 			void addPrior(const PoseKey& i, const Pose2& p, const SharedGaussian& model); | 
					
						
							| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  | 			void addPoseConstraint(const PoseKey& i, const Pose2& p); | 
					
						
							| 
									
										
										
										
											2010-01-18 13:38:53 +08:00
										 |  |  | 			void addOdometry(const PoseKey& i, const PoseKey& j, const Pose2& z, | 
					
						
							| 
									
										
										
										
											2010-01-23 01:36:57 +08:00
										 |  |  | 					const SharedGaussian& model); | 
					
						
							| 
									
										
										
										
											2010-01-18 13:38:53 +08:00
										 |  |  | 			void addBearing(const PoseKey& i, const PointKey& j, const Rot2& z, | 
					
						
							| 
									
										
										
										
											2010-01-23 01:36:57 +08:00
										 |  |  | 					const SharedGaussian& model); | 
					
						
							| 
									
										
										
										
											2010-01-18 13:38:53 +08:00
										 |  |  | 			void addRange(const PoseKey& i, const PointKey& j, double z, | 
					
						
							| 
									
										
										
										
											2010-01-23 01:36:57 +08:00
										 |  |  | 					const SharedGaussian& model); | 
					
						
							| 
									
										
										
										
											2010-01-16 09:16:59 +08:00
										 |  |  | 		}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		// Optimizer
 | 
					
						
							|  |  |  | 		typedef NonlinearOptimizer<Graph, Config> Optimizer; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} // planarSLAM
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace gtsam
 | 
					
						
							|  |  |  | 
 |