| 
									
										
										
										
											2011-01-20 23:42:11 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file testNonlinearISAM | 
					
						
							|  |  |  |  * @author Alex Cunningham | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <CppUnitLite/TestHarness.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <gtsam/linear/Sampler.h>
 | 
					
						
							| 
									
										
										
										
											2011-11-18 05:20:04 +08:00
										 |  |  | #include <gtsam/nonlinear/NonlinearISAM.h>
 | 
					
						
							| 
									
										
										
										
											2011-01-20 23:42:11 +08:00
										 |  |  | #include <gtsam/slam/planarSLAM.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | using namespace gtsam; | 
					
						
							|  |  |  | using namespace planarSLAM; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-30 12:34:46 +08:00
										 |  |  | typedef NonlinearISAM<> PlanarISAM; | 
					
						
							| 
									
										
										
										
											2011-01-20 23:42:11 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | const double tol=1e-5; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | TEST(testNonlinearISAM, markov_chain ) { | 
					
						
							|  |  |  | 	int reorder_interval = 2; | 
					
						
							| 
									
										
										
										
											2011-01-29 08:53:15 +08:00
										 |  |  | 	PlanarISAM isam(reorder_interval); // create an ISAM object
 | 
					
						
							| 
									
										
										
										
											2011-01-20 23:42:11 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	SharedDiagonal model = noiseModel::Diagonal::Sigmas(Vector_(3, 3.0, 3.0, 0.5)); | 
					
						
							|  |  |  | 	Sampler sampler(model, 42u); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// create initial graph
 | 
					
						
							|  |  |  | 	PoseKey key(0); | 
					
						
							|  |  |  | 	Pose2 cur_pose; // start at origin
 | 
					
						
							|  |  |  | 	Graph start_factors; | 
					
						
							|  |  |  | 	start_factors.addPoseConstraint(key, cur_pose); | 
					
						
							| 
									
										
										
										
											2011-06-14 00:55:31 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-06 06:34:35 +08:00
										 |  |  | 	planarSLAM::Values init; | 
					
						
							|  |  |  | 	planarSLAM::Values expected; | 
					
						
							| 
									
										
										
										
											2011-01-20 23:42:11 +08:00
										 |  |  | 	init.insert(key, cur_pose); | 
					
						
							|  |  |  | 	expected.insert(key, cur_pose); | 
					
						
							|  |  |  | 	isam.update(start_factors, init); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// loop for a period of time to verify memory usage
 | 
					
						
							|  |  |  | 	size_t nrPoses = 21; | 
					
						
							|  |  |  | 	Pose2 z(1.0, 2.0, 0.1); | 
					
						
							|  |  |  | 	for (size_t i=1; i<=nrPoses; ++i) { | 
					
						
							|  |  |  | 		Graph new_factors; | 
					
						
							|  |  |  | 		PoseKey key1(i-1), key2(i); | 
					
						
							|  |  |  | 		new_factors.addOdometry(key1, key2, z, model); | 
					
						
							| 
									
										
										
										
											2012-02-06 06:34:35 +08:00
										 |  |  | 		planarSLAM::Values new_init; | 
					
						
							| 
									
										
										
										
											2011-02-02 11:50:06 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		// perform a check on changing orderings
 | 
					
						
							|  |  |  | 		if (i == 5) { | 
					
						
							|  |  |  | 			Ordering ordering = isam.getOrdering(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			// swap last two elements
 | 
					
						
							|  |  |  | 			Symbol last = ordering.pop_back().first; | 
					
						
							|  |  |  | 			Symbol secondLast = ordering.pop_back().first; | 
					
						
							|  |  |  | 			ordering.push_back(last); | 
					
						
							|  |  |  | 			ordering.push_back(secondLast); | 
					
						
							|  |  |  | 			isam.setOrdering(ordering); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			Ordering expected; expected += PoseKey(0), PoseKey(1), PoseKey(2), PoseKey(4), PoseKey(3); | 
					
						
							|  |  |  | 			EXPECT(assert_equal(expected, isam.getOrdering())); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-20 23:42:11 +08:00
										 |  |  | 		cur_pose = cur_pose.compose(z); | 
					
						
							| 
									
										
										
										
											2011-11-05 05:44:34 +08:00
										 |  |  | 		new_init.insert(key2, cur_pose.retract(sampler.sample())); | 
					
						
							| 
									
										
										
										
											2011-01-20 23:42:11 +08:00
										 |  |  | 		expected.insert(key2, cur_pose); | 
					
						
							|  |  |  | 		isam.update(new_factors, new_init); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// verify values - all but the last one should be very close
 | 
					
						
							| 
									
										
										
										
											2012-02-06 06:34:35 +08:00
										 |  |  | 	planarSLAM::Values actual = isam.estimate(); | 
					
						
							| 
									
										
										
										
											2011-06-14 00:55:31 +08:00
										 |  |  | 	for (size_t i=0; i<nrPoses; ++i) { | 
					
						
							| 
									
										
										
										
											2011-01-20 23:42:11 +08:00
										 |  |  | 		PoseKey cur_key(i); | 
					
						
							|  |  |  | 		EXPECT(assert_equal(expected[cur_key], actual[cur_key], tol)); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* ************************************************************************* */ | 
					
						
							|  |  |  | int main() { TestResult tr; return TestRegistry::runAllTests(tr); } | 
					
						
							|  |  |  | /* ************************************************************************* */ |