source: src/Jobs/MPQCData_printKeyNames.hpp@ 2dd305

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults AddingActions_SaveParseParticleParameters Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_ParticleName_to_Atom Adding_StructOpt_integration_tests AtomFragments Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator CombiningParticlePotentialParsing Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_BoundInBox_CenterInBox_MoleculeActions Fix_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_PopActions Fix_QtFragmentList_sorted_selection Fix_Restrictedkeyset_FragmentMolecule Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns Fix_fitting_potentials Fixes ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion FragmentAction_writes_AtomFragments FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity ImplicitCharges IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix MoreRobust_FragmentAutomation ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PdbParser_setsAtomName PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks Rewrite_FitPartialCharges RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching SaturateAtoms_singleDegree StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg Switchable_LogView ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps TremoloParser_setsAtomName Ubuntu_1604_changes stable
Last change on this file since 2dd305 was 4aee30, checked in by Frederik Heber <heber@…>, 13 years ago

Timings of MPQCJob are now gathered for total and for the gathering process.

  • the gathering process e.g. includes sampling of electron density.
  • Property mode set to 100644
File size: 2.4 KB
Line 
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 <boost/preprocessor/iteration/local.hpp>
20#include <boost/preprocessor/seq/elem.hpp>
21#include <boost/preprocessor/seq/seq.hpp>
22#include <boost/preprocessor/seq/size.hpp>
23#include <boost/preprocessor/stringize.hpp>
24
25/** this is the boost::preprocessor::sequence of the keys in the boost::fusion::map
26 *
27 * Basically, every key appears here in brackets. If so, then the preprocessor magic
28 * below will create a template specialization of the printName() function in the
29 * namespace printKeyNames.
30 */
31#define tokensequence \
32 (energy_total) \
33 (energy_nuclear_repulsion) \
34 (energy_electron_coulomb) \
35 (energy_electron_exchange) \
36 (energy_correlation) \
37 (energy_overlap) \
38 (energy_kinetic) \
39 (energy_hcore) \
40 (energy_eigenvalues) \
41 (forces) \
42 (sampled_grid) \
43 (times_total_walltime) \
44 (times_total_cputime) \
45 (times_total_flops) \
46 (times_gather_walltime) \
47 (times_gather_cputime) \
48 (times_gather_flops)
49
50/// we take note of the number of keys in tokensequence as (local) loop bounds below
51#ifndef tokensequence
52#define MAXTOKENS 0
53#else
54#define MAXTOKENS BOOST_PP_SEQ_SIZE(tokensequence)
55#endif
56
57//!> this is the macro function which prints the specialized template function
58#define printName_specializer(z, n, NAMESPACE, TOKENSEQ, NAMESEQ ) \
59 template<> std::string printName< NAMESPACE :: BOOST_PP_SEQ_ELEM( n, TOKENSEQ ) >() { \
60 return std::string( BOOST_PP_STRINGIZE( BOOST_PP_SEQ_ELEM( n, NAMESEQ ) ) ); \
61 }
62
63/** Specific namespace for all the specialized template functions that print
64 * a useful name for each of the boost::fusion::map key.
65 */
66namespace printKeyNames {
67 /* iterate (line-wise) over the sequence and spill out a specialized printName
68 * for each member in the boost::fusion::map.
69 */
70#if defined tokensequence && defined MAXTOKENS && defined printName_specializer
71#define BOOST_PP_LOCAL_MACRO(n) printName_specializer(~, n, MPQCDataFused, tokensequence, tokensequence)
72#define BOOST_PP_LOCAL_LIMITS (0, MAXTOKENS-1)
73#include BOOST_PP_LOCAL_ITERATE()
74#endif
75
76}; /* namespace printKeyNames */
77
78#undef tokensequence
79#undef printName_specializer
80
81#undef MAXTOKENS
82
83#endif /* MPQCDATA_PRINTKEYNAMES_HPP_ */
Note: See TracBrowser for help on using the repository browser.