1 
2 #include <iostream>
3 #include "BenchUtil.h"
4 #include "basicbenchmark.h"
5 
main(int argc,char * argv[])6 int main(int argc, char *argv[])
7 {
8   DISABLE_SSE_EXCEPTIONS();
9 
10   // this is the list of matrix type and size we want to bench:
11   // ((suffix) (matrix size) (number of iterations))
12   #define MODES ((3d)(3)(4000000)) ((4d)(4)(1000000)) ((Xd)(4)(1000000)) ((Xd)(20)(10000))
13 //   #define MODES ((Xd)(20)(10000))
14 
15   #define _GENERATE_HEADER(R,ARG,EL) << BOOST_PP_STRINGIZE(BOOST_PP_SEQ_HEAD(EL)) << "-" \
16     << BOOST_PP_STRINGIZE(BOOST_PP_SEQ_ELEM(1,EL)) << "x" \
17     << BOOST_PP_STRINGIZE(BOOST_PP_SEQ_ELEM(1,EL)) << "   /   "
18 
19   std::cout BOOST_PP_SEQ_FOR_EACH(_GENERATE_HEADER, ~, MODES ) << endl;
20 
21   const int tries = 10;
22 
23   #define _RUN_BENCH(R,ARG,EL) \
24     std::cout << ARG( \
25       BOOST_PP_CAT(Matrix, BOOST_PP_SEQ_HEAD(EL)) (\
26          BOOST_PP_SEQ_ELEM(1,EL),BOOST_PP_SEQ_ELEM(1,EL)), BOOST_PP_SEQ_ELEM(2,EL), tries) \
27     << "   ";
28 
29   BOOST_PP_SEQ_FOR_EACH(_RUN_BENCH, benchBasic<LazyEval>, MODES );
30   std::cout << endl;
31   BOOST_PP_SEQ_FOR_EACH(_RUN_BENCH, benchBasic<EarlyEval>, MODES );
32   std::cout << endl;
33 
34   return 0;
35 }
36