source: src/Fragmentation/Automation/MPQCCommandFragmentController.hpp@ 3da643

Last change on this file since 3da643 was d6a7b9, checked in by Frederik Heber <heber@…>, 11 years ago

Specifying executable and suffix in SystemCommandJob with MPQCCommandFragmentController.

  • Property mode set to 100644
File size: 2.6 KB
Line 
1/*
2 * MPQCCommandFragmentController.hpp
3 *
4 * Created on: Apr 14, 2014
5 * Author: heber
6 */
7
8#ifndef MPQCCOMMANDFRAGMENTCONTROLLER_HPP_
9#define MPQCCOMMANDFRAGMENTCONTROLLER_HPP_
10
11
12// include config.h
13#ifdef HAVE_CONFIG_H
14#include <config.h>
15#endif
16
17#include <boost/filesystem/path.hpp>
18
19#include <list>
20#include <map>
21#include <string>
22#include <vector>
23
24#include "Fragmentation/Summation/Containers/MPQCData.hpp"
25#include "Fragmentation/Automation/ResultContainer.hpp"
26
27/** This class mimics the interface of SpecificFragmentController derived from
28 * JobMarket's FragmentController but without using JobMarket.
29 *
30 * This is for calculating fragments via MPQCCommandJobs when JobMarket is not
31 * available.
32 */
33class MPQCCommandFragmentController
34{
35public:
36 MPQCCommandFragmentController() :
37 exitflag(0)
38 {}
39 ~MPQCCommandFragmentController()
40 {}
41
42 /** Command Controller to fill its hold of jobs from FragmentJobQueue.
43 *
44 * \param _DoSampleDensity whether to actually sample the resulting electronic density
45 * \param _DoValenceOnly whether to sample just the valence or the total elctron and nuclei density
46 * \param _command command to pass to jobs for execution
47 * \return true - jobs obtained, false - queue empty
48 */
49 bool addJobsFromQueue(
50 const MPQCData::DoLongrange_t _DoLongrange,
51 const MPQCData::DoValenceOnly_t _DoValenceOnly,
52 const std::string &_command
53 );
54
55 /** Mimicks waitforResults but actually does nothing.
56 *
57 */
58 void waitforResults(const size_t NoExpectedResults)
59 { return; }
60
61 /** Get results map of calculated jobs.
62 *
63 * \param fragmentData contains map of results on output
64 */
65 void getResults(std::map<JobId_t, MPQCData> &fragmentData) {
66 fragmentData.insert(results.IdData.begin(), results.IdData.end());
67 results.clear();
68 }
69
70 /** Runs the service.
71 *
72 * Here, we finalize each job's id and push them to the server.
73 */
74 void run();
75
76 /** Mimicks a (unlimited) pool of requested ids that are served by this function.
77 *
78 * \return next unique job id to use
79 */
80 unsigned int getAvailableId()
81 {
82 return nextid++;
83 }
84
85 /** Getter for exitflag.
86 *
87 * \return exitflag
88 */
89 int getExitflag() const
90 { return exitflag; }
91
92private:
93 //!> static member variable to count individual job ids
94 static unsigned int nextid;
95
96 //!> overall exit flag of jobs
97 int exitflag;
98
99 //!> queue with all jobs to calculate serially
100 std::list<MPQCCommandJob *> queue;
101
102 //!> type-specific result container
103 ResultContainer<MPQCData> results;
104};
105
106
107#endif /* MPQCCOMMANDFRAGMENTCONTROLLER_HPP_ */
Note: See TracBrowser for help on using the repository browser.