source: src/Jobs/MPQCJob.hpp

Candidate_v1.6.1
Last change on this file was ec1aae, checked in by Frederik Heber <heber@…>, 8 years ago

FIX: MPQCData now correctly checks sampled_grid to be cubic.

  • Property mode set to 100644
File size: 1.8 KB
RevLine 
[28e894]1/*
2 * MPQCJob.hpp
3 *
4 * Created on: Jul 10, 2012
5 * Author: heber
6 */
7
8#ifndef MPQCJOB_HPP_
9#define MPQCJOB_HPP_
10
11
12// include config.h
13#ifdef HAVE_CONFIG_H
14#include <config.h>
15#endif
16
17#include "boost/serialization/export.hpp"
18
[1dfe00]19#ifdef HAVE_JOBMARKET
[28e894]20#include "JobMarket/Jobs/FragmentJob.hpp"
[1dfe00]21#else
22#include "Jobs/JobMarket/FragmentJob.hpp"
23#endif
[28e894]24
[fbf143]25#include "Fragmentation/Summation/SetValues/SamplingGridProperties.hpp"
26#include "Fragmentation/Summation/Containers/MPQCData.hpp"
[28c025]27
[28e894]28#include <string>
29
30/** This class encapsulates a MPQC Job.
31 *
32 */
33class MPQCJob : public FragmentJob
34{
35public:
[d12d621]36 MPQCJob(
37 const JobId_t _JobId,
38 const std::string &_inputfile,
[ec1aae]39 const double _begin[NDIM],
40 const double _end[NDIM],
[d12d621]41 const int _level);
[a9558f]42 virtual ~MPQCJob();
[28e894]43
44 FragmentResult::ptr Work();
45
[503acc1]46 //!> whether to actually sample the density
47 MPQCData::DoLongrange_t DoLongrange;
48
[6ff62c]49 //!> whether to sample just the valence or the total electron and nuclei density
50 MPQCData::DoValenceOnly_t DoValenceOnly;
51
[28e894]52private:
[28c025]53 //!> contents of inputfile
[28e894]54 const std::string inputfile;
[28c025]55 //!> information for how to sample the density
56 const SamplingGridProperties grid;
[28e894]57
58private:
59 /** private default cstor for serialization only
60 */
[a9558f]61 MPQCJob();
[28e894]62
63 friend class boost::serialization::access;
64 // serialization
65 template <typename Archive>
66 void serialize(Archive& ar, const unsigned int version)
67 {
68 ar & boost::serialization::base_object<FragmentJob>(*this);
[503acc1]69 ar & DoLongrange;
[6ff62c]70 ar & DoValenceOnly;
[28e894]71 ar & const_cast<std::string &>(inputfile);
[28c025]72 ar & const_cast<SamplingGridProperties &>(grid);
[28e894]73 }
74};
75
76// we need to give this class a unique key for serialization
77// its is only serialized through its base class FragmentJob
78BOOST_CLASS_EXPORT_KEY(MPQCJob)
79
80#endif /* MPQCJOB_HPP_ */
Note: See TracBrowser for help on using the repository browser.