1#ifndef RPG_AM_ITERATOR_GRID_H
2#define RPG_AM_ITERATOR_GRID_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>
77 double value,
bool& success);
93 using Iterator<D>::setFlexibleParams;
117 void setup(
bool isContinuation);
180 void addPredictedError(
FieldCUDA& fieldTrial,
185 bool hasInitialGuess();
234 #ifndef RPG_AM_ITERATOR_GRID_TPP
Template for Anderson mixing iterator algorithm.
FieldCUDA const & residual() const
int solve(bool isContinuation=false)
FieldCUDA const & field() const
Modified interaction to compute residual defn.
Dynamic array on the GPU device with aligned data.
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.
AmIteratorGrid(System< D > &system)
Constructor.
void readParameters(std::istream &in)
Read all parameters and initialize.
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 setup(bool isContinuation)
Setup iterator just before entering iteration loop.
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.
~AmIteratorGrid()
Destructor.
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.