| 
									
										
										
										
											2009-11-18 05:47:42 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file    testIncremental.cpp | 
					
						
							|  |  |  |  * @brief   Unit tests for graph-based iSAM | 
					
						
							|  |  |  |  * @author  Michael Kaess | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/assign/std/list.hpp> // for operator +=
 | 
					
						
							|  |  |  | using namespace boost::assign; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <CppUnitLite/TestHarness.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "SymbolicBayesNet.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-19 01:03:19 +08:00
										 |  |  | #include "SymbolicFactorGraph.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-18 05:47:42 +08:00
										 |  |  | #include "GaussianBayesNet.h"
 | 
					
						
							|  |  |  | #include "Ordering.h"
 | 
					
						
							|  |  |  | #include "BayesTree-inl.h"
 | 
					
						
							|  |  |  | #include "smallExample.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | using namespace gtsam; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef BayesTree<SymbolicConditional> SymbolicBayesTree; | 
					
						
							|  |  |  | typedef BayesTree<GaussianConditional> GaussianBayesTree; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Conditionals for ASIA example from the tutorial with A and D evidence
 | 
					
						
							|  |  |  | SymbolicConditional::shared_ptr B(new SymbolicConditional("B")), L( | 
					
						
							|  |  |  | 		new SymbolicConditional("L", "B")), E( | 
					
						
							|  |  |  | 		new SymbolicConditional("E", "L", "B")), S(new SymbolicConditional("S", | 
					
						
							|  |  |  | 		"L", "B")), T(new SymbolicConditional("T", "E", "L")), X( | 
					
						
							|  |  |  | 		new SymbolicConditional("X", "E")); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-19 00:31:19 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-19 01:03:19 +08:00
										 |  |  | SymbolicBayesTree update(const SymbolicBayesTree& initial, | 
					
						
							|  |  |  | 		const boost::shared_ptr<SymbolicFactor>& newFactor) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// create a factor graph with the new factor in it
 | 
					
						
							|  |  |  | 	SymbolicFactorGraph factorGraph; | 
					
						
							|  |  |  | 	factorGraph.push_back(newFactor); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// get the ELB clique
 | 
					
						
							| 
									
										
										
										
											2009-11-19 01:28:07 +08:00
										 |  |  | 	SymbolicBayesTree::sharedClique ELB = initial["B"]; | 
					
						
							|  |  |  | 	FactorGraph<SymbolicFactor> ELB_factors(*ELB); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-19 01:03:19 +08:00
										 |  |  | 	// add it to the factor graph
 | 
					
						
							| 
									
										
										
										
											2009-11-19 01:28:07 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-19 01:03:19 +08:00
										 |  |  | 	// get the SLB clique
 | 
					
						
							| 
									
										
										
										
											2009-11-19 01:28:07 +08:00
										 |  |  | 	SymbolicBayesTree::sharedClique SLB = initial["S"]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-19 01:03:19 +08:00
										 |  |  | 	// add it to the factor graph
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// create an ordering ESLB
 | 
					
						
							|  |  |  | 	Ordering ordering; | 
					
						
							|  |  |  | 	ordering += "S","B"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// eliminate into a Bayes net
 | 
					
						
							|  |  |  | 	SymbolicBayesNet bayesNet = eliminate<SymbolicFactor,SymbolicConditional>(factorGraph,ordering); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// turn back into a Bayes Tree
 | 
					
						
							|  |  |  | 	BayesTree<SymbolicConditional> newTree(bayesNet); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// add orphans to the bottom of the new tree
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return newTree; | 
					
						
							| 
									
										
										
										
											2009-11-19 00:31:19 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-18 05:47:42 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-11-18 23:37:19 +08:00
										 |  |  | TEST( BayesTree, iSAM ) | 
					
						
							| 
									
										
										
										
											2009-11-18 05:47:42 +08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-11-18 23:37:19 +08:00
										 |  |  | 	// Create using insert
 | 
					
						
							|  |  |  | 	SymbolicBayesTree bayesTree; | 
					
						
							|  |  |  | 	bayesTree.insert(B); | 
					
						
							|  |  |  | 	bayesTree.insert(L); | 
					
						
							|  |  |  | 	bayesTree.insert(E); | 
					
						
							|  |  |  | 	bayesTree.insert(S); | 
					
						
							|  |  |  | 	bayesTree.insert(T); | 
					
						
							|  |  |  | 	bayesTree.insert(X); | 
					
						
							| 
									
										
										
										
											2009-11-19 00:32:45 +08:00
										 |  |  | 	//bayesTree.print("bayesTree");
 | 
					
						
							| 
									
										
										
										
											2009-11-19 00:31:19 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Create expected Bayes tree
 | 
					
						
							|  |  |  | 	SymbolicBayesTree expected; | 
					
						
							|  |  |  | 	expected.insert(B); | 
					
						
							|  |  |  | 	expected.insert(L); | 
					
						
							|  |  |  | 	expected.insert(S); | 
					
						
							|  |  |  | 	expected.insert(E); | 
					
						
							|  |  |  | 	expected.insert(T); | 
					
						
							|  |  |  | 	expected.insert(X); | 
					
						
							| 
									
										
										
										
											2009-11-19 00:32:45 +08:00
										 |  |  | 	//expected.print("expected");
 | 
					
						
							| 
									
										
										
										
											2009-11-19 00:31:19 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// create a new factor to be inserted
 | 
					
						
							|  |  |  | 	list<string> keys; | 
					
						
							|  |  |  | 	keys += "B","S"; | 
					
						
							| 
									
										
										
										
											2009-11-19 01:03:19 +08:00
										 |  |  | 	boost::shared_ptr<SymbolicFactor> newFactor(new SymbolicFactor(keys)); | 
					
						
							| 
									
										
										
										
											2009-11-19 00:31:19 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// do incremental inference
 | 
					
						
							|  |  |  | 	SymbolicBayesTree actual = update(bayesTree, newFactor); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Check whether the same
 | 
					
						
							| 
									
										
										
										
											2009-11-19 01:28:07 +08:00
										 |  |  | 	CHECK(assert_equal(expected,actual)); | 
					
						
							| 
									
										
										
										
											2009-11-18 05:47:42 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | int main() { | 
					
						
							|  |  |  | 	TestResult tr; | 
					
						
							|  |  |  | 	return TestRegistry::runAllTests(tr); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | /* ************************************************************************* */ |