1#ifndef PRDC_MASK_GEN_FILM_BASE_H
2#define PRDC_MASK_GEN_FILM_BASE_H
11#include <prdc/crystal/UnitCell.h>
12#include <pscf/iterator/FieldGenerator.h>
13#include <pscf/math/RealVec.h>
247 double interfaceThickness_;
250 double excludedThickness_;
264 {
return normalVecId_; }
269 {
return interfaceThickness_; }
274 {
return excludedThickness_; }
284 {
return hasFBulk_; }
286 #ifndef PRDC_MASK_GEN_FILM_BASE_TPP
Abstract base class for objects that generate fields for ImposedFields.
Type type_
Type of field (Mask, External, Both, or None)
Base class defining mask that imposes thin film confinement.
double fBulk_
Reference free energy used to calculate stress normal to the film.
virtual double stressTerm(int paramId) const =0
Get contribution to the stress from this mask.
virtual void allocate()=0
Allocate container necessary to generate and store field.
bool updateNeeded() const
Check whether system has changed such that the field needs updating.
FSArray< bool, 6 > modifyFlexibleParams(FSArray< bool, 6 > current, UnitCell< D > const &cell) const
Modifies a flexibleParams array to be compatible with this mask.
MaskGenFilmBase()
Constructor.
~MaskGenFilmBase()
Destructor.
double fBulk() const
Get value of fBulk.
void checkLatticeVectors() const
Check that lattice vectors are compatible with thin film constraint.
bool isGenerated() const =0
Check whether the field has been generated.
double excludedThickness() const
Get value of excludedThickness.
void checkCompatibility()
Check that the system is compatible with this field.
void readParameters(std::istream &in)
Read parameter file block and initialize.
virtual void setFlexibleParams() const =0
Sets flexible lattice parameters to be compatible with the mask.
virtual double modifyStress(int paramId, double stress) const =0
Modify stress value in direction normal to the film.
void checkSpaceGroup() const
Check that space group is compatible with the mask.
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.
virtual RealVec< D > systemLatticeVector(int id) const =0
Get one of the lattice vectors for this system.
virtual std::string systemSpaceGroup() const =0
Get the space group name for this system.
bool hasFBulk() const
Check whether a value of fBulk was provided.
virtual void generate()=0
Generate the field and store where the Iterator can access.
Base template for UnitCell<D> classes, D=1, 2 or 3.
A RealVec<D, T> is D-component vector with elements of floating type T.
A fixed capacity (static) contiguous array with a variable logical size.
ScalarParam< Type > & read(std::istream &in, const char *label, Type &value)
Add and read a new required ScalarParam < Type > object.
ScalarParam< Type > & readOptional(std::istream &in, const char *label, Type &value)
Add and read a new optional ScalarParam < Type > object.
PSCF package top-level namespace.
Utility classes for scientific computation.