1#ifndef RPC_EXT_GEN_FILM_H
2#define RPC_EXT_GEN_FILM_H
11#include <rpc/System.h>
12#include <prdc/iterator/ExtGenFilmBase.h>
135 double interfaceThickness_;
144 {
return system().
h().hasData(); }
159 {
return system().domain().groupName(); }
164 {
return system().domain().unitCell().rBasis(
id); }
169 {
return system().mixture().nMonomer(); }
171 #ifndef RPC_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.
ExtGenFilm()
Default constructor.
bool isGenerated() const
Check whether the fields have been generated.
std::string systemSpaceGroup() const
Get the space group name for this system.
int systemNMonomer() const
Get the number of monomer species for this system.
void allocate()
Allocate container necessary to generate and store fields.
RealVec< D > systemLatticeVector(int id) const
Get one of the lattice vectors for this system.
void generate()
Generate the fields and store where the Iterator can access.
double stressTerm(int paramId) const
Get contribution to the stress from the external fields.
System< D > & system()
Get the System associated with this object by reference.
Main class for SCFT or PS-FTS simulation of one system.
WFieldContainer< D > & h()
Get container of external potential fields (reference).
void setClassName(const char *className)
Set class name string.
Periodic fields and crystallography.
PSCF package top-level namespace.
Utility classes for scientific computation.