1#ifndef RPC_MC_MOVE_MANAGER_H
2#define RPC_MC_MOVE_MANAGER_H
12#include <util/param/Manager.h>
13#include <util/containers/DArray.h>
15namespace Util {
class Random; }
22 template <
int D>
class System;
23 template <
int D>
class McSimulator;
152 return probabilities_[i];
155 #ifndef RPC_MC_MOVE_MANAGER_TPP
Manager for a set of McMove objects.
void setup()
Initialize at beginning of system run.
McMoveManager(McSimulator< D > &simulator, System< D > &system)
Constructor.
bool needsCc()
Decide whether any move needs to store cc fields.
void outputTimers(std::ostream &out) const
Log output timing results.
~McMoveManager()
Destructor.
McMove< D > & chooseMove()
Choose an McMove at random, using specified probabilities.
void output() const
Output statistics for all moves.
virtual void readParameters(std::istream &in)
Read instructions for creating McMove objects.
bool needsDc()
Decide whether any move needs to store dc fields.
void clearTimers()
Clear timers.
double probability(int i) const
Return probability of move i.
McMove is an abstract base class for Monte Carlo moves.
Monte-Carlo simulation coordinator.
Main class for SCFT or PS-FTS simulation of one system.
Dynamically allocatable contiguous array template.
Template container for pointers to objects with a common base class.
void setClassName(const char *className)
Set class name string.
PSCF package top-level namespace.
Utility classes for scientific computation.