diff options
author | Thomas Capricelli <orzel@freehackers.org> | 2010-02-27 16:30:15 +0100 |
---|---|---|
committer | Thomas Capricelli <orzel@freehackers.org> | 2010-02-27 16:30:15 +0100 |
commit | 15a33622acfb195935adf190508d7e9e8238c4ee (patch) | |
tree | 334f4a077d3c5c7a41797bcfa9f0597d62e51e60 | |
parent | d9f638049994b90ed388c68c8a0ab7efc2e5615c (diff) |
* define COMPARE(,), which prints expected/actual results in case of failure
* use it in test/NonLinearOptimization.cpp
-rw-r--r-- | test/main.h | 7 | ||||
-rw-r--r-- | unsupported/test/NonLinearOptimization.cpp | 94 |
2 files changed, 54 insertions, 47 deletions
diff --git a/test/main.h b/test/main.h index 5ca9395c2..f4cfa11c5 100644 --- a/test/main.h +++ b/test/main.h @@ -157,6 +157,13 @@ namespace Eigen exit(2); \ } } while (0) +// Use COMPARE for exact comparison of scalar values (mostly, int) +#define COMPARE(actual, expected) do { if (actual!=expected) { \ + std::cerr << "Test " << g_test_stack.back() << ". Comparison failed in "EI_PP_MAKE_STRING(__FILE__) << " (" << EI_PP_MAKE_STRING(__LINE__) << ")" \ + << std::endl << " actual = " << actual \ + << std::endl << " expected = " << expected << std::endl << std::endl; \ + exit(2); \ + } } while (0) #define VERIFY_IS_EQUAL(a, b) VERIFY(test_is_equal(a, b)) #define VERIFY_IS_APPROX(a, b) VERIFY(test_ei_isApprox(a, b)) #define VERIFY_IS_NOT_APPROX(a, b) VERIFY(!test_ei_isApprox(a, b)) diff --git a/unsupported/test/NonLinearOptimization.cpp b/unsupported/test/NonLinearOptimization.cpp index 7aea7b361..38d7b7766 100644 --- a/unsupported/test/NonLinearOptimization.cpp +++ b/unsupported/test/NonLinearOptimization.cpp @@ -172,9 +172,9 @@ void testLmder1() info = lm.lmder1(x); // check return value - VERIFY( 1 == info); - VERIFY(lm.nfev==6); - VERIFY(lm.njev==5); + COMPARE(info, 1); + COMPARE(lm.nfev, 6); + COMPARE(lm.njev, 5); // check norm VERIFY_IS_APPROX(lm.fvec.blueNorm(), 0.09063596); @@ -201,9 +201,9 @@ void testLmder() info = lm.minimize(x); // check return values - VERIFY( 1 == info); - VERIFY(lm.nfev==6); - VERIFY(lm.njev==5); + COMPARE(info, 1); + COMPARE(lm.nfev, 6); + COMPARE(lm.njev, 5); // check norm fnorm = lm.fvec.blueNorm(); @@ -286,7 +286,7 @@ void testHybrj1() info = solver.hybrj1(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY(solver.nfev==11); VERIFY(solver.njev==1); @@ -321,7 +321,7 @@ void testHybrj() info = solver.solve(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY(solver.nfev==11); VERIFY(solver.njev==1); @@ -375,7 +375,7 @@ void testHybrd1() info = solver.hybrd1(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY(solver.nfev==20); // check norm @@ -406,7 +406,7 @@ void testHybrd() info = solver.solveNumericalDiff(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY(solver.nfev==14); // check norm @@ -477,9 +477,9 @@ void testLmstr1() info = lm.lmstr1(x); // check return value - VERIFY( 1 == info); - VERIFY(lm.nfev==6); - VERIFY(lm.njev==5); + COMPARE(info, 1); + COMPARE(lm.nfev, 6); + COMPARE(lm.njev, 5); // check norm VERIFY_IS_APPROX(lm.fvec.blueNorm(), 0.09063596); @@ -506,9 +506,9 @@ void testLmstr() info = lm.minimizeOptimumStorage(x); // check return values - VERIFY( 1 == info); - VERIFY(lm.nfev==6); - VERIFY(lm.njev==5); + COMPARE(info, 1); + COMPARE(lm.nfev, 6); + COMPARE(lm.njev, 5); // check norm fnorm = lm.fvec.blueNorm(); @@ -562,7 +562,7 @@ void testLmdif1() info = LevenbergMarquardt<lmdif_functor>::lmdif1(functor, x, &nfev); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY(nfev==26); // check norm @@ -593,8 +593,8 @@ void testLmdif() info = lm.minimize(x); // check return values - VERIFY( 1 == info); - VERIFY(lm.nfev==26); + COMPARE(info, 1); + COMPARE(lm.nfev, 26); // check norm fnorm = lm.fvec.blueNorm(); @@ -678,7 +678,7 @@ void testNistChwirut2(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 10 == lm.nfev); VERIFY( 8 == lm.njev); // check norm^2 @@ -699,7 +699,7 @@ void testNistChwirut2(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 7 == lm.nfev); VERIFY( 6 == lm.njev); // check norm^2 @@ -758,7 +758,7 @@ void testNistMisra1a(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 19 == lm.nfev); VERIFY( 15 == lm.njev); // check norm^2 @@ -775,7 +775,7 @@ void testNistMisra1a(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 5 == lm.nfev); VERIFY( 4 == lm.njev); // check norm^2 @@ -844,7 +844,7 @@ void testNistHahn1(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 11== lm.nfev); VERIFY( 10== lm.njev); // check norm^2 @@ -866,7 +866,7 @@ void testNistHahn1(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 11 == lm.nfev); VERIFY( 10 == lm.njev); // check norm^2 @@ -930,7 +930,7 @@ void testNistMisra1d(void) info = lm.minimize(x); // check return value - VERIFY( 3 == info); + COMPARE(info, 3); VERIFY( 9 == lm.nfev); VERIFY( 7 == lm.njev); // check norm^2 @@ -947,7 +947,7 @@ void testNistMisra1d(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 4 == lm.nfev); VERIFY( 3 == lm.njev); // check norm^2 @@ -1008,7 +1008,7 @@ void testNistLanczos1(void) info = lm.minimize(x); // check return value - VERIFY( 2 == info); + COMPARE(info, 2); VERIFY( 79 == lm.nfev); VERIFY( 72 == lm.njev); // check norm^2 @@ -1029,7 +1029,7 @@ void testNistLanczos1(void) info = lm.minimize(x); // check return value - VERIFY( 2 == info); + COMPARE(info, 2); VERIFY( 9 == lm.nfev); VERIFY( 8 == lm.njev); // check norm^2 @@ -1094,7 +1094,7 @@ void testNistRat42(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 10 == lm.nfev); VERIFY( 8 == lm.njev); // check norm^2 @@ -1112,7 +1112,7 @@ void testNistRat42(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 6 == lm.nfev); VERIFY( 5 == lm.njev); // check norm^2 @@ -1172,7 +1172,7 @@ void testNistMGH10(void) info = lm.minimize(x); // check return value - VERIFY( 2 == info); + COMPARE(info, 2); VERIFY( 284 == lm.nfev); VERIFY( 249 == lm.njev); // check norm^2 @@ -1190,7 +1190,7 @@ void testNistMGH10(void) info = lm.minimize(x); // check return value - VERIFY( 3 == info); + COMPARE(info, 3); VERIFY( 126 == lm.nfev); VERIFY( 116 == lm.njev); // check norm^2 @@ -1251,7 +1251,7 @@ void testNistBoxBOD(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 31 == lm.nfev); VERIFY( 25 == lm.njev); // check norm^2 @@ -1271,7 +1271,7 @@ void testNistBoxBOD(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 15 == lm.nfev); VERIFY( 14 == lm.njev); // check norm^2 @@ -1333,7 +1333,7 @@ void testNistMGH17(void) info = lm.minimize(x); // check return value - VERIFY( 2 == info); + COMPARE(info, 2); VERIFY( 602 == lm.nfev); VERIFY( 545 == lm.njev); // check norm^2 @@ -1354,7 +1354,7 @@ void testNistMGH17(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 18 == lm.nfev); VERIFY( 15 == lm.njev); // check norm^2 @@ -1420,7 +1420,7 @@ void testNistMGH09(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 490 == lm.nfev); VERIFY( 376 == lm.njev); // check norm^2 @@ -1440,7 +1440,7 @@ void testNistMGH09(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 18 == lm.nfev); VERIFY( 16 == lm.njev); // check norm^2 @@ -1503,7 +1503,7 @@ void testNistBennett5(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 758 == lm.nfev); VERIFY( 744 == lm.njev); // check norm^2 @@ -1521,7 +1521,7 @@ void testNistBennett5(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 203 == lm.nfev); VERIFY( 192 == lm.njev); // check norm^2 @@ -1591,7 +1591,7 @@ void testNistThurber(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 39 == lm.nfev); VERIFY( 36== lm.njev); // check norm^2 @@ -1616,7 +1616,7 @@ void testNistThurber(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 29 == lm.nfev); VERIFY( 28 == lm.njev); // check norm^2 @@ -1683,7 +1683,7 @@ void testNistRat43(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 27 == lm.nfev); VERIFY( 20 == lm.njev); // check norm^2 @@ -1705,7 +1705,7 @@ void testNistRat43(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 9 == lm.nfev); VERIFY( 8 == lm.njev); // check norm^2 @@ -1768,7 +1768,7 @@ void testNistEckerle4(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 18 == lm.nfev); VERIFY( 15 == lm.njev); // check norm^2 @@ -1786,7 +1786,7 @@ void testNistEckerle4(void) info = lm.minimize(x); // check return value - VERIFY( 1 == info); + COMPARE(info, 1); VERIFY( 7 == lm.nfev); VERIFY( 6 == lm.njev); // check norm^2 |