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