8#include "ImposedFieldsTmpl.h"
9#include <util/param/Label.h>
28 read(in,
"type", type_);
32 std::streampos pos = in.tellg();
64 FieldGenerator::External);
66 UTIL_THROW(
"fieldGenPtr2_ must have type Mask or External.");
122 for (
int i = 0; i < a2.
size(); i++) {
132 double value,
bool& success)
Abstract base class for objects that generate fields for ImposedFields.
Type type() const
Return Type enumeration value (Mask, External, or None)
void setup()
Allocate, check compatibility, calculate, and store the field(s)
void update()
Check whether system has changed and update the field(s) if necessary.
bool isDependent() const
Is this object dependent on the parameters of another FieldGenerator?
virtual double stressTerm(int paramId) const
Get contribution to the stress from this imposed field.
virtual double modifyStress(int paramId, double stress) const
Modify the stress value if necessary.
void readParameters(std::istream &in)
Read parameters from input stream.
void update()
Check whether system has changed, update the field(s) if necessary.
FieldGenerator const & fieldGenerator1() const
Return const references to the FieldGenerator child objects.
void setup()
Allocate, check compatibility, calculate, and store the field(s).
ImposedFieldsTmpl()
Constructor.
virtual void createGenerators()=0
Create FieldGenerator objects for mask and/or external field.
void setParameter(std::string name, DArray< int > ids, double value, bool &success)
Set the value of a specialized sweep parameter.
~ImposedFieldsTmpl()
Destructor.
double correctedStress(int paramId, double stress) const
Correct the stress value if necessary.
double getParameter(std::string name, DArray< int > ids, bool &success) const
Get the value of a specialized sweep parameter.
FieldGenerator * fieldGenPtr2_
Pointer to the second FieldGenerator object (optional).
FieldGenerator * fieldGenPtr1_
Pointer to the first FieldGenerator object (required).
GArray< ParameterType > getParameterTypes()
Return specialized sweep parameter types to add to a Sweep object.
std::string type() const
Get the type string associated with this object.
virtual GArray< ParameterType > getParameterTypes()
Return specialized sweep parameter types to add to the Sweep object.
virtual void setParameter(std::string name, DArray< int > ids, double value, bool &success)
Set the value of a specialized sweep parameter.
virtual double getParameter(std::string name, DArray< int > ids, bool &success) const
Get the value of a specialized sweep parameter.
Dynamically allocatable contiguous array template.
An automatically growable array, analogous to a std::vector.
int size() const
Return logical size of this array (i.e., current number of elements).
void append(Data const &data)
Append an element to the end of the sequence.
static void clear()
Clear the input buffer.
virtual void readParameters(std::istream &in)
Read the body of parameter block, without begin and end lines.
ScalarParam< Type > & read(std::istream &in, const char *label, Type &value)
Add and read a new required ScalarParam < Type > object.
void setParent(ParamComponent ¶m, bool next=true)
Set this to the parent of a child component.
void addComponent(ParamComponent ¶m, bool isLeaf=true)
Add a new ParamComponent object to the format array.
#define UTIL_CHECK(condition)
Assertion macro suitable for serial or parallel production code.
#define UTIL_THROW(msg)
Macro for throwing an Exception, reporting function, file and line number.
PSCF package top-level namespace.