PSCF v1.2
Pscf::Rpc::WFieldContainer< D > Class Template Reference

A container of fields stored in both basis and r-grid format. More...

#include <WFieldContainer.h>

Inheritance diagram for Pscf::Rpc::WFieldContainer< D >:
Util::ParamComposite Util::ParamComponent Util::Serializable Util::MpiFileIo

Public Member Functions

 WFieldContainer ()
 Constructor.
 
 ~WFieldContainer ()
 Destructor.
 
Initialization and Memory Management
void setFieldIo (FieldIo< D > const &fieldIo)
 Create association with FieldIo (store pointer).
 
void setNMonomer (int nMonomer)
 Set stored value of nMonomer.
 
void allocateRGrid (IntVec< D > const &dimensions)
 Allocate or re-allocate memory for fields in rgrid format.
 
void deallocateRGrid ()
 De-allocate fields in rgrid format.
 
void allocateBasis (int nBasis)
 Allocate or re-allocate memory for fields in basis format.
 
void deallocateBasis ()
 De-allocate fields in basis format.
 
void allocate (int nMonomer, int nBasis, IntVec< D > const &dimensions)
 Allocate memory for all fields.
 
Field Mutators


void setBasis (DArray< DArray< double > > const &fields)
 Set field component values, in symmetrized Fourier format.
 
void setRGrid (DArray< RField< D > > const &fields, bool isSymmetric=false)
 Set fields values in real-space (r-grid) format.
 
void readBasis (std::istream &in, UnitCell< D > &unitCell)
 Read field component values from input stream, in symmetrized Fourier format.
 
void readBasis (std::string filename, UnitCell< D > &unitCell)
 Read field component values from file, in symmetrized Fourier format.
 
void readRGrid (std::istream &in, UnitCell< D > &unitCell, bool isSymmetric=false)
 Reads fields from an input stream in real-space (r-grid) format.
 
void readRGrid (std::string filename, UnitCell< D > &unitCell, bool isSymmetric=false)
 Reads fields from a file in real-space (r-grid) format.
 
Field Accessors (by const reference)
DArray< DArray< double > > const & basis () const
 Get array of all fields in basis format.
 
DArray< double > const & basis (int monomerId) const
 Get the field for one monomer type in basis format.
 
DArray< RField< D > > const & rgrid () const
 Get array of all fields in r-space grid format.
 
RField< D > const & rgrid (int monomerId) const
 Get the field for one monomer type in r-space grid format.
 
Boolean Queries
bool isAllocatedRGrid () const
 Has memory been allocated for fields in r-grid format?
 
bool isAllocatedBasis () const
 Has memory been allocated for fields in basis format?
 
bool hasData () const
 Has field data been set in either format?
 
bool isSymmetric () const
 Are fields symmetric under all elements of the space group?
 
- Public Member Functions inherited from Util::ParamComposite
 ParamComposite ()
 Constructor.
 
 ParamComposite (const ParamComposite &other)
 Copy constructor.
 
 ParamComposite (int capacity)
 Constructor.
 
virtual ~ParamComposite ()
 Virtual destructor.
 
void resetParam ()
 Resets ParamComposite to its empty state.
 
virtual void readParam (std::istream &in)
 Read the parameter file block.
 
virtual void readParamOptional (std::istream &in)
 Read optional parameter file block.
 
virtual void readParameters (std::istream &in)
 Read the body of parameter block, without begin and end lines.
 
virtual void writeParam (std::ostream &out) const
 Write all parameters to an output stream.
 
virtual void load (Serializable::IArchive &ar)
 Load all parameters from an input archive.
 
virtual void loadOptional (Serializable::IArchive &ar)
 Load an optional ParamComposite.
 
virtual void loadParameters (Serializable::IArchive &ar)
 Load state from archive, without adding Begin and End lines.
 
virtual void save (Serializable::OArchive &ar)
 Saves all parameters to an archive.
 
void saveOptional (Serializable::OArchive &ar)
 Saves isActive flag, and then calls save() iff isActive is true.
 
void readParamComposite (std::istream &in, ParamComposite &child, bool next=true)
 Add and read a required child ParamComposite.
 
void readParamCompositeOptional (std::istream &in, ParamComposite &child, bool next=true)
 Add and attempt to read an optional child ParamComposite.
 
template<typename Type >
ScalarParam< Type > & read (std::istream &in, const char *label, Type &value)
 Add and read a new required ScalarParam < Type > object.
 
