source: src/Fragmentation/Summation/Containers/MPQCDataMap.hpp@ db0833

ForceAnnealing_goodresults ForceAnnealing_tocheck
Last change on this file since db0833 was 5c867e, checked in by Frederik Heber <heber@…>, 13 years ago

Added new SetValue Eigenvalues to just add up the set of eigenvalues.

  • Property mode set to 100644
File size: 4.4 KB
RevLine 
[56df37]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>
[8cae4c]17#include <boost/mpl/list.hpp>
[56df37]18
[fbf143]19#include "Fragmentation/Summation/Containers/MPQCDataFused.hpp"
[56df37]20
[5c867e]21class Eigenvalues;
[184943]22class Fragment;
[8cae4c]23class Histogram;
[e13990b]24class IndexedVectors;
[c37c20]25class SamplingGrid;
[8cae4c]26
27/// \note: We had to split up the map because boost::fusion only allows for
28/// up to 9 template types.
29
[56df37]30/** This boost::fusion map defines key-value or rather key-type pairs with
[8cae4c]31 * which we associate all energy_t data members in MPQCData and their type.
[56df37]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 */
37typedef boost::fusion::map<
38 boost::fusion::pair<MPQCDataFused::energy_total, double>
[8cae4c]39 , boost::fusion::pair<MPQCDataFused::energy_nuclear_repulsion, double>
[adccae]40 , boost::fusion::pair<MPQCDataFused::energy_electron_coulomb, double>
41 , boost::fusion::pair<MPQCDataFused::energy_electron_exchange, double>
[8cae4c]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>
[5c867e]46 , boost::fusion::pair<MPQCDataFused::energy_eigenvalues, Eigenvalues >
47 , boost::fusion::pair<MPQCDataFused::energy_eigenhistogram, Histogram >
[8cae4c]48> MPQCDataEnergyMap_t;
49
50typedef boost::mpl::list<
51 MPQCDataFused::energy_total,
52 MPQCDataFused::energy_nuclear_repulsion,
[adccae]53 MPQCDataFused::energy_electron_coulomb,
54 MPQCDataFused::energy_electron_exchange,
[8cae4c]55 MPQCDataFused::energy_correlation,
56 MPQCDataFused::energy_overlap,
57 MPQCDataFused::energy_kinetic,
[dde8ec]58 MPQCDataFused::energy_hcore,
[5c867e]59 MPQCDataFused::energy_eigenvalues,
60 MPQCDataFused::energy_eigenhistogram
[8cae4c]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 */
70typedef boost::fusion::map<
[e13990b]71 boost::fusion::pair<MPQCDataFused::forces, IndexedVectors >
[8cae4c]72> MPQCDataForceMap_t;
73
74typedef boost::mpl::list<
75 MPQCDataFused::forces
76> MPQCDataForceVector_t;
77
[c37c20]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 */
85typedef boost::fusion::map<
86 boost::fusion::pair<MPQCDataFused::sampled_grid, SamplingGrid >
87> MPQCDataGridMap_t;
88
89typedef boost::mpl::list<
90 MPQCDataFused::sampled_grid
91> MPQCDataGridVector_t;
92
[184943]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 */
100typedef boost::fusion::map<
101 boost::fusion::pair<MPQCDataFused::fragment, Fragment >
102> MPQCDataFragmentMap_t;
103
104typedef boost::mpl::list<
105 MPQCDataFused::fragment
106> MPQCDataFragmentVector_t;
107
[8cae4c]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 */
115typedef boost::fusion::map<
[4aee30]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 >
[8cae4c]122> MPQCDataTimeMap_t;
123
124typedef boost::mpl::list<
[4aee30]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
[8cae4c]131> MPQCDataTimeVector_t;
[56df37]132
133#endif /* MPQCDATAMAP_HPP_ */
Note: See TracBrowser for help on using the repository browser.