| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | /* ----------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-19 14:13:59 +08:00
										 |  |  |  * GTSAM Copyright 2010, Georgia Tech Research Corporation, | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  |  * Atlanta, Georgia 30332-0415 | 
					
						
							|  |  |  |  * All Rights Reserved | 
					
						
							|  |  |  |  * Authors: Frank Dellaert, et al. (see THANKS for the full author list) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  * See LICENSE for the license information | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  * -------------------------------------------------------------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @file    IncrementalFixedLagSmoother.h | 
					
						
							|  |  |  |  * @brief   An iSAM2-based fixed-lag smoother. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @author  Michael Kaess, Stephen Williams | 
					
						
							|  |  |  |  * @date    Oct 14, 2012 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // \callgraph
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-21 00:03:36 +08:00
										 |  |  | #include <gtsam/nonlinear/FixedLagSmoother.h>
 | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | #include <gtsam/nonlinear/ISAM2.h>
 | 
					
						
							| 
									
										
										
										
											2023-03-08 03:31:58 +08:00
										 |  |  | #include "gtsam_unstable/dllexport.h"
 | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * This is a base class for the various HMF2 implementations. The HMF2 eliminates the factor graph | 
					
						
							|  |  |  |  * such that the active states are placed in/near the root. This base class implements a function | 
					
						
							|  |  |  |  * to calculate the ordering, and an update function to incorporate new factors into the HMF. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-05-14 14:44:46 +08:00
										 |  |  | class GTSAM_UNSTABLE_EXPORT IncrementalFixedLagSmoother: public FixedLagSmoother { | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-14 14:44:46 +08:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /// Typedef for a shared pointer to an Incremental Fixed-Lag Smoother
 | 
					
						
							| 
									
										
										
										
											2023-01-18 06:05:12 +08:00
										 |  |  |   typedef std::shared_ptr<IncrementalFixedLagSmoother> shared_ptr; | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /** default constructor */ | 
					
						
							| 
									
										
										
										
											2015-05-14 14:44:46 +08:00
										 |  |  |   IncrementalFixedLagSmoother(double smootherLag = 0.0, | 
					
						
							| 
									
										
										
										
											2019-10-18 00:23:00 +08:00
										 |  |  |       const ISAM2Params& parameters = DefaultISAM2Params()) : | 
					
						
							|  |  |  |       FixedLagSmoother(smootherLag), isam_(parameters) { | 
					
						
							| 
									
										
										
										
											2015-05-14 13:26:24 +08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /** destructor */ | 
					
						
							| 
									
										
										
										
											2021-01-29 12:02:13 +08:00
										 |  |  |   ~IncrementalFixedLagSmoother() override { | 
					
						
							| 
									
										
										
										
											2015-05-14 13:26:24 +08:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /** Print the factor for debugging and testing (implementing Testable) */ | 
					
						
							| 
									
										
										
										
											2021-01-29 12:02:13 +08:00
										 |  |  |   void print(const std::string& s = "IncrementalFixedLagSmoother:\n", | 
					
						
							| 
									
										
										
										
											2019-05-19 10:47:58 +08:00
										 |  |  |       const KeyFormatter& keyFormatter = DefaultKeyFormatter) const override; | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /** Check if two IncrementalFixedLagSmoother Objects are equal */ | 
					
						
							| 
									
										
										
										
											2021-01-29 12:02:13 +08:00
										 |  |  |   bool equals(const FixedLagSmoother& rhs, double tol = 1e-9) const override; | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-14 13:26:24 +08:00
										 |  |  |   /**
 | 
					
						
							|  |  |  |    * Add new factors, updating the solution and re-linearizing as needed. | 
					
						
							|  |  |  |    * @param newFactors new factors on old and/or new variables | 
					
						
							|  |  |  |    * @param newTheta new values for new variables only | 
					
						
							|  |  |  |    * @param timestamps an (optional) map from keys to real time stamps | 
					
						
							| 
									
										
										
										
											2019-01-22 07:10:40 +08:00
										 |  |  |    * @param factorsToRemove an (optional) list of factors to remove. | 
					
						
							| 
									
										
										
										
											2015-05-14 13:26:24 +08:00
										 |  |  |    */ | 
					
						
							|  |  |  |   Result update(const NonlinearFactorGraph& newFactors = NonlinearFactorGraph(), | 
					
						
							| 
									
										
										
										
											2019-01-22 07:03:38 +08:00
										 |  |  |                 const Values& newTheta = Values(), //
 | 
					
						
							|  |  |  |                 const KeyTimestampMap& timestamps = KeyTimestampMap(), | 
					
						
							| 
									
										
										
										
											2019-05-19 10:47:58 +08:00
										 |  |  |                 const FactorIndices& factorsToRemove = FactorIndices()) override; | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /** Compute an estimate from the incomplete linear delta computed during the last update.
 | 
					
						
							|  |  |  |    * This delta is incomplete because it was not updated below wildfire_threshold.  If only | 
					
						
							|  |  |  |    * a single variable is needed, it is faster to call calculateEstimate(const KEY&). | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2019-05-19 10:47:58 +08:00
										 |  |  |   Values calculateEstimate() const override { | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  |     return isam_.calculateEstimate(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Compute an estimate for a single variable using its incomplete linear delta computed
 | 
					
						
							|  |  |  |    * during the last update.  This is faster than calling the no-argument version of | 
					
						
							|  |  |  |    * calculateEstimate, which operates on all variables. | 
					
						
							|  |  |  |    * @param key | 
					
						
							|  |  |  |    * @return | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   template<class VALUE> | 
					
						
							|  |  |  |   VALUE calculateEstimate(Key key) const { | 
					
						
							|  |  |  |     return isam_.calculateEstimate<VALUE>(key); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** return the current set of iSAM2 parameters */ | 
					
						
							|  |  |  |   const ISAM2Params& params() const { | 
					
						
							|  |  |  |     return isam_.params(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-11 01:15:03 +08:00
										 |  |  |   /** Access the current set of factors */ | 
					
						
							|  |  |  |   const NonlinearFactorGraph& getFactors() const { | 
					
						
							|  |  |  |     return isam_.getFactorsUnsafe(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Access the current linearization point */ | 
					
						
							|  |  |  |   const Values& getLinearizationPoint() const { | 
					
						
							|  |  |  |     return isam_.getLinearizationPoint(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Access the current set of deltas to the linearization point */ | 
					
						
							|  |  |  |   const VectorValues& getDelta() const { | 
					
						
							|  |  |  |     return isam_.getDelta(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-14 13:26:24 +08:00
										 |  |  |   /// Calculate marginal covariance on given variable
 | 
					
						
							|  |  |  |   Matrix marginalCovariance(Key key) const { | 
					
						
							|  |  |  |     return isam_.marginalCovariance(key); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-25 02:19:02 +08:00
										 |  |  |   /// Get results of latest isam2 update
 | 
					
						
							| 
									
										
										
										
											2019-01-30 05:11:51 +08:00
										 |  |  |   const ISAM2Result& getISAM2Result() const{ return isamResult_; } | 
					
						
							| 
									
										
										
										
											2016-08-25 02:19:02 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-30 06:31:07 +08:00
										 |  |  |   /// Get the iSAM2 object which is used for the inference internally
 | 
					
						
							|  |  |  |   const ISAM2& getISAM2() const { return isam_; } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-14 14:44:46 +08:00
										 |  |  | protected: | 
					
						
							| 
									
										
										
										
											2019-10-17 21:32:21 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-18 00:23:00 +08:00
										 |  |  |   /** Create default parameters */ | 
					
						
							|  |  |  |   static ISAM2Params DefaultISAM2Params() { | 
					
						
							| 
									
										
										
										
											2019-10-17 21:32:21 +08:00
										 |  |  |     ISAM2Params params; | 
					
						
							|  |  |  |     params.findUnusedFactorSlots = true; | 
					
						
							|  |  |  |     return params; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  |   /** An iSAM2 object used to perform inference. The smoother lag is controlled
 | 
					
						
							|  |  |  |    * by what factors are removed each iteration */ | 
					
						
							|  |  |  |   ISAM2 isam_; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-25 02:19:02 +08:00
										 |  |  |   /** Store results of latest isam2 update */ | 
					
						
							| 
									
										
										
										
											2019-01-30 05:11:51 +08:00
										 |  |  |   ISAM2Result isamResult_; | 
					
						
							| 
									
										
										
										
											2016-08-25 02:19:02 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  |   /** Erase any keys associated with timestamps before the provided time */ | 
					
						
							|  |  |  |   void eraseKeysBefore(double timestamp); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** Fill in an iSAM2 ConstrainedKeys structure such that the provided keys are eliminated before all others */ | 
					
						
							| 
									
										
										
										
											2016-06-19 14:13:59 +08:00
										 |  |  |   void createOrderingConstraints(const KeyVector& marginalizableKeys, | 
					
						
							| 
									
										
										
										
											2023-01-13 05:35:48 +08:00
										 |  |  |       std::optional<FastMap<Key, int> >& constrainedKeys) const; | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-14 14:44:46 +08:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  |   /** Private methods for printing debug information */ | 
					
						
							| 
									
										
										
										
											2015-05-14 14:44:46 +08:00
										 |  |  |   static void PrintKeySet(const std::set<Key>& keys, const std::string& label = | 
					
						
							|  |  |  |       "Keys:"); | 
					
						
							| 
									
										
										
										
											2013-08-15 03:12:24 +08:00
										 |  |  |   static void PrintSymbolicFactor(const GaussianFactor::shared_ptr& factor); | 
					
						
							| 
									
										
										
										
											2015-05-14 14:44:46 +08:00
										 |  |  |   static void PrintSymbolicGraph(const GaussianFactorGraph& graph, | 
					
						
							|  |  |  |       const std::string& label = "Factor Graph:"); | 
					
						
							|  |  |  |   static void PrintSymbolicTree(const gtsam::ISAM2& isam, | 
					
						
							|  |  |  |       const std::string& label = "Bayes Tree:"); | 
					
						
							|  |  |  |   static void PrintSymbolicTreeHelper( | 
					
						
							|  |  |  |       const gtsam::ISAM2Clique::shared_ptr& clique, const std::string indent = | 
					
						
							|  |  |  |           ""); | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-14 13:26:24 +08:00
										 |  |  | }; | 
					
						
							|  |  |  | // IncrementalFixedLagSmoother
 | 
					
						
							| 
									
										
										
										
											2013-02-28 04:23:47 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-14 13:26:24 +08:00
										 |  |  | }/// namespace gtsam
 |