| 
									
										
										
										
											2009-10-28 04:23:19 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file    testBayesTree.cpp | 
					
						
							|  |  |  |  * @brief   Unit tests for Bayes Tree | 
					
						
							|  |  |  |  * @author  Frank Dellaert | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-31 23:24:22 +08:00
										 |  |  | #include <boost/assign/std/list.hpp> // for operator +=
 | 
					
						
							|  |  |  | using namespace boost::assign; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-28 04:23:19 +08:00
										 |  |  | #include <CppUnitLite/TestHarness.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-01 03:53:20 +08:00
										 |  |  | #include "SymbolicBayesNet.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | #include "GaussianBayesNet.h"
 | 
					
						
							|  |  |  | #include "Ordering.h"
 | 
					
						
							| 
									
										
										
										
											2009-10-30 21:03:38 +08:00
										 |  |  | #include "BayesTree-inl.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | #include "smallExample.h"
 | 
					
						
							| 
									
										
										
										
											2009-10-28 04:23:19 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | using namespace gtsam; | 
					
						
							| 
									
										
										
										
											2009-10-31 13:12:39 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Conditionals for ASIA example from the tutorial with A and D evidence
 | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | 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-10-31 13:12:39 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( BayesTree, Front ) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-11-04 11:22:29 +08:00
										 |  |  | 	SymbolicBayesNet f1; | 
					
						
							| 
									
										
										
										
											2009-11-02 13:17:44 +08:00
										 |  |  | 	f1.push_back(B); | 
					
						
							|  |  |  | 	f1.push_back(L); | 
					
						
							| 
									
										
										
										
											2009-11-04 11:22:29 +08:00
										 |  |  | 	SymbolicBayesNet f2; | 
					
						
							| 
									
										
										
										
											2009-11-02 13:17:44 +08:00
										 |  |  | 	f2.push_back(L); | 
					
						
							|  |  |  | 	f2.push_back(B); | 
					
						
							| 
									
										
										
										
											2009-10-31 13:12:39 +08:00
										 |  |  | 	CHECK(f1.equals(f1)); | 
					
						
							|  |  |  | 	CHECK(!f1.equals(f2)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-10-31 22:12:41 +08:00
										 |  |  | TEST( BayesTree, constructor ) | 
					
						
							| 
									
										
										
										
											2009-10-31 13:12:39 +08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-10-31 22:12:41 +08:00
										 |  |  | 	// Create using insert
 | 
					
						
							| 
									
										
										
										
											2009-10-31 13:12:39 +08:00
										 |  |  | 	BayesTree<SymbolicConditional> bayesTree; | 
					
						
							| 
									
										
										
										
											2009-11-02 11:50:30 +08:00
										 |  |  | 	bayesTree.insert(B); | 
					
						
							|  |  |  | 	bayesTree.insert(L); | 
					
						
							|  |  |  | 	bayesTree.insert(E); | 
					
						
							|  |  |  | 	bayesTree.insert(S); | 
					
						
							|  |  |  | 	bayesTree.insert(T); | 
					
						
							|  |  |  | 	bayesTree.insert(X); | 
					
						
							| 
									
										
										
										
											2009-10-31 13:12:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-31 22:12:41 +08:00
										 |  |  | 	// Check Size
 | 
					
						
							| 
									
										
										
										
											2009-11-05 13:29:47 +08:00
										 |  |  | 	LONGS_EQUAL(6,bayesTree.size()); | 
					
						
							| 
									
										
										
										
											2009-10-31 13:12:39 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Check root
 | 
					
						
							| 
									
										
										
										
											2009-11-02 13:17:44 +08:00
										 |  |  | 	BayesNet<SymbolicConditional> expected_root; | 
					
						
							|  |  |  | 	expected_root.push_back(E); | 
					
						
							| 
									
										
										
										
											2009-11-03 14:29:56 +08:00
										 |  |  | 	expected_root.push_back(L); | 
					
						
							|  |  |  | 	expected_root.push_back(B); | 
					
						
							| 
									
										
										
										
											2009-11-05 13:29:47 +08:00
										 |  |  | 	boost::shared_ptr<BayesNet<SymbolicConditional> > actual_root = bayesTree.root(); | 
					
						
							|  |  |  | 	CHECK(assert_equal(expected_root,*actual_root)); | 
					
						
							| 
									
										
										
										
											2009-10-28 04:23:19 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-31 22:12:41 +08:00
										 |  |  | 	// Create from symbolic Bayes chain in which we want to discover cliques
 | 
					
						
							| 
									
										
										
										
											2009-11-01 03:53:20 +08:00
										 |  |  | 	SymbolicBayesNet ASIA; | 
					
						
							| 
									
										
										
										
											2009-11-02 13:17:44 +08:00
										 |  |  | 	ASIA.push_back(X); | 
					
						
							|  |  |  | 	ASIA.push_back(T); | 
					
						
							|  |  |  | 	ASIA.push_back(S); | 
					
						
							|  |  |  | 	ASIA.push_back(E); | 
					
						
							|  |  |  | 	ASIA.push_back(L); | 
					
						
							|  |  |  | 	ASIA.push_back(B); | 
					
						
							| 
									
										
										
										
											2009-11-04 11:22:29 +08:00
										 |  |  | 	BayesTree<SymbolicConditional> bayesTree2(ASIA); | 
					
						
							|  |  |  | 	//bayesTree2.print("bayesTree2");
 | 
					
						
							| 
									
										
										
										
											2009-10-31 13:12:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-31 22:12:41 +08:00
										 |  |  | 	// Check whether the same
 | 
					
						
							| 
									
										
										
										
											2009-11-01 00:57:36 +08:00
										 |  |  | 	CHECK(assert_equal(bayesTree,bayesTree2)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* *
 | 
					
						
							|  |  |  |  Bayes tree for smoother with "natural" ordering: | 
					
						
							|  |  |  |  x6 x7 | 
					
						
							|  |  |  |    x5 : x6 | 
					
						
							|  |  |  |      x4 : x5 | 
					
						
							|  |  |  |        x3 : x4 | 
					
						
							|  |  |  |          x2 : x3 | 
					
						
							|  |  |  |            x1 : x2 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST( BayesTree, smoother ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	// Create smoother with 7 nodes
 | 
					
						
							|  |  |  | 	LinearFactorGraph smoother = createSmoother(7); | 
					
						
							|  |  |  | 	Ordering ordering; | 
					
						
							|  |  |  | 	for (int t = 1; t <= 7; t++) | 
					
						
							|  |  |  | 		ordering.push_back(symbol('x', t)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// eliminate using the "natural" ordering
 | 
					
						
							| 
									
										
										
										
											2009-11-01 03:53:20 +08:00
										 |  |  | 	GaussianBayesNet::shared_ptr chordalBayesNet = smoother.eliminate(ordering); | 
					
						
							| 
									
										
										
										
											2009-11-01 00:57:36 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Create the Bayes tree
 | 
					
						
							| 
									
										
										
										
											2009-11-04 11:22:29 +08:00
										 |  |  | 	BayesTree<ConditionalGaussian> bayesTree(*chordalBayesNet); | 
					
						
							| 
									
										
										
										
											2009-11-05 13:29:47 +08:00
										 |  |  | 	LONGS_EQUAL(7,bayesTree.size()); | 
					
						
							| 
									
										
										
										
											2009-11-01 00:57:36 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* *
 | 
					
						
							|  |  |  |  Bayes tree for smoother with "nested dissection" ordering: | 
					
						
							|  |  |  |  x5 x6 x4 | 
					
						
							|  |  |  |    x3 x2 : x4 | 
					
						
							|  |  |  |      x1 : x2 | 
					
						
							|  |  |  |    x7 : x6 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2009-11-04 11:22:29 +08:00
										 |  |  | TEST( BayesTree, balanced_smoother_marginals ) | 
					
						
							| 
									
										
										
										
											2009-11-01 00:57:36 +08:00
										 |  |  | { | 
					
						
							|  |  |  | 	// Create smoother with 7 nodes
 | 
					
						
							|  |  |  | 	LinearFactorGraph smoother = createSmoother(7); | 
					
						
							|  |  |  | 	Ordering ordering; | 
					
						
							|  |  |  | 	ordering += "x1","x3","x5","x7","x2","x6","x4"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// eliminate using a "nested dissection" ordering
 | 
					
						
							| 
									
										
										
										
											2009-11-01 03:53:20 +08:00
										 |  |  | 	GaussianBayesNet::shared_ptr chordalBayesNet = smoother.eliminate(ordering); | 
					
						
							| 
									
										
										
										
											2009-11-01 00:57:36 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Create the Bayes tree
 | 
					
						
							| 
									
										
										
										
											2009-11-04 11:22:29 +08:00
										 |  |  | 	BayesTree<ConditionalGaussian> bayesTree(*chordalBayesNet); | 
					
						
							| 
									
										
										
										
											2009-11-05 13:29:47 +08:00
										 |  |  | 	LONGS_EQUAL(7,bayesTree.size()); | 
					
						
							| 
									
										
										
										
											2009-11-04 11:22:29 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// Check root clique
 | 
					
						
							|  |  |  | 	//BayesNet<ConditionalGaussian> expected_root;
 | 
					
						
							|  |  |  | 	//BayesNet<ConditionalGaussian> actual_root = bayesTree.root();
 | 
					
						
							|  |  |  | 	//CHECK(assert_equal(expected_root,actual_root));
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Check marginal on x1
 | 
					
						
							|  |  |  | 	ConditionalGaussian expected; | 
					
						
							|  |  |  | 	ConditionalGaussian::shared_ptr actual = bayesTree.marginal("x1"); | 
					
						
							|  |  |  | 	CHECK(assert_equal(expected,*actual)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// JunctionTree is an undirected tree of cliques
 | 
					
						
							|  |  |  | 	// JunctionTree<ConditionalGaussian> marginals = bayesTree.marginals();
 | 
					
						
							| 
									
										
										
										
											2009-10-28 04:23:19 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | int main() { | 
					
						
							|  |  |  | 	TestResult tr; | 
					
						
							|  |  |  | 	return TestRegistry::runAllTests(tr); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | /* ************************************************************************* */ |