template<typename Type >
ScalarParam< Type > & readOptional (std::istream &in, const char *label, Type &value)
 Add and read a new optional ScalarParam < Type > object.
 
template<typename Type >
CArrayParam< Type > & readCArray (std::istream &in, const char *label, Type *value, int n)
 Add and read a required C array parameter.
 
template<typename Type >
CArrayParam< Type > & readOptionalCArray (std::istream &in, const char *label, Type *value, int n)
 Add and read an optional C array parameter.
 
template<typename Type >
DArrayParam< Type > & readDArray (std::istream &in, const char *label, DArray< Type > &array, int n)
 Add and read a required DArray < Type > parameter.
 
template<typename Type >
DArrayParam< Type > & readOptionalDArray (std::istream &in, const char *label, DArray< Type > &array, int n)
 Add and read an optional DArray < Type > parameter.
 
template<typename Type , int N>
FArrayParam< Type, N > & readFArray (std::istream &in, const char *label, FArray< Type, N > &array)
 Add and read a required FArray < Type, N > array parameter.
 
template<typename Type , int N>
FArrayParam< Type, N > & readOptionalFArray (std::istream &in, const char *label, FArray< Type, N > &array)
 Add and read an optional FArray < Type, N > array parameter.
 
template<typename Type , int N>
FSArrayParam< Type, N > & readFSArray (std::istream &in, const char *label, FSArray< Type, N > &array, int size)
 Add and read a required FSArray < Type, N > array parameter.
 
template<typename Type , int N>
FSArrayParam< Type, N > & readOptionalFSArray (std::istream &in, const char *label, FSArray< Type, N > &array, int size)
 Add and read an optional FSArray < Type, N > array parameter.
 
template<typename Type >
CArray2DParam< Type > & readCArray2D (std::istream &in, const char *label, Type *value, int m, int n, int np)
 Add and read a required CArray2DParam < Type > 2D C-array.
 
template<typename Type >
CArray2DParam< Type > & readOptionalCArray2D (std::istream &in, const char *label, Type *value, int m, int n, int np)
 Add and read an optional CArray2DParam < Type > 2D C-array parameter.
 
template<typename Type >
DMatrixParam< Type > & readDMatrix (std::istream &in, const char *label, DMatrix< Type > &matrix, int m, int n)
 Add and read a required DMatrix < Type > matrix parameter.
 
template<typename Type >
DMatrixParam< Type > & readOptionalDMatrix (std::istream &in, const char *label, DMatrix< Type > &matrix, int m, int n)
 Add and read an optional DMatrix < Type > matrix parameter.
 
template<typename Type >
DSymmMatrixParam< Type > & readDSymmMatrix (std::istream &in, const char *label, DMatrix< Type > &matrix, int n)
 Add and read a required symmetrix DMatrix.
 
template<typename Type >
DSymmMatrixParam< Type > & readOptionalDSymmMatrix (std::istream &in, const char *label, DMatrix< Type > &matrix, int n)
 Add and read an optional DMatrix matrix parameter.
 
BeginreadBegin (std::istream &in, const char *label, bool isRequired=true)
 Add and read a class label and opening bracket.
 
EndreadEnd (std::istream &in)
 Add and read the closing bracket.
 
BlankreadBlank (std::istream &in)
 Add and read a new Blank object, representing a blank line.
 
void loadParamComposite (Serializable::IArchive &ar, ParamComposite &child, bool next=true)
 Add and load a required child ParamComposite.
 
void loadParamCompositeOptional (Serializable::IArchive &ar, ParamComposite &child, bool next=true)
 Add and load an optional child ParamComposite if isActive.
 
template<typename Type >
ScalarParam< Type > & loadParameter (Serializable::IArchive &ar, const char *label, Type &value, bool isRequired)
 Add and load a new ScalarParam < Type > object.
 
template<typename Type >
ScalarParam< Type > & loadParameter (Serializable::IArchive &ar, const char *label, Type &value)
 Add and load new required ScalarParam < Type > object.
 
template<typename Type >
CArrayParam< Type > & loadCArray (Serializable::IArchive &ar, const char *label, Type *value, int n, bool isRequired)
 Add a C array parameter and load its elements.
 
template<typename Type >
CArrayParam< Type > & loadCArray (Serializable::IArchive &ar, const char *label, Type *value, int n)
 Add and load a required CArrayParam< Type > array parameter.
 
