00001 /*************************************************************************************************** 00002 ***** Copyright (C) 2005 John Schneiderman <JohnMS@member.fsf.org> ***** 00003 ***** ***** 00004 ***** This program is free software; you can redistribute it and/or modify ***** 00005 ***** it under the terms of the GNU General Public License as published by ***** 00006 ***** the Free Software Foundation; either version 2 of the License, or ***** 00007 ***** (at your option) any later version. ***** 00008 ***** ***** 00009 ***** This program is distributed in the hope that it will be useful, ***** 00010 ***** but WITHOUT ANY WARRANTY; without even the implied warranty of ***** 00011 ***** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ***** 00012 ***** GNU General Public License for more details. ***** 00013 ***** ***** 00014 ***** You should have received a copy of the GNU General Public License ***** 00015 ***** along with this program; if not, write to the Free Software ***** 00016 ***** Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA ***** 00017 ***************************************************************************************************/ 00018 #ifndef MCSIMULATION_H 00019 #define MCSIMULATION_H 00020 #include "basesimulation.h" 00021 00022 #include <fstream> 00023 using std::ostream; 00024 using std::endl; 00025 00026 class ConfigurationDatabase; 00027 00033 class MC_Simulation: public BaseSimulation 00034 { 00035 public: 00040 MC_Simulation(const ConfigurationDatabase &conf); 00045 double temperature() const; 00050 void setTemperature(double temperature); 00051 00052 protected: 00056 double m_temperature; 00060 double m_accumPotentialTotal; 00064 double m_accumPotentialSQ; 00065 00071 void writeAverages(ostream &out, const Cluster &cluster); 00072 }; 00073 #endif