1#ifndef RPC_MASK_GEN_FILM_H
2#define RPC_MASK_GEN_FILM_H
11#include <rpc/System.h>
12#include <prdc/iterator/MaskGenFilmBase.h>
153 {
return system().
mask().hasData(); }
168 {
return system().domain().groupName(); }
173 {
return system().domain().unitCell().rBasis(
id); }
175 #ifndef RPC_MASK_GEN_FILM_TPP
Base class defining mask that imposes thin film confinement.
double fBulk_
Reference free energy used to calculate stress normal to the film.
FSArray< bool, 6 > modifyFlexibleParams(FSArray< bool, 6 > current, UnitCell< D > const &cell) const
Modifies a flexibleParams array to be compatible with this mask.
double excludedThickness() const
Get value of excludedThickness.
double interfaceThickness() const
Get value of interfaceThickness.
RealVec< D > normalVecCurrent_
The lattice vector normal to the film used to generate these fields.
int normalVecId() const
Get value of normalVecId.
bool hasFBulk() const
Check whether a value of fBulk was provided.
A RealVec<D, T> is D-component vector with elements of floating type T.
Mask generator for a thin film geometry.
MaskGenFilm()
Default constructor.
System< D > & system()
Get the System associated with this object by reference.
RealVec< D > systemLatticeVector(int id) const
Get one of the lattice vectors for this system.
void setFlexibleParams() const
Modifies iterator().flexibleParams_ to be compatible with the mask.
double stressTerm(int paramId) const
Get contribution to the stress from this mask.
bool isGenerated() const
Check whether the field has been generated.
void generate()
Generate the field and store where the Iterator can access.
std::string systemSpaceGroup() const
Get the space group name for this system.
void allocate()
Allocate container necessary to generate and store field.
~MaskGenFilm()
Destructor.
double modifyStress(int paramId, double stress) const
Modify stress value in direction normal to the film.
Main class for SCFT or PS-FTS simulation of one system.
Mask< D > & mask()
Get the mask (field to which total density is constrained).
void setClassName(const char *className)
Set class name string.
Periodic fields and crystallography.
PSCF package top-level namespace.
Utility classes for scientific computation.