1#ifndef RPC_FORCE_BIAS_MOVE_H
2#define RPC_FORCE_BIAS_MOVE_H
12#include <prdc/cpu/RField.h>
13#include <util/containers/DArray.h>
108 using McMove<D>::compressorTimer_;
109 using McMove<D>::componentTimer_;
110 using McMove<D>::hamiltonianTimer_;
111 using McMove<D>::decisionTimer_;
112 using McMove<D>::totalTimer_;
139 #ifndef RPC_FORCE_BIAS_MOVE_TPP
ForceBiasMove attempts a Brownian dynamics move.
ForceBiasMove(McSimulator< D > &simulator)
Constructor.
void readParameters(std::istream &in)
Read required parameters from file.
bool move()
Attempt and accept or reject force bias Monte-Carlo move.
bool needsDc()
Decide whether dc fields need to be saved for move.
void outputTimers(std::ostream &out)
Return real move times contributions.
~ForceBiasMove()
Destructor.
void setup()
Setup before the beginning of each simulation run.
void output()
Output statistics for this move (at the end of simulation)
McMove is an abstract base class for Monte Carlo moves.
void incrementNAccept()
Increment the number of accepted moves.
virtual void clearTimers()
Clear timers.
Timer attemptMoveTimer_
Timers for McMove.
Random & random()
Get Random number generator of parent System.
System< D > & system()
Get parent System object.
McSimulator< D > & simulator()
Get parent McSimulator object.
void incrementNAttempt()
Increment the number of attempted moves.
void readProbability(std::istream &in)
Read the probability from file.
void incrementNFail()
Increment the number of failed moves.
Monte-Carlo simulation coordinator.
Dynamically allocatable contiguous array template.
ScalarParam< Type > & read(std::istream &in, const char *label, Type &value)
Add and read a new required ScalarParam < Type > object.
void setClassName(const char *className)
Set class name string.
Fields and FFTs for periodic boundary conditions (CPU)
PSCF package top-level namespace.
Utility classes for scientific computation.