1#ifndef RPG_AM_ITERATOR_BASIS_H
2#define RPG_AM_ITERATOR_BASIS_H
12#include "ImposedFieldsGenerator.h"
13#include <pscf/iterator/AmIteratorTmpl.h>
14#include <pscf/iterator/AmbdInteraction.h>
15#include <util/containers/DArray.h>
16#include <util/containers/RingBuffer.h>
79 double value,
bool& success);
96 using Iterator<D>::setFlexibleParams;
120 void setup(
bool isContinuation);
184 bool hasInitialGuess();
224 #ifndef RPG_AM_ITERATOR_BASIS_TPP
Template for Anderson mixing iterator algorithm.
DArray< double > const & residual() const
int solve(bool isContinuation=false)
Modified interaction to compute residual defn.
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.
Rpg implementation of the Anderson Mixing iterator.
double getParameter(std::string name, DArray< int > ids, bool &success) const
Get the value of a specialized sweep parameter.
~AmIteratorBasis()
Destructor.
AmIteratorBasis(System< D > &system)
Constructor.
void readParameters(std::istream &in)
Read all parameters and initialize.
void setup(bool isContinuation)
Setup iterator just before entering iteration loop.
void outputTimers(std::ostream &out)
Output timing results to log file.
void setParameter(std::string name, DArray< int > ids, double value, bool &success)
Set the value of a specialized sweep parameter.
GArray< ParameterType > getParameterTypes()
Return specialized sweep parameter types to add to the Sweep object.
Class defining mask & external fields to impose on the calculation.
Base class for iterative solvers for SCF equations.
Main class for calculations that represent one system.
Dynamically allocatable contiguous array template.
An automatically growable array, analogous to a std::vector.
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.
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.
Class for storing history of previous values in an array.
PSCF package top-level namespace.
Utility classes for scientific computation.