template<typename Type >
DArrayParam< Type > & loadDArray (Serializable::IArchive &ar, const char *label, DArray< Type > &array, int n, bool isRequired)
 Add an load a DArray < Type > array parameter.
 
template<typename Type >
DArrayParam< Type > & loadDArray (Serializable::IArchive &ar, const char *label, DArray< Type > &array, int n)
 Add and load a required DArray< Type > array parameter.
 
template<typename Type , int N>
FArrayParam< Type, N > & loadFArray (Serializable::IArchive &ar, const char *label, FArray< Type, N > &array, bool isRequired)
 Add and load an FArray < Type, N > fixed-size array parameter.
 
template<typename Type , int N>
FArrayParam< Type, N > & loadFArray (Serializable::IArchive &ar, const char *label, FArray< Type, N > &array)
 Add and load a required FArray < Type > array parameter.
 
template<typename Type , int N>
FSArrayParam< Type, N > & loadFSArray (Serializable::IArchive &ar, const char *label, FSArray< Type, N > &array, int size, bool isRequired)
 Add and load an FSArray < Type, N > array parameter.
 
template<typename Type , int N>
FSArrayParam< Type, N > & loadFSArray (Serializable::IArchive &ar, const char *label, FSArray< Type, N > &array, int size)
 Add and load a required FSArray < Type > array parameter.
 
template<typename Type >
CArray2DParam< Type > & loadCArray2D (Serializable::IArchive &ar, const char *label, Type *value, int m, int n, int np, bool isRequired)
 Add and load a CArray2DParam < Type > C 2D array parameter.
 
template<typename Type >
CArray2DParam< Type > & loadCArray2D (Serializable::IArchive &ar, const char *label, Type *value, int m, int n, int np)
 Add and load a required < Type > matrix parameter.
 
template<typename Type >
DMatrixParam< Type > & loadDMatrix (Serializable::IArchive &ar, const char *label, DMatrix< Type > &matrix, int m, int n, bool isRequired)
 Add and load a DMatrixParam < Type > matrix parameter.
 
template<typename Type >
DMatrixParam< Type > & loadDMatrix (Serializable::IArchive &ar, const char *label, DMatrix< Type > &matrix, int m, int n)
 Add and load a required DMatrixParam < Type > matrix parameter.
 
template<typename Type >
DSymmMatrixParam< Type > & loadDSymmMatrix (Serializable::IArchive &ar, const char *label, DMatrix< Type > &matrix, int n, bool isRequired)
 Add and load a symmetric DSymmMatrixParam < Type > matrix parameter.
 
template<typename Type >
DSymmMatrixParam< Type > & loadDSymmMatrix (Serializable::IArchive &ar, const char *label, DMatrix< Type > &matrix, int n)
 Add and load a required DSymmMatrixParam < Type > matrix parameter.
 
void addParamComposite (ParamComposite &child, bool next=true)
 Add a child ParamComposite object to the format array.
 
BeginaddBegin (const char *label)
 Add a Begin object representing a class name and bracket.
 
EndaddEnd ()
 Add a closing bracket.
 
BlankaddBlank ()
 Create and add a new Blank object, representing a blank line.
 
std::string className () const
 Get class name string.
 
bool isRequired () const
 Is this ParamComposite required in the input file?
 
bool isActive () const
 Is this parameter active?
 
- Public Member Functions inherited from Util::ParamComponent
virtual ~ParamComponent ()
 Destructor.
 
void setIndent (const ParamComponent &parent, bool next=true)
 Set indent level.
 
std::string indent () const
 Return indent string for this object (string of spaces).
 
template<class Archive >
void serialize (Archive &ar, const unsigned int version)
 Serialize this ParamComponent as a string.
 
- Public Member Functions inherited from Util::Serializable
virtual ~Serializable ()
 Destructor.
 
- Public Member Functions inherited from Util::MpiFileIo
 MpiFileIo ()
 Constructor.
 
 MpiFileIo (const MpiFileIo &other)
 Copy constructor.
 
bool isIoProcessor () const
 Can this processor do file I/O ?
 
void setIoCommunicator (MPI::Intracomm &communicator)
 Set the communicator.
 
void clearCommunicator ()
 Clear (nullify) the communicator.
 
bool hasIoCommunicator () const
 Does this object have an associated MPI communicator?
 
MPI::Intracomm & ioCommunicator () const
 Get the MPI communicator by reference.
 

Additional Inherited Members

- Public Types inherited from Util::Serializable
typedef BinaryFileOArchive OArchive
 Type of output archive used by save method.
 
