/* * Thermostat.hpp * * Created on: Aug 18, 2010 * Author: crueger */ #ifndef THERMOSTAT_HPP_ #define THERMOSTAT_HPP_ class config; #include #include #include #include #include "AtomSet.hpp" class ThermoStatContainer; class Thermostat { public: Thermostat(); virtual ~Thermostat(); // cannot template this, because we need virtual functions virtual double scaleAtoms(unsigned int step,double ActualTemp,ATOMSET(std::list) atoms)=0; virtual double scaleAtoms(unsigned int step,double ActualTemp,ATOMSET(std::vector) atoms)=0; virtual double scaleAtoms(unsigned int step,double ActualTemp,ATOMSET(std::set) atoms)=0; virtual std::string name()=0; virtual std::string writeParams()=0; protected: void addToContainer(ThermoStatContainer &); ThermoStatContainer &getContainer(); private: ThermoStatContainer* container; }; template struct ThermostatTraits; template <> struct ThermostatTraits{ ThermostatTraits(); virtual Thermostat *make(class ConfigFileBuffer * const fb)=0; const char* name; }; #endif /* THERMOSTAT_HPP_ */