1#ifndef RPC_FOURTH_ORDER_PARAMETER_H
2#define RPC_FOURTH_ORDER_PARAMETER_H
11#include "AverageAnalyzer.h"
13#include <util/containers/DArray.h>
14#include <util/accumulators/Average.h>
15#include <prdc/cpu/RFieldDft.h>
24 template <
int D>
class System;
25 template <
int D>
class Simulator;
124 double FourthOrderParameter_;
128 #ifndef RPC_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.
Analyze averages and block averages of several real variables.
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.
virtual void output()
Write final results to file after a simulation.
System< D > & system()
Return reference to parent system.
virtual void readParameters(std::istream &in)
Read interval, outputFileName and (optionally) nSamplePerOutput.
FourthOrderParameter is used to detect an order-disorder transition.
FourthOrderParameter(Simulator< D > &simulator, System< D > &system)
Constructor.
void computePrefactor()
Compute prefactor for each Fourier wavevector.
virtual void setup()
Setup before simulation loop.
virtual ~FourthOrderParameter()
Destructor.
virtual void outputValue(int step, double value)
Output a sampled or block average value.
virtual double compute()
Compute and return the derivative of H w/ respect to chi.
Field theoretic simulator (base class).
Main class for SCFT or PS-FTS simulation of one system.
Dynamically allocatable contiguous array template.
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.