typedef BinaryFileIArchive IArchive
 Type of input archive used by load method.
 
- Static Public Member Functions inherited from Util::ParamComponent
static void initStatic ()
 Initialize static echo member to false.
 
static void setEcho (bool echo=true)
 Enable or disable echoing for all subclasses of ParamComponent.
 
static bool echo ()
 Get echo parameter.
 
- Protected Member Functions inherited from Util::ParamComposite
void setClassName (const char *className)
 Set class name string.
 
void setIsRequired (bool isRequired)
 Set or unset the isActive flag.
 
void setIsActive (bool isActive)
 Set or unset the isActive flag.
 
void setParent (ParamComponent &param, bool next=true)
 Set this to the parent of a child component.
 
void addComponent (ParamComponent &param, bool isLeaf=true)
 Add a new ParamComponent object to the format array.
 
template<typename Type >
ScalarParam< Type > & add (std::istream &in, const char *label, Type &value, bool isRequired=true)
 Add a new required ScalarParam < Type > object.
 
template<typename Type >
CArrayParam< Type > & addCArray (std::istream &in, const char *label, Type *value, int n, bool isRequired=true)
 Add (but do not read) a required C array parameter.
 
template<typename Type >
DArrayParam< Type > & addDArray (std::istream &in, const char *label, DArray< Type > &array, int n, bool isRequired=true)
 Add (but do not read) a DArray < Type > parameter.
 
template<typename Type , int N>
FArrayParam< Type, N > & addFArray (std::istream &in, const char *label, FArray< Type, N > &array, bool isRequired=true)
 Add (but do not read) a FArray < Type, N > array parameter.
 
template<typename Type , int N>
FSArrayParam< Type, N > & addFSArray (std::istream &in, const char *label, FSArray< Type, N > &array, int size, bool isRequired=true)
 Add (but do not read) a FSArray < Type, N > array parameter.
 
template<typename Type >
CArray2DParam< Type > & addCArray2D (std::istream &in, const char *label, Type *value, int m, int n, int np, bool isRequired=true)
 Add (but do not read) a CArray2DParam < Type > 2D C-array.
 
template<typename Type >
DMatrixParam< Type > & addDMatrix (std::istream &in, const char *label, DMatrix< Type > &matrix, int m, int n, bool isRequired=true)
 Add and read a required DMatrix < Type > matrix parameter.
 
- Protected Member Functions inherited from Util::ParamComponent
 ParamComponent ()
 Constructor.
 
 ParamComponent (const ParamComponent &other)
 Copy constructor.
 

Detailed Description

template<int D>
class Pscf::Rpc::WFieldContainer< D >

A container of fields stored in both basis and r-grid format.

A WFieldContainer<D> contains representations of a list of nMonomer fields that are associated with different monomer types. Fields may be stored in two different related formats:

  • A DArray of DArray<double> containers holds components of each field in a symmetry-adapted Fourier expansion (i.e., in basis format). This is accessed by the basis() and basis(int) member functions.
  • A DArray of RField<D> containers holds valus of each field on the nodes of a regular grid. This is accessed by the rgrid() and rgrid(int) member functions.

A WFieldContainer is designed to automatically update one of these representations when the other is modified, when appropriate. A pointer to an associated FieldIo<D> is used for these conversions. The setBasis function allows the user to input new components in basis format and internally recomputes the values in r-grid format. The setRgrid function allows the user to reset the fields in r-grid format, but recomputes the components in basis format if and only if the user declares that the fields are known to be invariant under all symmetries of the space group. A boolean flag named isSymmetric is used to keep track of whether the current field is symmetric, and thus whether the basis format exists.

Definition at line 60 of file rpc/field/WFieldContainer.h.

Constructor & Destructor Documentation

◆ WFieldContainer()

template<int D>
Pscf::Rpc::WFieldContainer< D >::WFieldContainer ( )

Constructor.

Definition at line 26 of file rpc/field/WFieldContainer.tpp.

◆ ~WFieldContainer()

template<int D>
Pscf::Rpc::WFieldContainer< D >::~WFieldContainer ( )

Destructor.

Definition at line 44 of file rpc/field/WFieldContainer.tpp.

Member Function Documentation

◆ setFieldIo()

template<int D>
void Pscf::Rpc::WFieldContainer< D >::setFieldIo ( FieldIo< D > const & fieldIo)

Create association with FieldIo (store pointer).

