source: src/ThermoStatContainer.cpp@ 1fb318

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults AddingActions_SaveParseParticleParameters Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_ParticleName_to_Atom Adding_StructOpt_integration_tests AtomFragments Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator CombiningParticlePotentialParsing Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_BoundInBox_CenterInBox_MoleculeActions Fix_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_PopActions Fix_QtFragmentList_sorted_selection Fix_Restrictedkeyset_FragmentMolecule Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns Fix_fitting_potentials Fixes ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion FragmentAction_writes_AtomFragments FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity ImplicitCharges IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix MoreRobust_FragmentAutomation ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PdbParser_setsAtomName PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks Rewrite_FitPartialCharges RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching SaturateAtoms_singleDegree StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg Switchable_LogView ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps TremoloParser_setsAtomName Ubuntu_1604_changes stable
Last change on this file since 1fb318 was 51c3e4, checked in by Tillmann Crueger <crueger@…>, 15 years ago

Merge branch 'stable' into StructureRefactoring

Conflicts:

src/atom_trajectoryparticle.cpp

  • Property mode set to 100644
File size: 3.3 KB
Line 
1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2010 University of Bonn. All rights reserved.
5 * Please see the LICENSE file or "Copyright notice" in builder.cpp for details.
6 */
7
8/*
9 * ThermoStatContainer.cpp
10 *
11 * Created on: 12.06.2010
12 * Author: heber
13 */
14
15// include config.h
16#ifdef HAVE_CONFIG_H
17#include <config.h>
18#endif
19
20#include "Helpers/MemDebug.hpp"
21
22#include <cstring>
23
24#include "ConfigFileBuffer.hpp"
25#include "config.hpp"
26#include "Helpers/Log.hpp"
27#include "ThermoStatContainer.hpp"
28#include "Helpers/Verbose.hpp"
29
30#include <Thermostats/Berendsen.hpp>
31#include <Thermostats/GaussianThermostat.hpp>
32#include <Thermostats/Langevin.hpp>
33#include <Thermostats/NoseHoover.hpp>
34#include <Thermostats/NoThermostat.hpp>
35#include <Thermostats/Woodcock.hpp>
36
37/** Constructor for class ThermoStatContainer.
38 *
39 */
40ThermoStatContainer::ThermoStatContainer() :
41 activeThermostat(0),
42 TargetTemp(0.00095004455)
43{
44 ThermostatTraits<Thermostat> *BerendsenTrait = new ThermostatTraits<Berendsen>();
45 availThermostats[BerendsenTrait->getName()] = BerendsenTrait;
46 ThermostatTraits<Thermostat> *GaussianTrait = new ThermostatTraits<GaussianThermostat>();
47 availThermostats[GaussianTrait->getName()] = GaussianTrait;
48 ThermostatTraits<Thermostat> *LangevinTrait = new ThermostatTraits<Langevin>();
49 availThermostats[LangevinTrait->getName()] = LangevinTrait;
50 ThermostatTraits<Thermostat> *NoseHooverTrait = new ThermostatTraits<NoseHoover>();
51 availThermostats[NoseHooverTrait->getName()] = NoseHooverTrait;
52 ThermostatTraits<Thermostat> *NoThermostatTrait = new ThermostatTraits<NoThermostat>();
53 availThermostats[NoThermostatTrait->getName()] = NoThermostatTrait;
54 ThermostatTraits<Thermostat> *WoodcockTrait = new ThermostatTraits<Woodcock>();
55 availThermostats[WoodcockTrait->getName()] = WoodcockTrait;
56 for(traitsMap::iterator iter = availThermostats.begin();iter!=availThermostats.end();++iter){
57 cout << iter->first << endl;
58 }
59 ASSERT(availThermostats.size()==6,"Not all implemented thermostats referenced!\nDid you check the names in the traits?");
60 activeThermostat=new Berendsen();
61}
62
63ThermostatTraits<Thermostat> *ThermoStatContainer::getTraitByName(const std::string name){
64 if(!availThermostats.count(name))
65 return 0;
66 return availThermostats[name];
67}
68
69Thermostat *ThermoStatContainer::makeByName(const std::string name,class ConfigFileBuffer * const fb){
70 ThermostatTraits<Thermostat>* trait = getTraitByName(name);
71 if(trait){
72 Thermostat *res = trait->make(fb);
73 res->addToContainer(this);
74 return res;
75 }
76 else{
77 return 0;
78 }
79}
80
81void ThermoStatContainer::makeActive(const std::string name,class ConfigFileBuffer * const fb){
82 Thermostat* newThermostat = makeByName(name,fb);
83 if(newThermostat){
84 if(activeThermostat){
85 delete activeThermostat;
86 }
87 activeThermostat = newThermostat;
88 }
89}
90
91void ThermoStatContainer::chooseNone(){
92 if(activeThermostat){
93 delete activeThermostat;
94 }
95 activeThermostat = new NoThermostat();
96}
97
98/** Destructor for Class ThermoStatContainer.
99 *
100 */
101ThermoStatContainer::~ThermoStatContainer()
102{
103 if(activeThermostat){
104 delete activeThermostat;
105 }
106 for(traitsMap::iterator iter= availThermostats.begin();iter!=availThermostats.end();++iter){
107 delete (iter->second);
108 }
109}
110
111
Note: See TracBrowser for help on using the repository browser.