1#ifndef RPG_FOURTH_ORDER_PARAMETER_H
2#define RPG_FOURTH_ORDER_PARAMETER_H
11#include "AverageAnalyzer.h"
13#include <util/containers/DArray.h>
14#include <util/accumulators/Average.h>
15#include <prdc/cuda/RField.h>
16#include <prdc/cuda/RFieldDft.h>
25 template <
int D>
class System;
26 template <
int D>
class Simulator;
127 double FourthOrderParameter_;
131 #ifndef RPG_FOURTH_ORDER_PARAMETER_TPP
An IntVec<D, T> is a D-component vector of elements of integer type T.
Fourier transform of a real field on an FFT mesh.
Field of real double precision values on an FFT mesh.
Analyze averages and block averages of several real variables.
virtual void readParameters(std::istream &in)
Read interval, outputFileName and (optionally) nSamplePerOutput.
virtual void sample(long iStep)
Compute a sampled value and update the accumulator.
int nSamplePerOutput() const
Get value of nSamplePerOutput.
Simulator< D > & simulator()
Return reference to parent simulator.
System< D > & system()
Return reference to parent system.
virtual void output()
Write final results to file after a simulation.
FourthOrderParameter is used to detect an order-disorder transition.
virtual ~FourthOrderParameter()
Destructor.
virtual double compute()
Compute and return the fourth order parameter.
FourthOrderParameter(Simulator< D > &simulator, System< D > &system)
Constructor.
virtual void outputValue(int step, double value)
Output a sampled or block average value.
virtual void setup()
Setup before simulation loop.
void computePrefactor()
Compute prefactor for each Fourier wavevector.
Field theoretic simulator (base class).
Main class for calculations that represent one system.
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.