Definition at line 51 of file rpc/field/WFieldContainer.tpp.

◆ setNMonomer()

template<int D>
void Pscf::Rpc::WFieldContainer< D >::setNMonomer ( int nMonomer)

Set stored value of nMonomer.

May only be called once.

Parameters
nMonomernumber of monomer types.

Definition at line 58 of file rpc/field/WFieldContainer.tpp.

References UTIL_CHECK.

◆ allocateRGrid()

template<int D>
void Pscf::Rpc::WFieldContainer< D >::allocateRGrid ( IntVec< D > const & dimensions)

Allocate or re-allocate memory for fields in rgrid format.

Parameters
dimensionsdimensions of spatial mesh

Definition at line 70 of file rpc/field/WFieldContainer.tpp.

References UTIL_CHECK.

◆ deallocateRGrid()

template<int D>
void Pscf::Rpc::WFieldContainer< D >::deallocateRGrid ( )

De-allocate fields in rgrid format.

Definition at line 100 of file rpc/field/WFieldContainer.tpp.

References UTIL_CHECK.

◆ allocateBasis()

template<int D>
void Pscf::Rpc::WFieldContainer< D >::allocateBasis ( int nBasis)

Allocate or re-allocate memory for fields in basis format.

Parameters
nBasisnumber of basis functions

Definition at line 117 of file rpc/field/WFieldContainer.tpp.

References UTIL_CHECK.

◆ deallocateBasis()

template<int D>
void Pscf::Rpc::WFieldContainer< D >::deallocateBasis ( )

De-allocate fields in basis format.

Definition at line 141 of file rpc/field/WFieldContainer.tpp.

References UTIL_CHECK.

◆ allocate()

template<int D>
void Pscf::Rpc::WFieldContainer< D >::allocate ( int nMonomer,
int nBasis,
IntVec< D > const & dimensions )

Allocate memory for all fields.

This function may only be called once.

Parameters
nMonomernumber of monomer types
nBasisnumber of basis functions
dimensionsdimensions of spatial mesh

Definition at line 157 of file rpc/field/WFieldContainer.tpp.

◆ setBasis()

template<int D>
void Pscf::Rpc::WFieldContainer< D >::setBasis ( DArray< DArray< double > > const & fields)

Set field component values, in symmetrized Fourier format.

This function also computes and stores the corresponding r-grid representation. On return, hasData and isSymmetric are both true.

Parameters
fieldsarray of new fields in basis format

Definition at line 170 of file rpc/field/WFieldContainer.tpp.

References Util::Array< Data >::capacity(), and UTIL_CHECK.

◆ setRGrid()

template<int D>
void Pscf::Rpc::WFieldContainer< D >::setRGrid ( DArray< RField< D > > const & fields,
bool isSymmetric = false )

Set fields values in real-space (r-grid) format.

If the isSymmetric parameter is true, this function assumes that the fields are known to be symmetric and so computes and stores the corresponding basis components. If isSymmetric is false, it only sets the values in the r-grid format.

On return, hasData is true and the persistent isSymmetric flag defined by the class is set to the value of the isSymmetric input parameter.

Parameters
fieldsarray of new fields in r-grid format
isSymmetricis this field symmetric under the space group?

Definition at line 196 of file rpc/field/WFieldContainer.tpp.

References Util::Array< Data >::capacity(), and UTIL_CHECK.

◆ readBasis() [1/2]

template<int D>
void Pscf::Rpc::WFieldContainer< D >::readBasis ( std::istream & in,
UnitCell< D > & unitCell )

Read field component values from input stream, in symmetrized Fourier format.

This function also computes and stores the corresponding r-grid representation. On return, hasData and isSymmetric are both true.

This object must already be allocated and associated with a FieldIo object to run this function.

Parameters
ininput stream from which to read fields
unitCellassociated crystallographic unit cell

Definition at line 230 of file rpc/field/WFieldContainer.tpp.

References UTIL_CHECK.

◆ readBasis() [2/2]

template<int D>
void Pscf::Rpc::WFieldContainer< D >::readBasis ( std::string filename,
UnitCell< D > & unitCell )

Read field component values from file, in symmetrized Fourier format.

This function also computes and stores the corresponding r-grid representation. On return, hasData and isSymmetric are both true.

This object must already be allocated and associated with a FieldIo object to run this function.

Parameters
filenamefile from which to read fields
unitCellassociated crystallographic unit cell

Definition at line 252 of file rpc/field/WFieldContainer.tpp.

