1#ifndef RPG_AM_COMPRESSOR_H
2#define RPG_AM_COMPRESSOR_H
11#include "Compressor.h"
12#include <prdc/cuda/RField.h>
13#include <pscf/cuda/DeviceArray.h>
14#include <pscf/iterator/AmIteratorTmpl.h>
16#include <util/containers/DArray.h>
22 template <
int D>
class System;
35 DeviceArray<cudaReal> >
68 void setup(
bool isContinuation);
186 bool hasInitialGuess();
Template for Anderson mixing iterator algorithm.
Dynamic array on the GPU device with aligned data.
Rpg implementation of the Anderson Mixing compressor.
int compress()
Compress to obtain partial saddle point w+.
int mdeCounter()
Return how many times MDE has been solved.
void outputTimers(std::ostream &out)
Return compressor times contributions.
AmCompressor(System< D > &system)
Constructor.
~AmCompressor()
Destructor.
void setup(bool isContinuation)
Initialize just before entry to iterative loop.
double computeLambda(double r)
Compute mixing parameter lambda.
void clearTimers()
Clear all timers (reset accumulated time to zero).
void readParameters(std::istream &in)
Read all parameters and initialize.
Base class for iterators that impose incompressibility.
Main class for calculations that represent one system.
Dynamically allocatable contiguous array template.
ScalarParam< Type > & readOptional(std::istream &in, const char *label, Type &value)
Add and read a new optional ScalarParam < Type > object.
Class for storing history of previous values in an array.
Fields, FFTs, and utilities for periodic boundary conditions (CUDA)
Periodic fields and crystallography.
PSCF package top-level namespace.
Utility classes for scientific computation.