1#ifndef RPG_LINEAR_SWEEP_TPP
2#define RPG_LINEAR_SWEEP_TPP
11#include "LinearSweep.h"
12#include <rpg/system/System.h>
32 this->
read(in,
"nParameter", nParameter_);
33 parameters_.allocate(nParameter_);
37 for (
int i = 0; i < nParameter_; ++i) {
38 parameters_[i].setParameterTypesArray(
47 for (
int i = 0; i < nParameter_; ++i) {
48 if (parameters_[i].type() ==
"phi_polymer" || parameters_[i].type() ==
"phi_solvent") {
49 sum += parameters_[i].change();
66 for (
int i = 0; i < nParameter_; ++i) {
67 parameters_[i].setSystem(
system());
68 parameters_[i].getInitial();
77 for (
int i = 0; i < nParameter_; ++i) {
78 newVal = parameters_[i].initial() +
s*parameters_[i].change();
79 parameters_[i].update(newVal);
FieldState for fields in symmetry-adapted basis format.
void setup()
Setup operation at the beginning of a sweep.
void outputSummary(std::ostream &out)
Output data to a running summary.
void setParameters(double s)
Set the state before an iteration.
void readParameters(std::istream &in)
Read parameters from param file.
LinearSweep(System< D > &system)
Constructor.
virtual void readParameters(std::istream &in)
Read parameters from param file.
virtual void setup()
Setup operation at the beginning of a sweep.
bool hasSystem()
Has an association with the parent System been set?
Sweep()
Default Constructor.
System< D > & system()
Return the parent system by reference.
Main class, representing one complete system.
Solve a sequence of problems along a path through parameter space.
GArray< ParameterType > parameterTypes_
DArrayParam< Type > & readDArray(std::istream &in, const char *label, DArray< Type > &array, int n)
Add and read a required DArray < Type > parameter.
ScalarParam< Type > & read(std::istream &in, const char *label, Type &value)
Add and read a new required ScalarParam < Type > object.
#define UTIL_CHECK(condition)
Assertion macro suitable for serial or parallel production code.
SCFT and PS-FTS with real periodic fields (GPU)
PSCF package top-level namespace.