1#ifndef RPG_FOURIER_MOVE_H
2#define RPG_FOURIER_MOVE_H
12#include <prdc/cuda/RFieldDft.h>
13#include <prdc/cuda/RField.h>
14#include <util/containers/DArray.h>
103 void computeRgSquare();
112 double computeF(
double x);
122 double computeDebye(
double f,
double x);
131 double computeS(
double qSquare);
136 void computeStructureFactor();
198 #ifndef RPG_FOURIER_MOVE_TPP
Field of real double precision values on an FFT mesh.
FourierMove is a Monte Carlo move in fourier space.
FourierMove(McSimulator< D > &simulator)
Constructor.
void attemptMove()
Attempt unconstrained move.
void setup()
Setup before the beginning of each simulation run.
void output()
Output statistics for this move (at the end of simulation)
~FourierMove()
Destructor.
void outputTimers(std::ostream &out)
Return fourier move times contributions.
void readParameters(std::istream &in)
Read required parameters from file.
McMove is an abstract base class for Monte Carlo moves.
CudaRandom & cudaRandom()
Get cuda random number generator by reference.
Random & random()
Get Random number generator of parent System.
virtual bool move()
Generate, attempt, and accept or reject a Monte Carlo move.
void readProbability(std::istream &in)
Read the probability from file.
McSimulator< D > & simulator()
Get parent McSimulator object.
System< D > & system()
Get parent System object.
virtual void clearTimers()
Clear timers.
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, FFTs, and utilities for periodic boundary conditions (CUDA)
Periodic fields and crystallography.
PSCF package top-level namespace.
Utility classes for scientific computation.