References UTIL_CHECK.

◆ readRGrid() [1/2]

template<int D>
void Pscf::Rpc::WFieldContainer< D >::readRGrid ( std::istream & in,
UnitCell< D > & unitCell,
bool isSymmetric = false )

Reads fields from an input stream in real-space (r-grid) format.

If the isSymmetric parameter is true, this function assumes that the fields are known to be symmetric and so computes and stores the corresponding basis components. If isSymmetric is false, it only sets the values in the r-grid format.

On return, hasData is true and the persistent isSymmetric flag defined by the class is set to the value of the isSymmetric input parameter.

This object must already be allocated and associated with a FieldIo object to run this function.

Parameters
ininput stream from which to read fields
unitCellassociated crystallographic unit cell
isSymmetricis this field symmetric under the space group?

Definition at line 278 of file rpc/field/WFieldContainer.tpp.

References UTIL_CHECK.

◆ readRGrid() [2/2]

template<int D>
void Pscf::Rpc::WFieldContainer< D >::readRGrid ( std::string filename,
UnitCell< D > & unitCell,
bool isSymmetric = false )

Reads fields from a file in real-space (r-grid) format.

If the isSymmetric parameter is true, this function assumes that the fields are known to be symmetric and so computes and stores the corresponding basis components. If isSymmetric is false, it only sets the values in the r-grid format.

On return, hasData is true and the persistent isSymmetric flag defined by the class is set to the value of the isSymmetric input parameter.

This object must already be allocated and associated with a FieldIo object to run this function.

Parameters
filenamefile from which to read fields
unitCellassociated crystallographic unit cell
isSymmetricis this field symmetric under the space group?

Definition at line 306 of file rpc/field/WFieldContainer.tpp.

References UTIL_CHECK.

◆ basis() [1/2]

template<int D>
DArray< DArray< double > > const & Pscf::Rpc::WFieldContainer< D >::basis ( ) const
inline

Get array of all fields in basis format.

The array capacity is equal to the number of monomer types.

Definition at line 379 of file rpc/field/WFieldContainer.h.

◆ basis() [2/2]

template<int D>
DArray< double > const & Pscf::Rpc::WFieldContainer< D >::basis ( int monomerId) const
inline

Get the field for one monomer type in basis format.

An Exception is thrown if isSymmetric is false.

Parameters
monomerIdinteger monomer type index (0,...,nMonomer-1)

Definition at line 385 of file rpc/field/WFieldContainer.h.

◆ rgrid() [1/2]

template<int D>
DArray< RField< D > > const & Pscf::Rpc::WFieldContainer< D >::rgrid ( ) const
inline

Get array of all fields in r-space grid format.

The array capacity is equal to the number of monomer types.

Definition at line 392 of file rpc/field/WFieldContainer.h.

◆ rgrid() [2/2]

template<int D>
RField< D > const & Pscf::Rpc::WFieldContainer< D >::rgrid ( int monomerId) const
inline

Get the field for one monomer type in r-space grid format.

Parameters
monomerIdinteger monomer type index (0,..,nMonomer-1)

Definition at line 398 of file rpc/field/WFieldContainer.h.

◆ isAllocatedRGrid()

template<int D>
bool Pscf::Rpc::WFieldContainer< D >::isAllocatedRGrid ( ) const
inline

Has memory been allocated for fields in r-grid format?

Definition at line 403 of file rpc/field/WFieldContainer.h.

◆ isAllocatedBasis()

template<int D>
bool Pscf::Rpc::WFieldContainer< D >::isAllocatedBasis ( ) const
inline

Has memory been allocated for fields in basis format?

Definition at line 408 of file rpc/field/WFieldContainer.h.

◆ hasData()

template<int D>
bool Pscf::Rpc::WFieldContainer< D >::hasData ( ) const
inline

Has field data been set in either format?

This flag is set true in setBasis and setRGrid.

Definition at line 413 of file rpc/field/WFieldContainer.h.

◆ isSymmetric()

template<int D>
bool Pscf::Rpc::WFieldContainer< D >::isSymmetric ( ) const
inline

Are fields symmetric under all elements of the space group?

A valid basis format exists if and only if isSymmetric is true. This flat is set true if the fields were input in basis format by the function setBasis, or if they were set in grid format by the function setRGrid but isSymmetric was set true.

Definition at line 418 of file rpc/field/WFieldContainer.h.


The documentation for this class was generated from the following files: