| 
									
										
										
										
											2009-11-29 02:35:36 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file testOrdering.cpp | 
					
						
							|  |  |  |  * @author Alex Cunningham | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <boost/assign/std/list.hpp> // for operator +=
 | 
					
						
							|  |  |  | #include <CppUnitLite/TestHarness.h>
 | 
					
						
							| 
									
										
										
										
											2010-01-18 03:34:57 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define GTSAM_MAGIC_KEY
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-14 15:56:03 +08:00
										 |  |  | #include "Ordering-inl.h"
 | 
					
						
							| 
									
										
										
										
											2010-01-17 02:01:16 +08:00
										 |  |  | #include "pose2SLAM.h"
 | 
					
						
							| 
									
										
										
										
											2010-01-14 15:56:03 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-29 02:35:36 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | using namespace std; | 
					
						
							|  |  |  | using namespace gtsam; | 
					
						
							|  |  |  | using namespace boost::assign; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-14 11:21:07 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							| 
									
										
										
										
											2010-01-07 16:00:54 +08:00
										 |  |  | // x1 -> x2
 | 
					
						
							|  |  |  | //		-> x3 -> x4
 | 
					
						
							|  |  |  | //    -> x5
 | 
					
						
							| 
									
										
										
										
											2010-01-14 15:56:03 +08:00
										 |  |  | TEST ( Ordering, predecessorMap2Keys ) { | 
					
						
							| 
									
										
										
										
											2010-01-18 03:34:57 +08:00
										 |  |  | 	typedef TypedSymbol<Pose2,'x'> Key; | 
					
						
							| 
									
										
										
										
											2010-01-14 15:56:03 +08:00
										 |  |  | 	PredecessorMap<Key> p_map; | 
					
						
							| 
									
										
										
										
											2010-01-15 00:05:04 +08:00
										 |  |  | 	p_map.insert(1,1); | 
					
						
							|  |  |  | 	p_map.insert(2,1); | 
					
						
							|  |  |  | 	p_map.insert(3,1); | 
					
						
							|  |  |  | 	p_map.insert(4,3); | 
					
						
							|  |  |  | 	p_map.insert(5,1); | 
					
						
							| 
									
										
										
										
											2010-01-14 15:56:03 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	list<Key> expected; | 
					
						
							| 
									
										
										
										
											2010-01-15 00:05:04 +08:00
										 |  |  | 	expected += 4,5,3,2,1;//Key(4), Key(5), Key(3), Key(2), Key(1);
 | 
					
						
							| 
									
										
										
										
											2010-01-14 15:56:03 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	list<Key> actual = predecessorMap2Keys<Key>(p_map); | 
					
						
							|  |  |  | 	LONGS_EQUAL(expected.size(), actual.size()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	list<Key>::const_iterator it1 = expected.begin(); | 
					
						
							|  |  |  | 	list<Key>::const_iterator it2 = actual.begin(); | 
					
						
							|  |  |  | 	for(; it1!=expected.end(); it1++, it2++) | 
					
						
							|  |  |  | 		CHECK(*it1 == *it2) | 
					
						
							| 
									
										
										
										
											2010-01-07 16:00:54 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-29 02:35:36 +08:00
										 |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST ( Ordering, subtract ) { | 
					
						
							|  |  |  | 	Ordering init, delta; | 
					
						
							|  |  |  | 	init += "a", "b", "c", "d", "e"; | 
					
						
							|  |  |  | 	CHECK(assert_equal(init.subtract(delta), init)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	delta += "b"; | 
					
						
							|  |  |  | 	Ordering expected1; | 
					
						
							|  |  |  | 	expected1 += "a", "c", "d", "e"; | 
					
						
							|  |  |  | 	CHECK(assert_equal(init.subtract(delta), expected1)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	delta += "e"; | 
					
						
							|  |  |  | 	Ordering expected2; | 
					
						
							|  |  |  | 	expected2 += "a", "c", "d"; | 
					
						
							|  |  |  | 	CHECK(assert_equal(init.subtract(delta), expected2)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | int main() { TestResult tr; return TestRegistry::runAllTests(tr); } | 
					
						
							|  |  |  | /* ************************************************************************* */ |