Candidate_v1.7.0
        stable
      
      
        
          | 
            Last change
 on this file since 1ca493a was             6625c3, checked in by Frederik Heber <heber@…>, 15 years ago           | 
        
        
          | 
             
Removed atom_trajectoryparticle*, replaced by AtomInfo class now having std::vector<> for trajectories. 
 
AtomInfo: 
 
Other changes: 
 
- gsl_rng_gaussian() exchanged by boost::random specific type.
  
           | 
        
        
          
            
              - 
Property                 mode
 set to                 
100644
               
             
           | 
        
        
          | 
            File size:
            1.3 KB
           | 
        
      
      
| Rev | Line |   | 
|---|
| [194649] | 1 | /*
 | 
|---|
 | 2 |  * Langevin.hpp
 | 
|---|
 | 3 |  *
 | 
|---|
 | 4 |  *  Created on: Aug 20, 2010
 | 
|---|
 | 5 |  *      Author: crueger
 | 
|---|
 | 6 |  */
 | 
|---|
 | 7 | 
 | 
|---|
 | 8 | #ifndef LANGEVIN_HPP_
 | 
|---|
 | 9 | #define LANGEVIN_HPP_
 | 
|---|
 | 10 | 
 | 
|---|
| [56f73b] | 11 | // include config.h
 | 
|---|
 | 12 | #ifdef HAVE_CONFIG_H
 | 
|---|
 | 13 | #include <config.h>
 | 
|---|
 | 14 | #endif
 | 
|---|
 | 15 | 
 | 
|---|
| [194649] | 16 | #include "Thermostats/Thermostat.hpp"
 | 
|---|
 | 17 | 
 | 
|---|
| [6625c3] | 18 | #include <boost/random/mersenne_twister.hpp>
 | 
|---|
 | 19 | #include <boost/random/normal_distribution.hpp>
 | 
|---|
 | 20 | 
 | 
|---|
| [194649] | 21 | class Langevin : public Thermostat
 | 
|---|
 | 22 | {
 | 
|---|
 | 23 | public:
 | 
|---|
| [c0c650] | 24 |   Langevin(double,double);
 | 
|---|
| [3e4162] | 25 |   Langevin();
 | 
|---|
| [194649] | 26 |   virtual ~Langevin();
 | 
|---|
 | 27 | 
 | 
|---|
| [579a81] | 28 |   virtual double scaleAtoms(unsigned int step,double ActualTemp,ATOMSET(std::list) atoms);
 | 
|---|
 | 29 |   virtual double scaleAtoms(unsigned int step,double ActualTemp,ATOMSET(std::vector) atoms);
 | 
|---|
 | 30 |   virtual double scaleAtoms(unsigned int step,double ActualTemp,ATOMSET(std::set) atoms);
 | 
|---|
| [194649] | 31 | 
 | 
|---|
| [579a81] | 32 |   virtual std::string name();
 | 
|---|
 | 33 |   virtual std::string writeParams();
 | 
|---|
| [194649] | 34 | 
 | 
|---|
 | 35 | private:
 | 
|---|
 | 36 |   template <class ForwardIterator>
 | 
|---|
| [579a81] | 37 |   double doScaleAtoms(unsigned int step,double ActualTemp,ForwardIterator begin, ForwardIterator end);
 | 
|---|
| [194649] | 38 | 
 | 
|---|
| [579a81] | 39 | 
 | 
|---|
 | 40 |   double TempFrequency;
 | 
|---|
 | 41 |   double alpha;
 | 
|---|
| [6625c3] | 42 | 
 | 
|---|
 | 43 |   boost::mt19937 *rng_engine;
 | 
|---|
 | 44 |   boost::normal_distribution<> *rng_distribution;
 | 
|---|
| [194649] | 45 | };
 | 
|---|
 | 46 | 
 | 
|---|
| [579a81] | 47 | template <>
 | 
|---|
| [0b882a] | 48 | struct ThermostatTraits<class Langevin> : public ThermostatTraits<Thermostat>
 | 
|---|
 | 49 | {
 | 
|---|
| [c0c650] | 50 |   virtual Thermostat *make(class ConfigFileBuffer * const fb);
 | 
|---|
| [14c57a] | 51 |   virtual std::string getName();
 | 
|---|
 | 52 |   static const char* name;
 | 
|---|
| [579a81] | 53 | };
 | 
|---|
 | 54 | 
 | 
|---|
| [194649] | 55 | #endif /* LANGEVIN_HPP_ */
 | 
|---|
       
      
  Note:
 See   
TracBrowser
 for help on using the repository browser.