PSCF v1.2
|
Rpc implementation of the Anderson Mixing iterator with symmetry. More...
#include <AmIteratorBasis.h>
Public Member Functions | |
AmIteratorBasis (System< D > &system) | |
Constructor. | |
~AmIteratorBasis () | |
Destructor. | |
void | readParameters (std::istream &in) |
Read all parameters and initialize. | |
void | outputTimers (std::ostream &out) |
Output timing results to log file. | |
GArray< ParameterType > | getParameterTypes () |
Return specialized sweep parameter types to add to the Sweep object. | |
void | setParameter (std::string name, DArray< int > ids, double value, bool &success) |
Set the value of a specialized sweep parameter. | |
double | getParameter (std::string name, DArray< int > ids, bool &success) const |
Get the value of a specialized sweep parameter. | |
void | setParameter (std::string name, DArray< int > ids, double value) |
Set the value of a specialized sweep parameter. | |
double | getParameter (std::string name, DArray< int > ids) const |
Get the value of a specialized sweep parameter. | |
![]() | |
AmIteratorTmpl () | |
Constructor. | |
~AmIteratorTmpl () | |
Destructor. | |
void | readParameters (std::istream &in) |
Read all parameters and initialize. | |
int | solve (bool isContinuation=false) |
Iterate to a solution. | |
void | outputTimers (std::ostream &out) |
Log output timing results. | |
void | clearTimers () |
Clear timers. | |
std::string | errorType () const |
Obtain error type. | |
Protected Member Functions | |
void | setup (bool isContinuation) |
Setup iterator just before entering iteration loop. | |
template<typename Type > | |
ScalarParam< Type > & | readOptional (std::istream &in, const char *label, Type &value) |
Add and read a new optional ScalarParam < Type > object. | |
void | readParamCompositeOptional (std::istream &in, ParamComposite &child, bool next=true) |
Add and attempt to read an optional child ParamComposite. | |
template<typename Type , int N> | |
FSArrayParam< Type, N > & | readOptionalFSArray (std::istream &in, const char *label, FSArray< Type, N > &array, int size) |
Add and read an optional FSArray < Type, N > array parameter. | |
void | setClassName (const char *className) |
Set class name string. | |
![]() | |
void | setMaxItr (int maxItr) |
Set value of maxItr. | |
void | setMaxHist (int maxHist) |
Set value of maxHist (number of retained previous states) | |
void | setErrorType (std::string errorType) |
Set and validate value of errorType string. | |
void | readErrorType (std::istream &in) |
Read and validate the optional errorType string parameter. | |
virtual bool | isValidErrorType () |
Checks if a string is a valid error type. | |
virtual double | norm (DArray< double > const &hist) |
Find the L2 norm of a vector. | |
void | allocateAM () |
Allocate memory required by AM algorithm, if necessary. | |
virtual void | clear () |
Clear information about history. | |
virtual double | computeError (DArray< double > &residTrial, DArray< double > &fieldTrial, std::string errorType, int verbose) |
Compute and return error used to test for convergence. | |
double | computeError (int verbose) |
Compute and return error used to test for convergence. | |
virtual double | computeLambda (double r) |
Compute mixing parameter for correction step of Anderson mixing. | |
DArray< double > const & | residual () const |
Return the current residual vector by const reference. | |
DArray< double > const & | field () const |
Return the current field or state vector by const reference. | |
int | verbose () const |
Verbosity level, allowed values 0, 1, or 2. | |
int | totalItr () |
Return the total number of iterations needed to converge. | |
double | timerTotal () |
Get total time. | |
double | timerMDE () |
Get time solving modified diffusion equation (MDE). | |
double | timerAM () |
Get total time for AM algorithm, excluding MDE solution. | |
double | timerResid () |
Get time computing residual. | |
double | timerError () |
Get time evaluating scalar error. | |
double | timerCoeff () |
Get time evaluating Anderson mixing coefficients. | |
double | timerOmega () |
Get time updating w fields. | |
bool | isAllocatedAM () const |
Have data structures required by the AM algorithm been allocated? | |
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. | |
Additional Inherited Members | |
![]() | |
std::string | errorType_ |
Type of error criterion used to test convergence. | |
Rpc implementation of the Anderson Mixing iterator with symmetry.
Definition at line 34 of file rpc/scft/iterator/AmIteratorBasis.h.
Pscf::Rpc::AmIteratorBasis< D >::AmIteratorBasis | ( | System< D > & | system | ) |
Constructor.
system | System object associated with this iterator. |
Definition at line 25 of file rpc/scft/iterator/AmIteratorBasis.tpp.
References Pscf::Rpc::AmIteratorBasis< D >::setClassName().
Pscf::Rpc::AmIteratorBasis< D >::~AmIteratorBasis | ( | ) |
Destructor.
Definition at line 35 of file rpc/scft/iterator/AmIteratorBasis.tpp.
void Pscf::Rpc::AmIteratorBasis< D >::readParameters | ( | std::istream & | in | ) |
Read all parameters and initialize.
in | input filestream |
Definition at line 40 of file rpc/scft/iterator/AmIteratorBasis.tpp.
References UTIL_CHECK.
void Pscf::Rpc::AmIteratorBasis< D >::outputTimers | ( | std::ostream & | out | ) |
Output timing results to log file.
out | output stream for timer report |
Definition at line 87 of file rpc/scft/iterator/AmIteratorBasis.tpp.
GArray< ParameterType > Pscf::Rpc::AmIteratorBasis< D >::getParameterTypes | ( | ) |
Return specialized sweep parameter types to add to the Sweep object.
Definition at line 459 of file rpc/scft/iterator/AmIteratorBasis.tpp.
void Pscf::Rpc::AmIteratorBasis< D >::setParameter | ( | std::string | name, |
DArray< int > | ids, | ||
double | value, | ||
bool & | success ) |
Set the value of a specialized sweep parameter.
name | name of the specialized parameter |
ids | array of integer indices specifying the value to set |
value | the value to which the parameter is set |
success | boolean flag used to indicate if parameter was set |
Definition at line 470 of file rpc/scft/iterator/AmIteratorBasis.tpp.
double Pscf::Rpc::AmIteratorBasis< D >::getParameter | ( | std::string | name, |
DArray< int > | ids, | ||
bool & | success ) const |
Get the value of a specialized sweep parameter.
name | name of the specialized parameter |
ids | array of integer indices specifying the value to get |
success | boolean flag used to indicate if parameter was gotten |
Definition at line 482 of file rpc/scft/iterator/AmIteratorBasis.tpp.
|
protectedvirtual |
Setup iterator just before entering iteration loop.
isContinuation | Is this a continuation within a sweep? |
Reimplemented from Pscf::AmIteratorTmpl< Iterator< D >, DArray< double > >.
Definition at line 99 of file rpc/scft/iterator/AmIteratorBasis.tpp.
void Pscf::ParameterModifier::setParameter | ( | std::string | name, |
DArray< int > | ids, | ||
double | value ) |
Set the value of a specialized sweep parameter.
This is an overloaded version of the setParameter method above, which should be used only when the caller is certain that the specialized sweep parameter belongs to this ParameterModifier. An error will be thrown if the specialized parameter is not settable using this class.
name | name of the specialized parameter |
ids | array of integer indices specifying the value to set |
value | the value to which the parameter is set |
Definition at line 122 of file ParameterModifier.cpp.
double Pscf::ParameterModifier::getParameter | ( | std::string | name, |
DArray< int > | ids ) const |
Get the value of a specialized sweep parameter.
This is an overloaded version of the getParameter method above, which should be used only when the caller is certain that the specialized sweep parameter belongs to this ParameterModifier. An error will be thrown if the specialized parameter is not gettable using this class.
name | name of the specialized parameter |
ids | array of integer indices specifying the value to set |
Definition at line 136 of file ParameterModifier.cpp.
|
inlineprotected |
Add and read a new optional ScalarParam < Type > object.
This is equivalent to ScalarParam<Type>(in, label, value, false).
in | input stream for reading |
label | Label string |
value | reference to new ScalarParam< Type > |
Definition at line 319 of file ParamComposite.h.
|
protected |
Add and attempt to read an optional child ParamComposite.
in | input stream for reading |
child | child ParamComposite object |
next | true if the indent level is one higher than parent. |
Definition at line 292 of file ParamComposite.cpp.
|
inlineprotected |
Add and read an optional FSArray < Type, N > array parameter.
in | input stream for reading |
label | Label string for new array |
array | FSArray object |
size | logical size of array |
Definition at line 427 of file ParamComposite.h.
|
protected |
Set class name string.
Should be set in subclass constructor.
Definition at line 900 of file ParamComposite.cpp.
Referenced by Pscf::Rpc::AmIteratorBasis< D >::AmIteratorBasis().