11#include <util/param/ParamComposite.h>
13#include <rpg/solvers/WaveList.h>
14#include <rpg/field/FieldIo.h>
15#include <prdc/cuda/FFT.h>
17#include <prdc/crystal/Basis.h>
18#include <prdc/crystal/SpaceGroup.h>
19#include <prdc/crystal/UnitCell.h>
21#include <pscf/mesh/Mesh.h>
269 std::string groupName_;
293 {
return unitCell_; }
298 {
return unitCell_; }
338 {
return waveList_; }
343 {
return waveList_; }
364 {
return groupName_; }
369 {
return hasGroup_; }
374 {
return basis_.isInitialized(); }
376 #ifndef RPG_DOMAIN_TPP
Description of a regular grid of points in a periodic domain.
Symmetry-adapted Fourier basis for pseudo-spectral scft.
Fourier transform wrapper.
Crystallographic space group.
Base template for UnitCell<D> classes, D=1, 2 or 3.
Spatial domain and spatial discretization for a periodic structure.
UnitCell< D > & unitCell()
Get UnitCell by reference.
void makeBasis()
Construct basis if not done already.
UnitCell< D >::LatticeSystem lattice() const
Get the lattice system (enumeration value).
bool hasBasis() const
Has a symmetry-adapted Fourier basis been initialized?
SpaceGroup< D > const & group() const
Get the SpaceGroup object by const reference.
WaveList< D > & waveList()
Get the WaveList object by reference.
Basis< D > & basis()
Get the Basis by reference.
Mesh< D > & mesh()
Get the spatial Mesh by reference.
virtual void readParameters(std::istream &in)
Read body of parameter block (without opening and closing lines).
void setUnitCell(UnitCell< D > const &unitCell)
Set the unit cell, given a UnitCell<D> object.
bool hasGroup() const
Has a space group been identified?
void readRGridFieldHeader(std::istream &in, int &nMonomer)
Read initialization data from header of an r-grid field file.
FieldIo< D > & fieldIo()
Get associated FieldIo object.
FFT< D > & fft()
Get the FFT object by reference.
void setFileMaster(FileMaster &fileMaster)
Create association with a FileMaster, needed by FieldIo.
std::string groupName() const
Get group name.
File input/output operations and format conversions for fields.
Class to calculate and store properties of wavevectors.
A fixed capacity (static) contiguous array with a variable logical size.
A FileMaster manages input and output files for a simulation.
An object that can read multiple parameters from file.
Fields, FFTs, and utilities for periodic boundary conditions (CUDA)
Periodic fields and crystallography.
PSCF package top-level namespace.
Utility classes for scientific computation.