added unit test on params
							parent
							
								
									f340e6260e
								
							
						
					
					
						commit
						31e1a713fc
					
				|  | @ -98,6 +98,30 @@ TEST(GncOptimizer, gncConstructor) { | ||||||
|   CHECK(gnc.equals(gnc2)); |   CHECK(gnc.equals(gnc2)); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /* ************************************************************************* */ | ||||||
|  | TEST(GncOptimizer, solverParameterParsing) { | ||||||
|  |   // has to have Gaussian noise models !
 | ||||||
|  |   auto fg = example::createReallyNonlinearFactorGraph();  // just a unary factor
 | ||||||
|  |                                                           // on a 2D point
 | ||||||
|  | 
 | ||||||
|  |   Point2 p0(3, 3); | ||||||
|  |   Values initial; | ||||||
|  |   initial.insert(X(1), p0); | ||||||
|  | 
 | ||||||
|  |   LevenbergMarquardtParams lmParams; | ||||||
|  |   lmParams.setMaxIterations(0); // forces not to perform optimization
 | ||||||
|  |   GncParams<LevenbergMarquardtParams> gncParams(lmParams); | ||||||
|  |   auto gnc = GncOptimizer<GncParams<LevenbergMarquardtParams>>(fg, initial, | ||||||
|  |                                                                gncParams); | ||||||
|  |   Values result = gnc.optimize(); | ||||||
|  | 
 | ||||||
|  |   // check that LM did not perform optimization and result is the same as the initial guess
 | ||||||
|  |   DOUBLES_EQUAL(fg.error(initial), fg.error(result), tol); | ||||||
|  | 
 | ||||||
|  |   // also check the params:
 | ||||||
|  |   DOUBLES_EQUAL(0.0, gncParams.baseOptimizerParams.maxIterations, tol); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /* ************************************************************************* */ | /* ************************************************************************* */ | ||||||
| TEST(GncOptimizer, gncConstructorWithRobustGraphAsInput) { | TEST(GncOptimizer, gncConstructorWithRobustGraphAsInput) { | ||||||
|   auto fg = example::sharedNonRobustFactorGraphWithOutliers(); |   auto fg = example::sharedNonRobustFactorGraphWithOutliers(); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue