| 
									
										
										
										
											2010-10-14 12:54:38 +08:00
										 |  |  | /* ----------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  * GTSAM Copyright 2010, Georgia Tech Research Corporation,  | 
					
						
							|  |  |  |  * 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 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  * -------------------------------------------------------------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file    smallExample.h | 
					
						
							|  |  |  |  * @brief   Create small example with two poses and one landmark | 
					
						
							|  |  |  |  * @brief   smallExample | 
					
						
							|  |  |  |  * @author  Carlos Nieto | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // \callgraph
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  | #include <boost/shared_ptr.hpp>
 | 
					
						
							| 
									
										
										
										
											2010-10-09 06:04:47 +08:00
										 |  |  | #include <boost/tuple/tuple.hpp>
 | 
					
						
							|  |  |  | #include <boost/optional.hpp>
 | 
					
						
							|  |  |  | #include <gtsam/nonlinear/Ordering.h>
 | 
					
						
							| 
									
										
										
										
											2010-08-20 01:23:19 +08:00
										 |  |  | #include <gtsam/nonlinear/NonlinearFactorGraph.h>
 | 
					
						
							|  |  |  | #include <gtsam/slam/simulated2D.h>
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 	namespace example { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		typedef simulated2D::Values Values; | 
					
						
							|  |  |  | 		typedef NonlinearFactorGraph<Values> Graph; | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							|  |  |  | 		 * Create small example for non-linear factor graph | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		boost::shared_ptr<const Graph> sharedNonlinearFactorGraph(); | 
					
						
							|  |  |  | 		Graph createNonlinearFactorGraph(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		 * Create values structure to go with it | 
					
						
							|  |  |  | 		 * The ground truth values structure for the example above | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		Values createValues(); | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		/** Vector Values equivalent */ | 
					
						
							|  |  |  | 		VectorValues createVectorValues(); | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		 * create a noisy values structure for a nonlinear factor graph | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		boost::shared_ptr<const Values> sharedNoisyValues(); | 
					
						
							|  |  |  | 		Values createNoisyValues(); | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							|  |  |  | 		 * Zero delta config | 
					
						
							|  |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		VectorValues createZeroDelta(const Ordering& ordering); | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		 * Delta config that, when added to noisyValues, returns the ground truth | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		VectorValues createCorrectDelta(const Ordering& ordering); | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							|  |  |  | 		 * create a linear factor graph | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		 * The non-linear graph above evaluated at NoisyValues | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2010-10-09 06:04:47 +08:00
										 |  |  | 		GaussianFactorGraph createGaussianFactorGraph(const Ordering& ordering); | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							|  |  |  | 		 * create small Chordal Bayes Net x <- y | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		GaussianBayesNet createSmallGaussianBayesNet(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							|  |  |  | 		 * Create really non-linear factor graph (cos/sin) | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		boost::shared_ptr<const Graph> | 
					
						
							|  |  |  | 		sharedReallyNonlinearFactorGraph(); | 
					
						
							|  |  |  | 		Graph createReallyNonlinearFactorGraph(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							|  |  |  | 		 * Create a full nonlinear smoother | 
					
						
							|  |  |  | 		 * @param T number of time-steps | 
					
						
							|  |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		std::pair<Graph, Values> createNonlinearSmoother(int T); | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							|  |  |  | 		 * Create a Kalman smoother by linearizing a non-linear factor graph | 
					
						
							|  |  |  | 		 * @param T number of time-steps | 
					
						
							|  |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2010-10-09 06:04:47 +08:00
										 |  |  | 		std::pair<GaussianFactorGraph, Ordering> createSmoother(int T, boost::optional<Ordering> ordering = boost::none); | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* ******************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-08-07 04:07:55 +08:00
										 |  |  | 		// Linear Constrained Examples
 | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 		/* ******************************************************* */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							|  |  |  | 		 * Creates a simple constrained graph with one linear factor and | 
					
						
							|  |  |  | 		 * one binary equality constraint that sets x = y | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		GaussianFactorGraph createSimpleConstraintGraph(); | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		VectorValues createSimpleConstraintValues(); | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							|  |  |  | 		 * Creates a simple constrained graph with one linear factor and | 
					
						
							|  |  |  | 		 * one binary constraint. | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		GaussianFactorGraph createSingleConstraintGraph(); | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		VectorValues createSingleConstraintValues(); | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/**
 | 
					
						
							|  |  |  | 		 * Creates a constrained graph with a linear factor and two | 
					
						
							|  |  |  | 		 * binary constraints that share a node | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		GaussianFactorGraph createMultiConstraintGraph(); | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		VectorValues createMultiConstraintValues(); | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* ******************************************************* */ | 
					
						
							|  |  |  | 		// Planar graph with easy subtree for SubgraphPreconditioner
 | 
					
						
							|  |  |  | 		/* ******************************************************* */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/*
 | 
					
						
							|  |  |  | 		 * Create factor graph with N^2 nodes, for example for N=3 | 
					
						
							|  |  |  | 		 *  x13-x23-x33 | 
					
						
							|  |  |  | 		 *   |   |   | | 
					
						
							|  |  |  | 		 *  x12-x22-x32 | 
					
						
							|  |  |  | 		 *   |   |   | | 
					
						
							|  |  |  | 		 * -x11-x21-x31 | 
					
						
							|  |  |  | 		 * with x11 clamped at (1,1), and others related by 2D odometry. | 
					
						
							|  |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2010-10-09 11:09:58 +08:00
										 |  |  | 		boost::tuple<GaussianFactorGraph, Ordering, VectorValues> planarGraph(size_t N); | 
					
						
							| 
									
										
										
										
											2010-01-19 13:33:44 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/*
 | 
					
						
							|  |  |  | 		 * Create canonical ordering for planar graph that also works for tree | 
					
						
							|  |  |  | 		 * With x11 the root, e.g. for N=3 | 
					
						
							|  |  |  | 		 * x33 x23 x13 x32 x22 x12 x31 x21 x11 | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		Ordering planarOrdering(size_t N); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/*
 | 
					
						
							|  |  |  | 		 * Split graph into tree and loop closing constraints, e.g., with N=3 | 
					
						
							|  |  |  | 		 *  x13-x23-x33 | 
					
						
							|  |  |  | 		 *   | | 
					
						
							|  |  |  | 		 *  x12-x22-x32 | 
					
						
							|  |  |  | 		 *   | | 
					
						
							|  |  |  | 		 * -x11-x21-x31 | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		std::pair<GaussianFactorGraph, GaussianFactorGraph> splitOffPlanarTree( | 
					
						
							|  |  |  | 				size_t N, const GaussianFactorGraph& original); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} // example
 | 
					
						
							| 
									
										
										
										
											2009-12-31 20:55:51 +08:00
										 |  |  | } // gtsam
 |