| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  | class VectorConfig { | 
					
						
							|  |  |  |   VectorConfig(); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   Vector get(string name) const; | 
					
						
							|  |  |  |   bool contains(string name) const; | 
					
						
							|  |  |  |   size_t size() const; | 
					
						
							|  |  |  |   void insert(string name, Vector val); | 
					
						
							|  |  |  |   void print() const; | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |   bool equals(const VectorConfig& expected, double tol) const; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   void clear(); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class LinearFactorSet { | 
					
						
							|  |  |  |   LinearFactorSet(); | 
					
						
							| 
									
										
										
										
											2009-10-20 23:22:06 +08:00
										 |  |  |   void push_back(LinearFactor* factor); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class LinearFactor { | 
					
						
							|  |  |  |   LinearFactor(string key1, | 
					
						
							|  |  |  | 	       Matrix A1, | 
					
						
							|  |  |  | 	       Vector b_in); | 
					
						
							|  |  |  |   LinearFactor(string key1, | 
					
						
							|  |  |  | 	       Matrix A1, | 
					
						
							|  |  |  | 	       string key2, | 
					
						
							|  |  |  | 	       Matrix A2, | 
					
						
							|  |  |  | 	       Vector b_in); | 
					
						
							|  |  |  |   LinearFactor(string key1, | 
					
						
							|  |  |  | 	       Matrix A1, | 
					
						
							|  |  |  | 	       string key2, | 
					
						
							|  |  |  | 	       Matrix A2, | 
					
						
							|  |  |  | 	       string key3, | 
					
						
							|  |  |  | 	       Matrix A3, | 
					
						
							|  |  |  | 	       Vector b_in); | 
					
						
							|  |  |  |   bool empty() const; | 
					
						
							|  |  |  |   Vector get_b() const; | 
					
						
							|  |  |  |   Matrix get_A(string key) const; | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |   double error(const VectorConfig& c) const; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   bool involves(string key) const; | 
					
						
							|  |  |  |   void print() const; | 
					
						
							|  |  |  |   bool equals(const LinearFactor& lf, double tol) const; | 
					
						
							|  |  |  |   pair<Matrix,Vector> matrix(const Ordering& ordering) const; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ConditionalGaussian { | 
					
						
							|  |  |  |   ConditionalGaussian(); | 
					
						
							|  |  |  |   ConditionalGaussian(Vector d, | 
					
						
							|  |  |  | 		      Matrix R); | 
					
						
							|  |  |  |   ConditionalGaussian(Vector d, | 
					
						
							|  |  |  | 		      Matrix R, | 
					
						
							|  |  |  | 		      string name1, | 
					
						
							|  |  |  | 		      Matrix S); | 
					
						
							|  |  |  |   ConditionalGaussian(Vector d, | 
					
						
							|  |  |  | 		      Matrix R, | 
					
						
							|  |  |  | 		      string name1, | 
					
						
							|  |  |  | 		      Matrix S, | 
					
						
							|  |  |  | 		      string name2, | 
					
						
							|  |  |  | 		      Matrix T); | 
					
						
							|  |  |  |   void print() const; | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |   Vector solve(const VectorConfig& x); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   void add(string key, Matrix S); | 
					
						
							|  |  |  |   bool equals(const ConditionalGaussian &cg) const; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Ordering { | 
					
						
							|  |  |  |   Ordering(); | 
					
						
							|  |  |  |   void push_back(string s); | 
					
						
							|  |  |  |   void print() const; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-01 03:53:20 +08:00
										 |  |  | class GaussianBayesNet { | 
					
						
							|  |  |  |   GaussianBayesNet(); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   void insert(string name, ConditionalGaussian* node); | 
					
						
							|  |  |  |   ConditionalGaussian* get(string name); | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |   VectorConfig* optimize(); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   void print() const; | 
					
						
							| 
									
										
										
										
											2009-11-01 03:53:20 +08:00
										 |  |  |   bool equals(const GaussianBayesNet& cbn) const; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   pair<Matrix,Vector> matrix() const; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class LinearFactorGraph { | 
					
						
							|  |  |  |   LinearFactorGraph(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   size_t size() const; | 
					
						
							|  |  |  |   void push_back(LinearFactor* ptr_f); | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |   double error(const VectorConfig& c) const; | 
					
						
							|  |  |  |   double probPrime(const VectorConfig& c) const; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   void print() const; | 
					
						
							|  |  |  |   bool equals(const LinearFactorGraph& lfgraph) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |   VectorConfig optimize(const Ordering& ordering); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   LinearFactor* combine_factors(string key); | 
					
						
							|  |  |  |   ConditionalGaussian* eliminate_one(string key); | 
					
						
							| 
									
										
										
										
											2009-11-01 03:53:20 +08:00
										 |  |  |   GaussianBayesNet* eliminate(const Ordering& ordering); | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   pair<Matrix,Vector> matrix(const Ordering& ordering) const; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Point2 { | 
					
						
							|  |  |  |   Point2(); | 
					
						
							|  |  |  |   Point2(double x, double y); | 
					
						
							|  |  |  |   double x(); | 
					
						
							|  |  |  |   double y(); | 
					
						
							|  |  |  |   size_t dim() const; | 
					
						
							|  |  |  |   void print() const; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Point3 { | 
					
						
							|  |  |  |   Point3(); | 
					
						
							|  |  |  |   Point3(double x, double y, double z); | 
					
						
							|  |  |  |   Point3(Vector v); | 
					
						
							|  |  |  |   size_t dim() const; | 
					
						
							|  |  |  |   Point3 exmap(Vector d) const; | 
					
						
							|  |  |  |   Vector vector() const; | 
					
						
							|  |  |  |   double x(); | 
					
						
							|  |  |  |   double y(); | 
					
						
							|  |  |  |   double z(); | 
					
						
							|  |  |  |   void print() const; | 
					
						
							|  |  |  | };  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Point2Prior { | 
					
						
							|  |  |  |   Point2Prior(Vector mu, double sigma, string key); | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |   Vector error_vector(const VectorConfig& c) const; | 
					
						
							|  |  |  |   LinearFactor* linearize(const VectorConfig& c) const; | 
					
						
							| 
									
										
										
										
											2009-10-21 04:41:45 +08:00
										 |  |  |   double sigma(); | 
					
						
							|  |  |  |   Vector measurement(); | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |   double error(const VectorConfig& c) const; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   void print() const; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Simulated2DOdometry { | 
					
						
							|  |  |  |   Simulated2DOdometry(Vector odo, double sigma, string key, string key2); | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |   Vector error_vector(const VectorConfig& c) const; | 
					
						
							|  |  |  |   LinearFactor* linearize(const VectorConfig& c) const; | 
					
						
							| 
									
										
										
										
											2009-10-21 04:41:45 +08:00
										 |  |  |   double sigma(); | 
					
						
							|  |  |  |   Vector measurement(); | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |   double error(const VectorConfig& c) const; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   void print() const; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Simulated2DMeasurement { | 
					
						
							|  |  |  |   Simulated2DMeasurement(Vector odo, double sigma, string key, string key2); | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |   Vector error_vector(const VectorConfig& c) const; | 
					
						
							|  |  |  |   LinearFactor* linearize(const VectorConfig& c) const; | 
					
						
							| 
									
										
										
										
											2009-10-21 04:41:45 +08:00
										 |  |  |   double sigma(); | 
					
						
							|  |  |  |   Vector measurement(); | 
					
						
							| 
									
										
										
										
											2009-10-15 04:39:59 +08:00
										 |  |  |   double error(const VectorConfig& c) const; | 
					
						
							| 
									
										
										
										
											2009-08-22 06:23:24 +08:00
										 |  |  |   void print() const; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 |