| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file    smallExample.cpp | 
					
						
							|  |  |  |  * @brief   Create small example with two poses and one landmark | 
					
						
							|  |  |  |  * @brief   smallExample | 
					
						
							|  |  |  |  * @author  Carlos Nieto | 
					
						
							|  |  |  |  * @author  Frank dellaert | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*STL/C++*/ | 
					
						
							|  |  |  | #include <iostream>
 | 
					
						
							|  |  |  | #include <string>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | using namespace std; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "Matrix.h"
 | 
					
						
							|  |  |  | #include "NonlinearFactor.h"
 | 
					
						
							|  |  |  | #include "EqualityFactor.h"
 | 
					
						
							|  |  |  | #include "DeltaFunction.h"
 | 
					
						
							|  |  |  | #include "smallExample.h"
 | 
					
						
							|  |  |  | #include "Point2Prior.h"
 | 
					
						
							|  |  |  | #include "Simulated2DOdometry.h"
 | 
					
						
							|  |  |  | #include "Simulated2DMeasurement.h"
 | 
					
						
							|  |  |  | #include "simulated2D.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace gtsam { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  | typedef boost::shared_ptr<NonlinearFactor> shared; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  | boost::shared_ptr<const NonlinearFactorGraph> sharedNonlinearFactorGraph() { | 
					
						
							|  |  |  | 	// Create
 | 
					
						
							|  |  |  | 	boost::shared_ptr<NonlinearFactorGraph> nlfg(new NonlinearFactorGraph); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// prior on x1
 | 
					
						
							|  |  |  | 	double sigma1=0.1; | 
					
						
							|  |  |  | 	Vector mu(2); mu(0) = 0 ; mu(1) = 0; | 
					
						
							|  |  |  | 	shared f1(new Point2Prior(mu, sigma1, "x1")); | 
					
						
							|  |  |  | 	nlfg->push_back(f1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// odometry between x1 and x2
 | 
					
						
							|  |  |  | 	double sigma2=0.1; | 
					
						
							|  |  |  | 	Vector z2(2); z2(0) = 1.5 ; z2(1) = 0; | 
					
						
							|  |  |  | 	shared f2(new Simulated2DOdometry(z2, sigma2, "x1", "x2")); | 
					
						
							|  |  |  | 	nlfg->push_back(f2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// measurement between x1 and l1
 | 
					
						
							|  |  |  | 	double sigma3=0.2; | 
					
						
							|  |  |  | 	Vector z3(2); z3(0) = 0. ; z3(1) = -1.; | 
					
						
							|  |  |  | 	shared f3(new Simulated2DMeasurement(z3, sigma3, "x1", "l1")); | 
					
						
							|  |  |  | 	nlfg->push_back(f3); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// measurement between x2 and l1
 | 
					
						
							|  |  |  | 	double sigma4=0.2; | 
					
						
							|  |  |  | 	Vector z4(2); z4(0)= -1.5 ; z4(1) = -1.; | 
					
						
							|  |  |  | 	shared f4(new Simulated2DMeasurement(z4, sigma4, "x2", "l1")); | 
					
						
							|  |  |  | 	nlfg->push_back(f4); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return nlfg; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | NonlinearFactorGraph createNonlinearFactorGraph() { | 
					
						
							|  |  |  | 	return *sharedNonlinearFactorGraph(); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | ConstrainedLinearFactorGraph createConstrainedLinearFactorGraph() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ConstrainedLinearFactorGraph graph; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// add an equality factor
 | 
					
						
							|  |  |  | 	Vector v1(2); v1(0)=1.;v1(1)=2.; | 
					
						
							|  |  |  | 	EqualityFactor::shared_ptr f1(new EqualityFactor(v1, "x0")); | 
					
						
							|  |  |  | 	graph.push_back_eq(f1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// add a normal linear factor
 | 
					
						
							|  |  |  | 	Matrix A21 = -1 * eye(2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Matrix A22 = eye(2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Vector b(2); | 
					
						
							|  |  |  | 	b(0) = 2 ; b(1) = 3; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	double sigma = 0.1; | 
					
						
							|  |  |  | 	LinearFactor::shared_ptr f2(new LinearFactor("x0", A21/sigma,  "x1", A22/sigma, b/sigma)); | 
					
						
							|  |  |  | 	graph.push_back(f2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return graph; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | ConstrainedNonlinearFactorGraph createConstrainedNonlinearFactorGraph() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ConstrainedNonlinearFactorGraph graph; | 
					
						
							|  |  |  | 	FGConfig c = createConstrainedConfig(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// equality constraint for initial pose
 | 
					
						
							|  |  |  | 	EqualityFactor::shared_ptr f1(new EqualityFactor(c["x0"], "x0")); | 
					
						
							|  |  |  | 	graph.push_back_eq(f1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // odometry between x0 and x1
 | 
					
						
							|  |  |  |     double sigma=0.1; | 
					
						
							|  |  |  |     shared f2(new Simulated2DOdometry(c["x1"]-c["x0"], sigma, "x0", "x1")); | 
					
						
							|  |  |  |     graph.push_back(f2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return graph; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | FGConfig createConfig() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     Vector v_x1(2); v_x1(0) = 0.;  v_x1(1) = 0.; | 
					
						
							|  |  |  |     Vector v_x2(2); v_x2(0) = 1.5; v_x2(1) = 0.; | 
					
						
							|  |  |  |     Vector v_l1(2); v_l1(0) = 0.;  v_l1(1) = -1.; | 
					
						
							|  |  |  |     FGConfig c; | 
					
						
							|  |  |  |     c.insert("x1", v_x1); | 
					
						
							|  |  |  |     c.insert("x2", v_x2); | 
					
						
							|  |  |  |     c.insert("l1", v_l1); | 
					
						
							|  |  |  |     return c; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  | boost::shared_ptr<const FGConfig> sharedNoisyConfig() | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | { | 
					
						
							|  |  |  |     Vector v_x1(2); v_x1(0) = 0.1;  v_x1(1) = 0.1; | 
					
						
							|  |  |  |     Vector v_x2(2); v_x2(0) = 1.4;  v_x2(1) = 0.2; | 
					
						
							|  |  |  |     Vector v_l1(2); v_l1(0) = 0.1;  v_l1(1) = -1.1; | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  |     boost::shared_ptr<FGConfig> c(new FGConfig); | 
					
						
							|  |  |  |     c->insert("x1", v_x1); | 
					
						
							|  |  |  |     c->insert("x2", v_x2); | 
					
						
							|  |  |  |     c->insert("l1", v_l1); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |     return c; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  | FGConfig createNoisyConfig() { | 
					
						
							|  |  |  | 	return *sharedNoisyConfig(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | FGConfig createConstrainedConfig() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	FGConfig config; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Vector x0(2); x0(0)=1.0; x0(1)=2.0; | 
					
						
							|  |  |  | 	config.insert("x0", x0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Vector x1(2); x1(0)=3.0; x1(1)=5.0; | 
					
						
							|  |  |  | 	config.insert("x1", x1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return config; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | FGConfig createConstrainedLinConfig() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	FGConfig config; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Vector x0(2); x0(0)=1.0; x0(1)=2.0; // value doesn't actually matter
 | 
					
						
							|  |  |  | 	config.insert("x0", x0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Vector x1(2); x1(0)=2.3; x1(1)=5.3; | 
					
						
							|  |  |  | 	config.insert("x1", x1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return config; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | FGConfig createConstrainedCorrectDelta() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	FGConfig config; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Vector x0(2); x0(0)=0.; x0(1)=0.; | 
					
						
							|  |  |  | 	config.insert("x0", x0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Vector x1(2); x1(0)= 0.7; x1(1)= -0.3; | 
					
						
							|  |  |  | 	config.insert("x1", x1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return config; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | FGConfig createCorrectDelta() { | 
					
						
							|  |  |  |   Vector v_x1(2); v_x1(0) = -0.1;  v_x1(1) = -0.1; | 
					
						
							|  |  |  |   Vector v_x2(2); v_x2(0) =  0.1;  v_x2(1) = -0.2; | 
					
						
							|  |  |  |   Vector v_l1(2); v_l1(0) = -0.1;  v_l1(1) =  0.1; | 
					
						
							|  |  |  |   FGConfig c; | 
					
						
							|  |  |  |   c.insert("x1", v_x1); | 
					
						
							|  |  |  |   c.insert("x2", v_x2); | 
					
						
							|  |  |  |   c.insert("l1", v_l1); | 
					
						
							|  |  |  |   return c; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | FGConfig createZeroDelta() { | 
					
						
							|  |  |  |   Vector v_x1(2); v_x1(0) = 0;  v_x1(1) = 0; | 
					
						
							|  |  |  |   Vector v_x2(2); v_x2(0) = 0;  v_x2(1) = 0; | 
					
						
							|  |  |  |   Vector v_l1(2); v_l1(0) = 0;  v_l1(1) = 0; | 
					
						
							|  |  |  |   FGConfig c; | 
					
						
							|  |  |  |   c.insert("x1", v_x1); | 
					
						
							|  |  |  |   c.insert("x2", v_x2); | 
					
						
							|  |  |  |   c.insert("l1", v_l1); | 
					
						
							|  |  |  |   return c; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | LinearFactorGraph createLinearFactorGraph() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   FGConfig c = createNoisyConfig(); | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   // Create
 | 
					
						
							|  |  |  |   LinearFactorGraph fg; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // prior on x1
 | 
					
						
							|  |  |  |   Matrix A11(2,2); | 
					
						
							|  |  |  |   A11(0,0) = 10; A11(0,1) =  0; | 
					
						
							|  |  |  |   A11(1,0) =  0; A11(1,1) = 10; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Vector b = - c["x1"]/0.1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   LinearFactor::shared_ptr f1(new LinearFactor("x1", A11, b)); | 
					
						
							|  |  |  |   fg.push_back(f1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // odometry between x1 and x2
 | 
					
						
							|  |  |  |   Matrix A21(2,2); | 
					
						
							|  |  |  |   A21(0,0) = -10 ; A21(0,1) =   0; | 
					
						
							|  |  |  |   A21(1,0) =   0 ; A21(1,1) = -10; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Matrix A22(2,2); | 
					
						
							|  |  |  |   A22(0,0) = 10 ; A22(0,1) =  0; | 
					
						
							|  |  |  |   A22(1,0) =  0 ; A22(1,1) = 10; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Vector b(2);
 | 
					
						
							|  |  |  |   b(0) = 2 ; b(1) = -1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   LinearFactor::shared_ptr f2(new LinearFactor("x1", A21,  "x2", A22, b)); | 
					
						
							|  |  |  |   fg.push_back(f2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // measurement between x1 and l1
 | 
					
						
							|  |  |  |   Matrix A31(2,2); | 
					
						
							|  |  |  |   A31(0,0) = -5; A31(0,1) =  0; | 
					
						
							|  |  |  |   A31(1,0) =  0; A31(1,1) = -5; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Matrix A32(2,2); | 
					
						
							|  |  |  |   A32(0,0) = 5 ; A32(0,1) = 0; | 
					
						
							|  |  |  |   A32(1,0) = 0 ; A32(1,1) = 5; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   b(0) = 0 ; b(1) = 1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   LinearFactor::shared_ptr f3(new LinearFactor("x1", A31, "l1", A32, b)); | 
					
						
							|  |  |  |   fg.push_back(f3); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // measurement between x2 and l1
 | 
					
						
							|  |  |  |   Matrix A41(2,2); | 
					
						
							|  |  |  |   A41(0,0) = -5 ; A41(0,1) =  0; | 
					
						
							|  |  |  |   A41(1,0) =  0 ; A41(1,1) = -5; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Matrix A42(2,2); | 
					
						
							|  |  |  |   A42(0,0) = 5 ; A42(0,1) = 0; | 
					
						
							|  |  |  |   A42(1,0) = 0 ; A42(1,1) = 5; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   b(0)= -1 ; b(1) = 1.5; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   LinearFactor::shared_ptr f4(new LinearFactor("x2", A41, "l1", A42, b)); | 
					
						
							|  |  |  |   fg.push_back(f4); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return fg; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | /** create small Chordal Bayes Net x <- y
 | 
					
						
							|  |  |  |  * x y d | 
					
						
							|  |  |  |  * 1 1 9 | 
					
						
							|  |  |  |  *   1 5 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | ChordalBayesNet createSmallChordalBayesNet() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   Matrix R11 = Matrix_(1,1,1.0), S12 = Matrix_(1,1,1.0); | 
					
						
							|  |  |  |   Matrix                          R22 = Matrix_(1,1,1.0); | 
					
						
							|  |  |  |   Vector d1(1), d2(1); | 
					
						
							|  |  |  |   d1(0) = 9; d2(0) = 5; | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  |   // define nodes and specify in reverse topological sort (i.e. parents last)
 | 
					
						
							|  |  |  |   ConditionalGaussian::shared_ptr | 
					
						
							|  |  |  |     x(new ConditionalGaussian(d1,R11,"y",S12)), | 
					
						
							|  |  |  |     y(new ConditionalGaussian(d2,R22)); | 
					
						
							|  |  |  |   ChordalBayesNet cbn; | 
					
						
							|  |  |  |   cbn.insert("x",x); | 
					
						
							|  |  |  |   cbn.insert("y",y); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return cbn; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | ConstrainedChordalBayesNet createConstrainedChordalBayesNet() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ConstrainedChordalBayesNet cbn; | 
					
						
							|  |  |  | 	FGConfig c = createConstrainedConfig(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// add regular conditional gaussian - no parent
 | 
					
						
							|  |  |  | 	Matrix R = eye(2); | 
					
						
							|  |  |  | 	Vector d = c["x1"]; | 
					
						
							|  |  |  | 	double sigma = 0.1; | 
					
						
							|  |  |  | 	ConditionalGaussian::shared_ptr f1(new ConditionalGaussian(d/sigma, R/sigma)); | 
					
						
							|  |  |  | 	cbn.insert("x1", f1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// add a delta function to the cbn
 | 
					
						
							|  |  |  | 	DeltaFunction::shared_ptr f2(new DeltaFunction(c["x0"], "x0")); | 
					
						
							|  |  |  | 	cbn.insert_df("x0", f2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return cbn; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | // Some nonlinear functions to optimize
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | namespace optimize { | 
					
						
							|  |  |  |   Vector h(const Vector& v) { | 
					
						
							|  |  |  |     double x = v(0); | 
					
						
							|  |  |  |     return Vector_(2,cos(x),sin(x)); | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  |   Matrix H(const Vector& v) { | 
					
						
							|  |  |  |     double x = v(0); | 
					
						
							|  |  |  |     return Matrix_(2,1,-sin(x),cos(x)); | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  | boost::shared_ptr<const NonlinearFactorGraph> sharedReallyNonlinearFactorGraph() | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  | 	boost::shared_ptr<NonlinearFactorGraph> fg(new NonlinearFactorGraph); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   Vector z = Vector_(2,1.0,0.0); | 
					
						
							|  |  |  |   double sigma = 0.1; | 
					
						
							|  |  |  |   boost::shared_ptr<NonlinearFactor1>  | 
					
						
							|  |  |  |     factor(new NonlinearFactor1(z,sigma,&optimize::h,"x",&optimize::H)); | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  |   fg->push_back(factor); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   return fg; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-09 12:43:04 +08:00
										 |  |  | NonlinearFactorGraph createReallyNonlinearFactorGraph() { | 
					
						
							|  |  |  | 	return *sharedReallyNonlinearFactorGraph(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace gtsam
 |