1#ifndef RPG_MC_MOVE_MANAGER_H
2#define RPG_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 RPG_MC_MOVE_MANAGER_TPP
Manager for a set of McMove objects.
void output() const
Output statistics for all moves.
void setup()
Initialize at beginning of system run.
void outputTimers(std::ostream &out) const
Log output timing results.
virtual void readParameters(std::istream &in)
Read instructions for creating McMove objects.
double probability(int i) const
Return probability of move i.
void clearTimers()
Clear timers.
McMove< D > & chooseMove()
Choose an McMove at random, using specified probabilities.
bool needsDc()
Decide whether any move needs to store dc fields.
McMoveManager(McSimulator< D > &simulator, System< D > &system)
Constructor.
~McMoveManager()
Destructor.
bool needsCc()
Decide whether any move needs to store cc fields.
McMove is an abstract base class for Monte Carlo moves.
Monte-Carlo simulation coordinator.
Main class for calculations that represent 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.