| 
									
										
										
										
											2015-07-06 01:26:11 +08:00
										 |  |  | /* ----------------------------------------------------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  * GTSAM Copyright 2010, Georgia Tech Research Corporation, | 
					
						
							|  |  |  |  * Atlanta, Georgia 30332-0415 | 
					
						
							|  |  |  |  * All Rights Reserved | 
					
						
							|  |  |  |  * Authors: Frank Dellaert, et al. (see THANKS for the full author list) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  * See LICENSE for the license information | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  * -------------------------------------------------------------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @file    timeSFMBAL.h | 
					
						
							|  |  |  |  * @brief   Common code for timeSFMBAL scripts | 
					
						
							|  |  |  |  * @author  Frank Dellaert | 
					
						
							|  |  |  |  * @date    July 5, 2015 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <gtsam/slam/dataset.h>
 | 
					
						
							|  |  |  | #include <gtsam/nonlinear/LevenbergMarquardtOptimizer.h>
 | 
					
						
							|  |  |  | #include <gtsam/nonlinear/NonlinearFactorGraph.h>
 | 
					
						
							|  |  |  | #include <gtsam/nonlinear/Values.h>
 | 
					
						
							|  |  |  | #include <gtsam/linear/NoiseModel.h>
 | 
					
						
							|  |  |  | #include <gtsam/inference/Ordering.h>
 | 
					
						
							|  |  |  | #include <gtsam/inference/Symbol.h>
 | 
					
						
							|  |  |  | #include <gtsam/base/timing.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <string>
 | 
					
						
							|  |  |  | #include <vector>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | using namespace std; | 
					
						
							|  |  |  | using namespace gtsam; | 
					
						
							|  |  |  | using symbol_shorthand::C; | 
					
						
							|  |  |  | using symbol_shorthand::K; | 
					
						
							|  |  |  | using symbol_shorthand::P; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static bool gUseSchur = true; | 
					
						
							|  |  |  | static SharedNoiseModel gNoiseModel = noiseModel::Unit::Create(2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // parse options and read BAL file
 | 
					
						
							|  |  |  | SfM_data preamble(int argc, char* argv[]) { | 
					
						
							|  |  |  |   // primitive argument parsing:
 | 
					
						
							|  |  |  |   if (argc > 2) { | 
					
						
							| 
									
										
										
										
											2015-07-06 02:18:45 +08:00
										 |  |  |     if (strcmp(argv[1], "--colamd")) | 
					
						
							| 
									
										
										
										
											2015-07-06 01:26:11 +08:00
										 |  |  |       gUseSchur = false; | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       throw runtime_error("Usage: timeSFMBALxxx [--colamd] [BALfile]"); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Load BAL file
 | 
					
						
							|  |  |  |   SfM_data db; | 
					
						
							| 
									
										
										
										
											2016-02-09 10:58:57 +08:00
										 |  |  |   string filename; | 
					
						
							|  |  |  |   if (argc > 1) | 
					
						
							|  |  |  |     filename = argv[argc - 1]; | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     filename = findExampleDataFile("dubrovnik-16-22106-pre"); | 
					
						
							| 
									
										
										
										
											2016-02-26 10:25:53 +08:00
										 |  |  |   bool success = readBAL(filename, db); | 
					
						
							| 
									
										
										
										
											2015-07-06 01:26:11 +08:00
										 |  |  |   if (!success) throw runtime_error("Could not access file!"); | 
					
						
							|  |  |  |   return db; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Create ordering and optimize
 | 
					
						
							|  |  |  | int optimize(const SfM_data& db, const NonlinearFactorGraph& graph, | 
					
						
							| 
									
										
										
										
											2015-07-06 02:18:45 +08:00
										 |  |  |              const Values& initial, bool separateCalibration = false) { | 
					
						
							| 
									
										
										
										
											2015-07-06 01:26:11 +08:00
										 |  |  |   using symbol_shorthand::P; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Set parameters to be similar to ceres
 | 
					
						
							|  |  |  |   LevenbergMarquardtParams params; | 
					
						
							|  |  |  |   LevenbergMarquardtParams::SetCeresDefaults(¶ms); | 
					
						
							| 
									
										
										
										
											2016-06-19 14:13:59 +08:00
										 |  |  | //  params.setLinearSolverType("SEQUENTIAL_CHOLESKY");
 | 
					
						
							| 
									
										
										
										
											2016-02-27 00:28:16 +08:00
										 |  |  | //  params.setVerbosityLM("SUMMARY");
 | 
					
						
							| 
									
										
										
										
											2015-07-06 01:26:11 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (gUseSchur) { | 
					
						
							|  |  |  |     // Create Schur-complement ordering
 | 
					
						
							|  |  |  |     Ordering ordering; | 
					
						
							|  |  |  |     for (size_t j = 0; j < db.number_tracks(); j++) ordering.push_back(P(j)); | 
					
						
							| 
									
										
										
										
											2015-07-06 02:18:45 +08:00
										 |  |  |     for (size_t i = 0; i < db.number_cameras(); i++) { | 
					
						
							|  |  |  |       ordering.push_back(C(i)); | 
					
						
							|  |  |  |       if (separateCalibration) ordering.push_back(K(i)); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-07-06 01:26:11 +08:00
										 |  |  |     params.setOrdering(ordering); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Optimize
 | 
					
						
							| 
									
										
										
										
											2016-02-27 00:28:16 +08:00
										 |  |  |   { | 
					
						
							|  |  |  |     gttic_(optimize); | 
					
						
							|  |  |  |     LevenbergMarquardtOptimizer lm(graph, initial, params); | 
					
						
							|  |  |  |     Values result = lm.optimize(); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 01:26:11 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   tictoc_finishedIteration_(); | 
					
						
							|  |  |  |   tictoc_print_(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return 0; | 
					
						
							|  |  |  | } |