1#ifndef RPG_EXT_GEN_FILM_H
2#define RPG_EXT_GEN_FILM_H
11#include <rpg/System.h>
12#include <prdc/iterator/ExtGenFilmBase.h>
145 double interfaceThickness_;
154 {
return system().
h().hasData(); }
169 {
return system().domain().groupName(); }
174 {
return system().domain().unitCell().rBasis(
id); }
179 {
return system().mixture().nMonomer(); }
181 #ifndef RPG_EXT_GEN_FILM_TPP
Base class defining external fields for thin film systems.
double excludedThickness() const
Get value of excludedThickness.
bool isAthermal() const
Are the walls athermal?
int normalVecId() const
Get value of normalVecId.
DArray< double > chiBottomCurrent_
The chiBottom array used to generate the current external fields.
RealVec< D > normalVecCurrent_
The lattice vector normal to the film used to generate these fields.
DArray< double > const & chiTop() const
Get const chiTop array by reference.
DArray< double > chiTopCurrent_
The chiTop array used to generate the current external fields.
double interfaceThickness() const
Get value of interfaceThickness.
DArray< double > const & chiBottom() const
Get const chiBottom matrix by reference.
A RealVec<D, T> is D-component vector with elements of floating type T.
External field generator for a thin film geometry.
void maskNormalVecId()
Use the mask to determine and store the value of normalVecId.
void generate()
Generate the fields and store where the Iterator can access.
RealVec< D > systemLatticeVector(int id) const
Get one of the lattice vectors for this system.
bool isGenerated() const
Check whether the fields have been generated.
std::string systemSpaceGroup() const
Get the space group name for this system.
double stressTerm(int paramId) const
Get contribution to the stress from the external fields.
void allocate()
Allocate container necessary to generate and store fields.
System< D > & system()
Get the System associated with this object by reference.
void maskInterfaceThickness()
Use the mask to determine and store the value of interfaceThickness.
int systemNMonomer() const
Get the number of monomer species for this system.
ExtGenFilm()
Default constructor.
Main class for calculations that represent one system.
WFieldContainer< D > & h()
Get container of external potential fields (non-const reference).
void setClassName(const char *className)
Set class name string.
Periodic fields and crystallography.
PSCF package top-level namespace.
Utility classes for scientific computation.