1#ifndef RPG_LR_AM_COMPRESSOR_H
2#define RPG_LR_AM_COMPRESSOR_H
11#include "Compressor.h"
12#include <prdc/cuda/RField.h>
13#include <prdc/cuda/RFieldDft.h>
14#include <pscf/math/IntVec.h>
15#include <pscf/cuda/DeviceArray.h>
16#include <pscf/iterator/AmIteratorTmpl.h>
17#include <rpg/fts/compressor/intra/IntraCorrelation.h>
23 template <
int D>
class System;
24 template <
int D>
class IntraCorrelation;
81 void setup(
bool isContinuation);
133 std::string errorType_;
240 bool hasInitialGuess();
286 double computeLambda(
double r);
295 #ifndef RPG_LR_AM_COMPRESSOR_TPP
Template for Anderson mixing iterator algorithm.
std::string errorType() const
Dynamic array on the GPU device with aligned data.
An IntVec<D, T> is a D-component vector of elements of integer type T.
Fourier transform of a real field on an FFT mesh.
Field of real double precision values on an FFT mesh.
Base class for iterators that impose incompressibility.
Base class for iterators that impose incompressibility.
Anderson Mixing compressor with linear-response preconditioning.
LrAmPreCompressor(System< D > &system)
Constructor.
double computeError(DeviceArray< cudaReal > &residTrial, DeviceArray< cudaReal > &fieldTrial, std::string errorType, int verbose)
Compute and return error used to test for convergence.
void readParameters(std::istream &in)
Read all parameters and initialize.
void setup(bool isContinuation)
Initialize just before entry to iterative loop.
void clearTimers()
Reset / clear all timers.
int compress()
Compress to obtain partial saddle point w+.
void outputTimers(std::ostream &out)
Write a report of time contributions used by this algorithm.
~LrAmPreCompressor()
Destructor.
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.