source: trunk/test_more/test_more.cpp @ 3683

Last change on this file since 3683 was 3683, checked in by bradbell, 5 years ago

merge to branch: trunk
from repository: https://github.com/coin-or/CppAD
start hash code: febe930d34888cf37df862a1bf118229b9bf37a5
end hash code: 494270b7d9413bba508ae4944e44e33b6f7be05b

commit 494270b7d9413bba508ae4944e44e33b6f7be05b
Author: Brad Bell <bradbell@…>
Date: Sat May 9 19:20:51 2015 -0700

  1. Fix duplicate expm1 in example and test_more makefile.am, CMakeLists.txt.
  2. Extend log theory to include log1p function.


log_forward.omh: remove trailing white space
log_reverse.omh: remove trailing white space

commit d2e5c615a1d620d364c7c73f47f9db18aa4bcba3
Author: Brad Bell <bradbell@…>
Date: Sat May 9 10:09:24 2015 -0700

Add new flags to configure.ac and include auto-tools automatic changes.


test_one.sh.in: handel case where space between name and (void).
exp_reverse.omh: change plural to singular.
test_one.sh.in: handel case where space between name and (void).

commit c62e0f95b359b188556d49fb7e3a75b0eaad12e4
Author: Brad Bell <bradbell@…>
Date: Sat May 9 07:14:17 2015 -0700

Remove trialing white space.

commit f443608ff6f29ed5ff05fa136543d6f2baab7757
Author: Brad Bell <bradbell@…>
Date: Sat May 9 07:13:53 2015 -0700

Fix some warnings when using eigen_vector for the test vector.


configure.ac: Comments for auto-tool commands that will result in many makefile.in changes.
makefile.in: automatic change from corresponding makefile.am.
test_one.sh.in: use cppad_cxx_flags to determine if c++11.
makefile.in: automatic change from corresponding makefile.am.
exp_forward.omh: Fix z{(0)} to be correct for both cases.
makefile.in: automatic change from corresponding makefile.am.

commit 003b9c373b2b77fde81427f57ee3db364fea5eff
Author: Brad Bell <bradbell@…>
Date: Sat May 9 04:53:44 2015 -0700

Add expm1 function.

commit a2b3d2fd72cda066e110368860452c5299211c30
Author: Brad Bell <bradbell@…>
Date: Fri May 8 19:39:12 2015 -0700

CMakeLists.txt: simplify ENDFOREACH command.

commit 31016ed04a3fd618456de115fd98c58f07b89f3e
Author: Brad Bell <bradbell@…>
Date: Fri May 8 17:04:34 2015 -0700

check_example.sh: Fix check that all examples are in list, remove trailing white space.
exp.cpp: minor white space edit.
example_list.omh: add examples that were missing.

commit e48ff330292e90ba40baffa8b2d1b2d12c44f099
Author: Brad Bell <bradbell@…>
Date: Fri May 8 16:31:28 2015 -0700

  1. Add expm1 funtion to exp theory.
  2. Change Exp -> exp.
  3. Remove redundant index commands.
  4. Remove trailing white space.


exp.cpp: more modern names in example.

  • Property svn:keywords set to Id
