1#ifndef RPC_BINARY_STRUCTURE_FACTOR_GRID_H
2#define RPC_BINARY_STRUCTURE_FACTOR_GRID_H
13#include <util/containers/DArray.h>
14#include <util/accumulators/Average.h>
15#include <prdc/cpu/RField.h>
16#include <prdc/cpu/RFieldDft.h>
26 template <
int D>
class System;
27 template <
int D>
class Simulator;
186 int nSamplePerBlock_;
207 std::vector<double> qList_;
210 std::map<double, double> averageSMap_;
217 {
return *systemPtr_; }
222 {
return *simulatorPtr_; }
224 #ifndef RPC_BINARY_STRUCTURE_FACTOR_GRID_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.
Abstract base for periodic output and/or analysis actions.
bool isAtInterval(long counter) const
Return true iff counter is a multiple of the interval.
void readInterval(std::istream &in)
Optionally read interval from file, with error checking.
const std::string & outputFileName() const
Return outputFileName string.
int interval() const
Get interval value.
void readOutputFileName(std::istream &in)
Read outputFileName from file.
BinaryStructureFactorGrid evaluates AB copolymer structure factors.
void setup()
Clear accumulators.
void setClassName(const char *className)
Set class name string.
System< D > & system()
Return reference to parent system.
void readParameters(std::istream &in)
Read parameters from file.
BinaryStructureFactorGrid(Simulator< D > &simulator, System< D > &system)
Constructor.
DArray< double > structureFactors_
Structure factor.
std::string filename_
Output filename.
Simulator< D > & simulator()
Return reference to parent Simulator.
System< D > * systemPtr_
Pointer to the parent system.
const Average & accumulator(int i) const
Get Average accumulator for a specific value.
std::ofstream outputFile_
Output file stream.
void sample(long iStep)
Add particles to BinaryStructureFactor accumulators.
void averageStructureFactor()
Compute average S(k) over k of equal magnitude.
int nWave_
Number of wavevectors.
~BinaryStructureFactorGrid()
Destructor.
void computeStructureFactor()
Compute structure factor.
Simulator< D > * simulatorPtr_
Pointer to parent Simulator.
void output()
Output results to predefined output file.
Field theoretic simulator (base class).
Main class for SCFT or PS-FTS simulation of one system.
Calculates the average and variance of a sampled property.
Loading (input) archive for binary istream.
Saving / output archive for binary ostream.
Dynamically allocatable contiguous array template.
DArrayParam< Type > & readDArray(std::istream &in, const char *label, DArray< Type > &array, int n)
Add and read a required DArray < Type > parameter.
void setClassName(const char *className)
Set class name string.
virtual void save(Serializable::OArchive &ar)
Saves all parameters to an archive.
ScalarParam< Type > & readOptional(std::istream &in, const char *label, Type &value)
Add and read a new optional ScalarParam < Type > object.
virtual void loadParameters(Serializable::IArchive &ar)
Load state from archive, without adding Begin and End lines.
Fields and FFTs for periodic boundary conditions (CPU)
PSCF package top-level namespace.
Utility classes for scientific computation.