| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  *  @file   PoseToPointFactor.hpp | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  |  *  @brief  This factor can be used to track a 3D landmark over time by | 
					
						
							|  |  |  |  *providing local measurements of its location. | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  |  *  @author David Wisth | 
					
						
							|  |  |  |  **/ | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <gtsam/geometry/Point3.h>
 | 
					
						
							|  |  |  | #include <gtsam/geometry/Pose3.h>
 | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  | #include <gtsam/nonlinear/NonlinearFactor.h>
 | 
					
						
							|  |  |  | #include <ostream>
 | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * A class for a measurement between a pose and a point. | 
					
						
							|  |  |  |  * @addtogroup SLAM | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  | class PoseToPointFactor : public NoiseModelFactor2<Pose3, Point3> { | 
					
						
							|  |  |  |  private: | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  |   typedef PoseToPointFactor This; | 
					
						
							|  |  |  |   typedef NoiseModelFactor2<Pose3, Point3> Base; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  |   Point3 measured_; /** the point measurement in local coordinates */ | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  |  public: | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  |   // shorthand for a smart pointer to a factor
 | 
					
						
							|  |  |  |   typedef boost::shared_ptr<PoseToPointFactor> shared_ptr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** default constructor - only use for serialization */ | 
					
						
							|  |  |  |   PoseToPointFactor() {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Constructor */ | 
					
						
							|  |  |  |   PoseToPointFactor(Key key1, Key key2, const Point3& measured, | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  |                     const SharedNoiseModel& model) | 
					
						
							|  |  |  |       : Base(model, key1, key2), measured_(measured) {} | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   virtual ~PoseToPointFactor() {} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** implement functions needed for Testable */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** print */ | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  |   virtual void print(const std::string& s, const KeyFormatter& keyFormatter = | 
					
						
							|  |  |  |                                                DefaultKeyFormatter) const { | 
					
						
							|  |  |  |     std::cout << s << "PoseToPointFactor(" << keyFormatter(this->key1()) << "," | 
					
						
							|  |  |  |               << keyFormatter(this->key2()) << ")\n" | 
					
						
							|  |  |  |               << "  measured: " << measured_.transpose() << std::endl; | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  |     this->noiseModel_->print("  noise model: "); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** equals */ | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  |   virtual bool equals(const NonlinearFactor& expected, | 
					
						
							|  |  |  |                       double tol = 1e-9) const { | 
					
						
							|  |  |  |     const This* e = dynamic_cast<const This*>(&expected); | 
					
						
							|  |  |  |     return e != nullptr && Base::equals(*e, tol) && | 
					
						
							|  |  |  |            traits<Point3>::Equals(this->measured_, e->measured_, tol); | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** implement functions needed to derive from Factor */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** vector of errors
 | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  |    * @brief Error = wTwi.inverse()*wPwp - measured_ | 
					
						
							|  |  |  |    * @param wTwi The pose of the sensor in world coordinates | 
					
						
							|  |  |  |    * @param wPwp The estimated point location in world coordinates | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Note: measured_ and the error are in local coordiantes. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   Vector evaluateError(const Pose3& wTwi, const Point3& wPwp, | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  |                        boost::optional<Matrix&> H1 = boost::none, | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  |                        boost::optional<Matrix&> H2 = boost::none) const { | 
					
						
							|  |  |  |     return wTwi.transformTo(wPwp, H1, H2) - measured_; | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** return the measured */ | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  |   const Point3& measured() const { return measured_; } | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  |  private: | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  |   /** Serialization function */ | 
					
						
							|  |  |  |   friend class boost::serialization::access; | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  |   template <class ARCHIVE> | 
					
						
							|  |  |  |   void serialize(ARCHIVE& ar, const unsigned int /*version*/) { | 
					
						
							|  |  |  |     ar& boost::serialization::make_nvp( | 
					
						
							|  |  |  |         "NoiseModelFactor2", boost::serialization::base_object<Base>(*this)); | 
					
						
							|  |  |  |     ar& BOOST_SERIALIZATION_NVP(measured_); | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  | };  // \class PoseToPointFactor
 | 
					
						
							| 
									
										
										
										
											2020-06-20 06:46:06 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-20 07:45:24 +08:00
										 |  |  | }  // namespace gtsam
 |