File size: 8.7 KB
Line 
1/* $Id: test_more.cpp 3683 2015-05-10 02:24:16Z bradbell $ */
2/* --------------------------------------------------------------------------
3CppAD: C++ Algorithmic Differentiation: Copyright (C) 2003-15 Bradley M. Bell
4
5CppAD is distributed under multiple licenses. This distribution is under
6the terms of the
7                    Eclipse Public License Version 1.0.
8
9A copy of this license is included in the COPYING file of this distribution.
10Please visit http://www.coin-or.org/CppAD/ for information on other licenses.
11-------------------------------------------------------------------------- */
12
13// system include files used for I/O
14# include <iostream>
15
16// memory leak checker
17# include <cppad/thread_alloc.hpp>
18
19// prototype external compiled tests (this line expected by bin/new_test.sh)
20extern bool abs(void);
21extern bool acos(void);
22extern bool acosh(void);
23extern bool adfun_copy(void);
24extern bool Add(void);
25extern bool AddEq(void);
26extern bool AddZero(void);
27extern bool alloc_openmp(void);
28extern bool asin(void);
29extern bool asinh(void);
30extern bool assign(void);
31extern bool atan(void);
32extern bool atanh(void);
33extern bool atan2(void);
34extern bool base_adolc(void);
35extern bool base_alloc_test(void);
36extern bool check_simple_vector(void);
37extern bool checkpoint(void);
38extern bool Compare(void);
39extern bool compare_change(void);
40extern bool CondExp(void);
41extern bool CondExpAD(void);
42extern bool cond_exp_rev(void);
43extern bool copy(void);
44extern bool Cos(void);
45extern bool Cosh(void);
46extern bool cppad_eigen(void);
47extern bool dbl_epsilon(void);
48extern bool Div(void);
49extern bool DivEq(void);
50extern bool DivZeroOne(void);
51extern bool erf(void);
52extern bool Exp(void);
53extern bool expm1(void);
54extern bool ForHess(void);
55extern bool for_sparse_jac(void);
56extern bool Forward(void);
57extern bool forward_dir(void);
58extern bool forward_order(void);
59extern bool FromBase(void);
60extern bool FunCheck(void);
61extern bool ipopt_solve(void);
62extern bool jacobian(void);
63extern bool limits(void);
64extern bool Log(void);
65extern bool Log10(void);
66extern bool Mul(void);
67extern bool mul_level(void);
68extern bool MulEq(void);
69extern bool MulZeroOne(void);
70extern bool NearEqualExt(void);
71extern bool Neg(void);
72extern bool ode_err_control(void);
73extern bool optimize(void);
74extern bool parameter(void);
75extern bool Poly(void);
76extern bool Pow(void);
77extern bool PowInt(void);
78extern bool print_for(void);
79extern bool reverse(void);
80extern bool rev_sparse_hes(void);
81extern bool rev_sparse_jac(void);
82extern bool RevTwo(void);
83extern bool RombergOne(void);
84extern bool Rosen34(void);
85extern bool Runge45(void);
86extern bool SimpleVector(void);
87extern bool Sin(void);
88extern bool SinCos(void);
89extern bool Sinh(void);
90extern bool sparse_hessian(void);
91extern bool sparse_jacobian(void);
92extern bool sparse_vec_ad(void);
93extern bool Sqrt(void);
94extern bool std_math(void);
95extern bool Sub(void);
96extern bool SubEq(void);
97extern bool SubZero(void);
98extern bool tan(void);
99extern bool test_vector(void);
100extern bool track_new_del(void);
101extern bool Value(void);
102extern bool VecAD(void);
103extern bool VecADPar(void);
104extern bool VecUnary(void);
105
106namespace {
107        // function that runs one test
108        static size_t Run_ok_count    = 0;
109        static size_t Run_error_count = 0;
110        bool Run(bool TestOk(void), std::string name)
111        {       bool ok               = true;
112                std::streamsize width =  20;
113                std::cout.width( width );
114                std::cout.setf( std::ios_base::left );
115                std::cout << name;
116                //
117                ok &= name.size() < size_t(width);
118                ok &= TestOk();
119                if( ok )
120                {       std::cout << "OK" << std::endl;
121                        Run_ok_count++;
122                }
123                else
124                {       std::cout << "Error" << std::endl;
125                        Run_error_count++;
126                }
127                return ok;
128        }
129}
130
131// main program that runs all the tests
132int main(void)
133{       bool ok = true;
134        using namespace std;
135
136        // This line is used by test_one.sh
137
138        // run external compiled tests (this line expected by bin/new_test.sh)
139        ok &= Run( abs,             "abs"            );
140        ok &= Run( acos,            "acos"           );
141        ok &= Run( acosh,           "acosh"          );
142        ok &= Run( adfun_copy,      "adfun_copy"     );
143        ok &= Run( Add,             "Add"            );
144        ok &= Run( AddEq,           "AddEq"          );
145        ok &= Run( AddZero,         "AddZero"        );
146        ok &= Run( asin,            "asin"           );
147        ok &= Run( asinh,           "asinh"          );
148        ok &= Run( assign,          "assign"         );
149        ok &= Run( atan,            "atan"           );
150        ok &= Run( atanh,           "atanh"          );
151        ok &= Run( atan2,           "atan2"          );
152        ok &= Run( check_simple_vector, "check_simple_vector" );
153        ok &= Run( checkpoint,      "checkpoint"     );
154        ok &= Run( Compare,         "Compare"        );
155        ok &= Run( compare_change,  "compare_change" );
156        ok &= Run( CondExp,         "CondExp"        );
157        ok &= Run( CondExpAD,       "CondExpAD"      );
158        ok &= Run( cond_exp_rev,    "cond_exp_rev"   );
159        ok &= Run( copy,            "copy"           );
160        ok &= Run( Cos,             "Cos"            );
161        ok &= Run( Cosh,            "Cosh"           );
162        ok &= Run( dbl_epsilon,     "dbl_epsilon"    );
163        ok &= Run( Div,             "Div"            );
164        ok &= Run( DivEq,           "DivEq"          );
165        ok &= Run( DivZeroOne,      "DivZeroOne"     );
166        ok &= Run( erf,             "erf"            );
167        ok &= Run( Exp,             "Exp"            );
168        ok &= Run( expm1,           "expm1"          );
169        ok &= Run( ForHess,         "ForHess"        );
170        ok &= Run( for_sparse_jac,  "for_sparse_jac" );
171        ok &= Run( Forward,         "Forward"        );
172        ok &= Run( forward_dir,     "forward_dir"    );
173        ok &= Run( forward_order,   "forward_order"  );
174        ok &= Run( FromBase,        "FromBase"       );
175        ok &= Run( FunCheck,        "FunCheck"       );
176        ok &= Run( jacobian,        "jacobian"       );
177        ok &= Run( limits,          "limits"         );
178        ok &= Run( Log,             "Log"            );
179        ok &= Run( Log10,           "Log10"          );
180        ok &= Run( Mul,             "Mul"            );
181        ok &= Run( mul_level,       "mul_level"      );
182        ok &= Run( MulEq,           "MulEq"          );
183        ok &= Run( MulZeroOne,      "MulZeroOne"     );
184        ok &= Run( NearEqualExt,    "NearEqualExt"   );
185        ok &= Run( Neg,             "Neg"            );
186        ok &= Run( ode_err_control, "ode_err_control");
187        ok &= Run( optimize,        "optimize"       );
188        ok &= Run( parameter,       "parameter"      );
189        ok &= Run( Poly,            "Poly"           );
190        ok &= Run( Pow,             "Pow"            );
191        ok &= Run( PowInt,          "PowInt"         );
192        ok &= Run( print_for,       "print_for"      );
193        ok &= Run( reverse,         "reverse"        );
194        ok &= Run( rev_sparse_hes,  "rev_sparse_hes" );
195        ok &= Run( rev_sparse_jac,  "rev_sparse_jac" );
196        ok &= Run( RevTwo,          "RevTwo"         );
197        ok &= Run( RombergOne,      "RombergOne"     );
198        ok &= Run( Rosen34,         "Rosen34"        );
199        ok &= Run( Runge45,         "Runge45"        );
200        ok &= Run( SimpleVector,    "SimpleVector"   );
201        ok &= Run( Sin,             "Sin"            );
202        ok &= Run( SinCos,          "SinCos"         );
203        ok &= Run( Sinh,            "Sinh"           );
204        ok &= Run( sparse_hessian,  "sparse_hessian" );
205        ok &= Run( sparse_jacobian, "sparse_jacobian");
206        ok &= Run( sparse_vec_ad,   "sparse_vec_ad"  );
207        ok &= Run( Sqrt,            "Sqrt"           );
208        ok &= Run( std_math,        "std_math"       );
209        ok &= Run( Sub,             "Sub"            );
210        ok &= Run( SubEq,           "SubEq"          );
211        ok &= Run( SubZero,         "SubZero"        );
212        ok &= Run( tan,             "tan"            );
213        ok &= Run( track_new_del,   "track_new_del"  );
214        ok &= Run( Value,           "Value"          );
215        ok &= Run( VecAD,           "VecAD"          );
216        ok &= Run( VecADPar,        "VecADPar"       );
217        ok &= Run( VecUnary,        "VecUnary"       );
218# ifdef CPPAD_ADOLC_TEST
219        ok &= Run( base_adolc,      "base_adolc"     );
220# endif
221# ifdef CPPAD_IPOPT_TEST
222        ok &= Run( ipopt_solve,     "ipopt_solve"    );
223# endif
224# ifdef CPPAD_OPENMP_TEST
225        ok &= Run( alloc_openmp,    "alloc_openmp"   );
226# endif
227# ifdef CPPAD_EIGEN_TEST
228        ok &= Run( cppad_eigen, "cppad_eigen" );
229# endif
230# if ! CPPAD_EIGENVECTOR
231        ok &= Run( test_vector, "test_vector" );
232# endif
233
234        // check for errors
235        using std::cout;
236        using std::endl;
237        assert( ok || (Run_error_count > 0) );
238        if( CppAD::thread_alloc::free_all() )
239        {       Run_ok_count++;
240                cout << "OK:    " << "No memory leak detected" << endl;
241        }
242        else
243        {       ok = false;
244                Run_error_count++;
245                cout << "Error: " << "memory leak detected" << endl;
246        }
247        // Run base_require after memory leak check because base_alloc.hpp uses
248        // thread_alloc to allocate memory for static copies of nan.
249        ok &= Run( base_alloc_test, "base_alloc"     );
250        // convert int(size_t) to avoid warning on _MSC_VER systems
251        if( ok )
252                cout << "All " << int(Run_ok_count) << " tests passed." << endl;
253        else    cout << int(Run_error_count) << " tests failed." << endl;
254
255        return static_cast<int>( ! ok );
256
257}
258// END PROGRAM
Note: See TracBrowser for help on using the repository browser.