| 1 | /* | 
|---|
| 2 | * MPQCData_printKeyNames.hpp | 
|---|
| 3 | * | 
|---|
| 4 | *  Created on: 28.07.2012 | 
|---|
| 5 | *      Author: heber | 
|---|
| 6 | */ | 
|---|
| 7 |  | 
|---|
| 8 | #ifndef MPQCDATA_PRINTKEYNAMES_HPP_ | 
|---|
| 9 | #define MPQCDATA_PRINTKEYNAMES_HPP_ | 
|---|
| 10 |  | 
|---|
| 11 | // include config.h | 
|---|
| 12 | #ifdef HAVE_CONFIG_H | 
|---|
| 13 | #include <config.h> | 
|---|
| 14 | #endif | 
|---|
| 15 |  | 
|---|
| 16 | //#include <iosfwd> | 
|---|
| 17 | #include <string> | 
|---|
| 18 |  | 
|---|
| 19 | #include "Fragmentation/Summation/printKeyNames.hpp" | 
|---|
| 20 |  | 
|---|
| 21 | #include <boost/preprocessor/iteration/local.hpp> | 
|---|
| 22 | #include <boost/preprocessor/seq/elem.hpp> | 
|---|
| 23 | #include <boost/preprocessor/seq/seq.hpp> | 
|---|
| 24 | #include <boost/preprocessor/seq/size.hpp> | 
|---|
| 25 | #include <boost/preprocessor/stringize.hpp> | 
|---|
| 26 |  | 
|---|
| 27 | /** this is the boost::preprocessor::sequence of the keys in the boost::fusion::map | 
|---|
| 28 | * | 
|---|
| 29 | * Basically, every key appears here in brackets. If so, then the preprocessor magic | 
|---|
| 30 | * below will create a template specialization of the printName() function in the | 
|---|
| 31 | * namespace printKeyNames. | 
|---|
| 32 | */ | 
|---|
| 33 | #define tokensequence \ | 
|---|
| 34 | (energy_total) \ | 
|---|
| 35 | (energy_nuclear_repulsion) \ | 
|---|
| 36 | (energy_electron_coulomb) \ | 
|---|
| 37 | (energy_electron_exchange) \ | 
|---|
| 38 | (energy_correlation) \ | 
|---|
| 39 | (energy_overlap) \ | 
|---|
| 40 | (energy_kinetic) \ | 
|---|
| 41 | (energy_hcore) \ | 
|---|
| 42 | (energy_eigenvalues) \ | 
|---|
| 43 | (energy_eigenhistogram) \ | 
|---|
| 44 | (forces) \ | 
|---|
| 45 | (sampled_grid) \ | 
|---|
| 46 | (times_total_walltime) \ | 
|---|
| 47 | (times_total_cputime) \ | 
|---|
| 48 | (times_total_flops) \ | 
|---|
| 49 | (times_gather_walltime) \ | 
|---|
| 50 | (times_gather_cputime) \ | 
|---|
| 51 | (times_gather_flops) | 
|---|
| 52 |  | 
|---|
| 53 | /// we take note of the number of keys in tokensequence as (local) loop bounds below | 
|---|
| 54 | #ifndef tokensequence | 
|---|
| 55 | #define MAXTOKENS 0 | 
|---|
| 56 | #else | 
|---|
| 57 | #define MAXTOKENS BOOST_PP_SEQ_SIZE(tokensequence) | 
|---|
| 58 | #endif | 
|---|
| 59 |  | 
|---|
| 60 | //!> this is the macro function which prints the specialized template function | 
|---|
| 61 | #define printName_specializer(z, n, NAMESPACE, TOKENSEQ, NAMESEQ ) \ | 
|---|
| 62 | template<> inline std::string printName< NAMESPACE :: BOOST_PP_SEQ_ELEM( n, TOKENSEQ ) >() { \ | 
|---|
| 63 | return std::string( BOOST_PP_STRINGIZE( BOOST_PP_SEQ_ELEM( n, NAMESEQ ) ) ); \ | 
|---|
| 64 | } | 
|---|
| 65 |  | 
|---|
| 66 | /** Specific namespace for all the specialized template functions that print | 
|---|
| 67 | * a useful name for each of the boost::fusion::map key. | 
|---|
| 68 | */ | 
|---|
| 69 | namespace printKeyNames { | 
|---|
| 70 | /* iterate (line-wise) over the sequence and spill out a specialized printName | 
|---|
| 71 | * for each member in the boost::fusion::map. | 
|---|
| 72 | */ | 
|---|
| 73 | #if defined tokensequence && defined MAXTOKENS && defined printName_specializer | 
|---|
| 74 | #define BOOST_PP_LOCAL_MACRO(n) printName_specializer(~, n, MPQCDataFused, tokensequence, tokensequence) | 
|---|
| 75 | #define BOOST_PP_LOCAL_LIMITS  (0, MAXTOKENS-1) | 
|---|
| 76 | #include BOOST_PP_LOCAL_ITERATE() | 
|---|
| 77 | #endif | 
|---|
| 78 |  | 
|---|
| 79 | }; /* namespace printKeyNames */ | 
|---|
| 80 |  | 
|---|
| 81 | #undef tokensequence | 
|---|
| 82 | #undef printName_specializer | 
|---|
| 83 |  | 
|---|
| 84 | #undef MAXTOKENS | 
|---|
| 85 |  | 
|---|
| 86 | #endif /* MPQCDATA_PRINTKEYNAMES_HPP_ */ | 
|---|