1 | /*
|
---|
2 | * MPQCDataMap.hpp
|
---|
3 | *
|
---|
4 | * Created on: 28.07.2012
|
---|
5 | * Author: heber
|
---|
6 | */
|
---|
7 |
|
---|
8 | #ifndef MPQCDATAMAP_HPP_
|
---|
9 | #define MPQCDATAMAP_HPP_
|
---|
10 |
|
---|
11 | // include config.h
|
---|
12 | #ifdef HAVE_CONFIG_H
|
---|
13 | #include <config.h>
|
---|
14 | #endif
|
---|
15 |
|
---|
16 | #include <boost/fusion/container/map.hpp>
|
---|
17 | #include <boost/mpl/list.hpp>
|
---|
18 |
|
---|
19 | #include "Jobs/MPQCDataFused.hpp"
|
---|
20 |
|
---|
21 | class Fragment;
|
---|
22 | class Histogram;
|
---|
23 | class IndexedVectors;
|
---|
24 | class SamplingGrid;
|
---|
25 |
|
---|
26 | /// \note: We had to split up the map because boost::fusion only allows for
|
---|
27 | /// up to 9 template types.
|
---|
28 |
|
---|
29 | /** This boost::fusion map defines key-value or rather key-type pairs with
|
---|
30 | * which we associate all energy_t data members in MPQCData and their type.
|
---|
31 | *
|
---|
32 | * This lets us resolves any ambiguitites of types in MPQCData, e.g.
|
---|
33 | * to know vector<double> is forces or energy_eigenvalues.
|
---|
34 | *
|
---|
35 | */
|
---|
36 | typedef boost::fusion::map<
|
---|
37 | boost::fusion::pair<MPQCDataFused::energy_total, double>
|
---|
38 | , boost::fusion::pair<MPQCDataFused::energy_nuclear_repulsion, double>
|
---|
39 | , boost::fusion::pair<MPQCDataFused::energy_electron_coulomb, double>
|
---|
40 | , boost::fusion::pair<MPQCDataFused::energy_electron_exchange, double>
|
---|
41 | , boost::fusion::pair<MPQCDataFused::energy_correlation, double>
|
---|
42 | , boost::fusion::pair<MPQCDataFused::energy_overlap, double>
|
---|
43 | , boost::fusion::pair<MPQCDataFused::energy_kinetic, double>
|
---|
44 | , boost::fusion::pair<MPQCDataFused::energy_hcore, double>
|
---|
45 | , boost::fusion::pair<MPQCDataFused::energy_eigenvalues, Histogram >
|
---|
46 | > MPQCDataEnergyMap_t;
|
---|
47 |
|
---|
48 | typedef boost::mpl::list<
|
---|
49 | MPQCDataFused::energy_total,
|
---|
50 | MPQCDataFused::energy_nuclear_repulsion,
|
---|
51 | MPQCDataFused::energy_electron_coulomb,
|
---|
52 | MPQCDataFused::energy_electron_exchange,
|
---|
53 | MPQCDataFused::energy_correlation,
|
---|
54 | MPQCDataFused::energy_overlap,
|
---|
55 | MPQCDataFused::energy_kinetic,
|
---|
56 | MPQCDataFused::energy_hcore,
|
---|
57 | MPQCDataFused::energy_eigenvalues
|
---|
58 | > MPQCDataEnergyVector_t;
|
---|
59 |
|
---|
60 | /** This boost::fusion map defines key-value or rather key-type pairs with
|
---|
61 | * which we associate all forces data members in MPQCData and their type.
|
---|
62 | *
|
---|
63 | * This lets us resolves any ambiguitites of types in MPQCData, e.g.
|
---|
64 | * to know vector<double> is forces or energy_eigenvalues.
|
---|
65 | *
|
---|
66 | */
|
---|
67 | typedef boost::fusion::map<
|
---|
68 | boost::fusion::pair<MPQCDataFused::forces, IndexedVectors >
|
---|
69 | > MPQCDataForceMap_t;
|
---|
70 |
|
---|
71 | typedef boost::mpl::list<
|
---|
72 | MPQCDataFused::forces
|
---|
73 | > MPQCDataForceVector_t;
|
---|
74 |
|
---|
75 | /** This boost::fusion map defines key-value or rather key-type pairs with
|
---|
76 | * which we associate all sampled_grid data members in MPQCData and their type.
|
---|
77 | *
|
---|
78 | * This lets us resolves any ambiguitites of types in MPQCData, e.g.
|
---|
79 | * to know vector<double> is forces or energy_eigenvalues.
|
---|
80 | *
|
---|
81 | */
|
---|
82 | typedef boost::fusion::map<
|
---|
83 | boost::fusion::pair<MPQCDataFused::sampled_grid, SamplingGrid >
|
---|
84 | > MPQCDataGridMap_t;
|
---|
85 |
|
---|
86 | typedef boost::mpl::list<
|
---|
87 | MPQCDataFused::sampled_grid
|
---|
88 | > MPQCDataGridVector_t;
|
---|
89 |
|
---|
90 | /** This boost::fusion map defines key-value or rather key-type pairs with
|
---|
91 | * which we associate all sampled_grid data members in MPQCData and their type.
|
---|
92 | *
|
---|
93 | * This lets us resolves any ambiguitites of types in MPQCData, e.g.
|
---|
94 | * to know vector<double> is forces or energy_eigenvalues.
|
---|
95 | *
|
---|
96 | */
|
---|
97 | typedef boost::fusion::map<
|
---|
98 | boost::fusion::pair<MPQCDataFused::fragment, Fragment >
|
---|
99 | > MPQCDataFragmentMap_t;
|
---|
100 |
|
---|
101 | typedef boost::mpl::list<
|
---|
102 | MPQCDataFused::fragment
|
---|
103 | > MPQCDataFragmentVector_t;
|
---|
104 |
|
---|
105 | /** This boost::fusion map defines key-value or rather key-type pairs with
|
---|
106 | * which we associate all times_t data members in MPQCData and their type.
|
---|
107 | *
|
---|
108 | * This lets us resolves any ambiguitites of types in MPQCData, e.g.
|
---|
109 | * to know vector<double> is forces or energy_eigenvalues.
|
---|
110 | *
|
---|
111 | */
|
---|
112 | typedef boost::fusion::map<
|
---|
113 | boost::fusion::pair<MPQCDataFused::times_total_walltime, double >
|
---|
114 | , boost::fusion::pair<MPQCDataFused::times_total_cputime, double >
|
---|
115 | , boost::fusion::pair<MPQCDataFused::times_total_flops, double >
|
---|
116 | , boost::fusion::pair<MPQCDataFused::times_gather_walltime, double >
|
---|
117 | , boost::fusion::pair<MPQCDataFused::times_gather_cputime, double >
|
---|
118 | , boost::fusion::pair<MPQCDataFused::times_gather_flops, double >
|
---|
119 | > MPQCDataTimeMap_t;
|
---|
120 |
|
---|
121 | typedef boost::mpl::list<
|
---|
122 | MPQCDataFused::times_total_walltime,
|
---|
123 | MPQCDataFused::times_total_cputime,
|
---|
124 | MPQCDataFused::times_total_flops,
|
---|
125 | MPQCDataFused::times_gather_walltime,
|
---|
126 | MPQCDataFused::times_gather_cputime,
|
---|
127 | MPQCDataFused::times_gather_flops
|
---|
128 | > MPQCDataTimeVector_t;
|
---|
129 |
|
---|
130 | #endif /* MPQCDATAMAP_HPP_ */
|
---|