| 
									
										
										
										
											2010-04-02 06:02:31 +08:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * BearingRangeFactor.h | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *   Created on: Apr 1, 2010 | 
					
						
							|  |  |  |  *       Author: Kai Ni | 
					
						
							|  |  |  |  *  Description: a single factor contains both the bearing and the range to prevent handle to pair bearing and range factors | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "BearingFactor.h"
 | 
					
						
							|  |  |  | #include "RangeFactor.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/**
 | 
					
						
							|  |  |  | 	 * Binary factor for a bearing measurement | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	template<class Config, class PoseKey, class PointKey> | 
					
						
							|  |  |  | 	class BearingRangeFactor: public NonlinearFactor2<Config, PoseKey, Pose2, | 
					
						
							|  |  |  | 	PointKey, Point2> { | 
					
						
							|  |  |  | 	private: | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-03 11:36:10 +08:00
										 |  |  | 		// the measurement
 | 
					
						
							|  |  |  | 		Rot2 bearing_; | 
					
						
							|  |  |  | 		double range_; | 
					
						
							| 
									
										
										
										
											2010-04-02 06:02:31 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		typedef NonlinearFactor2<Config, PoseKey, Pose2, PointKey, Point2> Base; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	public: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		BearingRangeFactor(); /* Default constructor */ | 
					
						
							| 
									
										
										
										
											2010-04-03 11:36:10 +08:00
										 |  |  | 		BearingRangeFactor(const PoseKey& i, const PointKey& j, const Rot2& bearing, const double range, | 
					
						
							| 
									
										
										
										
											2010-04-02 06:02:31 +08:00
										 |  |  | 				const SharedGaussian& model) : | 
					
						
							| 
									
										
										
										
											2010-04-03 11:36:10 +08:00
										 |  |  | 					Base(model, i, j), bearing_(bearing), range_(range) { | 
					
						
							| 
									
										
										
										
											2010-04-02 06:02:31 +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 { | 
					
						
							| 
									
										
										
										
											2010-04-02 08:04:11 +08:00
										 |  |  | 			Matrix H11, H21, H12, H22; | 
					
						
							|  |  |  | 			boost::optional<Matrix&> H11_ = H1 ? boost::optional<Matrix&>(H11) : boost::optional<Matrix&>(); | 
					
						
							|  |  |  | 			boost::optional<Matrix&> H21_ = H1 ? boost::optional<Matrix&>(H21) : boost::optional<Matrix&>(); | 
					
						
							|  |  |  | 			boost::optional<Matrix&> H12_ = H2 ? boost::optional<Matrix&>(H12) : boost::optional<Matrix&>(); | 
					
						
							|  |  |  | 			boost::optional<Matrix&> H22_ = H2 ? boost::optional<Matrix&>(H22) : boost::optional<Matrix&>(); | 
					
						
							| 
									
										
										
										
											2010-04-03 11:36:10 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			Rot2 y1 = gtsam::bearing(pose, point, H11_, H12_); | 
					
						
							|  |  |  | 			Vector e1 = logmap(between(bearing_, y1)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			double y2 = gtsam::range(pose, point, H21_, H22_); | 
					
						
							|  |  |  | 			Vector e2 = Vector_(1, y2 - range_); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (H1) *H1 = gtsam::stack(2, &H11, &H21); | 
					
						
							|  |  |  | 			if (H2) *H2 = gtsam::stack(2, &H12, &H22); | 
					
						
							| 
									
										
										
										
											2010-04-02 06:02:31 +08:00
										 |  |  | 			return concatVectors(2, &e1, &e2); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/** return the measured */ | 
					
						
							|  |  |  | 		inline const std::pair<Rot2, double> measured() const { | 
					
						
							| 
									
										
										
										
											2010-04-03 11:36:10 +08:00
										 |  |  | 			return std::make_pair(bearing_, range_); | 
					
						
							| 
									
										
										
										
											2010-04-02 06:02:31 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	}; // BearingRangeFactor
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace gtsam
 |