/* * MPQCJob.hpp * * Created on: Feb 05, 2012 * Author: heber */ #ifndef MPQCCOMMANDJOB_HPP_ #define MPQCCOMMANDJOB_HPP_ // include config.h #ifdef HAVE_CONFIG_H #include #endif #include #include #ifdef HAVE_JOBMARKET #include "JobMarket/Results/FragmentResult.hpp" #include "JobMarket/Jobs/SystemCommandJob.hpp" #else #include "Jobs/JobMarket/FragmentResult.hpp" #include "Jobs/JobMarket/SystemCommandJob.hpp" #endif #include "Fragmentation/Summation/Containers/MPQCData.hpp" class MPQCCommandJobTest; class MPQCCommandFragmentController; /** This class calls mpqc for solving a specific Hartree Fock problem. * */ class MPQCCommandJob : public SystemCommandJob { //!> grant unit test access friend class MPQCCommandJobTest; //!> grant access to controller friend class MPQCCommandFragmentController; public: MPQCCommandJob(const std::string &_inputfile, const JobId_t _JobId, const std::string &_command = std::string("mpqc")); ~MPQCCommandJob(); bool operator==(const MPQCCommandJob &other) const; bool operator!=(const MPQCCommandJob &other) const { return !(*this == other); } private: //!> Allow controller access to changing the commands void setCommand(const std::string &_command) { command = _command; } //!> Allow controller access to changing the suffix void setSuffix(const std::string &_suffix) { suffix = _suffix; } //!> private default cstor only for serializatio MPQCCommandJob(); friend class boost::serialization::access; // serialization template void serialize(Archive& ar, const unsigned int version) { ar & boost::serialization::base_object(*this); ar & data; } private: //!> class that contains energy and forces and serialization capabilities MPQCData data; FragmentResult::ptr extractResult(const std::string &resultstring); static const std::string keyword_hartreefock_energy; static const std::string keyword_hartreefock_forces; static const std::string keyword_moellerplesset_energy; static const std::string keyword_moellerplesset_forces; }; // we need to give this class a unique key for serialization // its is only serialized through its base class FragmentJob BOOST_CLASS_EXPORT_KEY(MPQCCommandJob) #endif /* MPQCCOMMANDJOB_HPP_ */