11#include <rpg/scft/sweep/Sweep.h>
12#include <pscf/cuda/DeviceArray.h>
13#include <pscf/sweep/ParameterModifier.h>
14#include <util/param/ParamComposite.h>
26 typedef Prdc::Cuda::DeviceArray<Prdc::Cuda::cudaReal> FieldCUDA;
62 virtual int solve(
bool isContinuation) = 0;
141 : isSymmetric_(false),
149 : isSymmetric_(false),
162 {
return isSymmetric_; }
168 {
return isFlexible_; }
173 {
return flexibleParams_; }
180 system().unitCell().nParameter());
182 for (
int i = 0; i < flexibleParams_.size(); i++) {
183 if (flexibleParams_[i]) nFlexParams++;
192 flexibleParams_ = flexParams;
193 if (nFlexibleParams() == 0) {
System< D > & system()
Return reference to parent system.
void setFlexibleParams(FSArray< bool, 6 > const &flexParams)
Set the array indicating which lattice parameters are flexible.
Iterator()
Default constructor.
virtual int solve(bool isContinuation)=0
Iterate to solution.
virtual void clearTimers()=0
Clear timers.
bool isFlexible() const
Is the unit cell flexible (true) or rigid (false).
int nFlexibleParams() const
Get the number of flexible lattice parameters.
bool isSymmetric() const
Does this iterator use a symmetry-adapted Fourier basis?
bool isFlexible_
Is the unit cell flexible during iteration?
FSArray< bool, 6 > flexibleParams() const
Get the array indicating which lattice parameters are flexible.
virtual void outputTimers(std::ostream &out)=0
Log output timing results.
bool isSymmetric_
Does this iterator use a symmetry-adapted basis?
FSArray< bool, 6 > flexibleParams_
Array of indices of the lattice parameters that are flexible.
Main class for calculations that represent one system.
A fixed capacity (static) contiguous array with a variable logical size.
An object that can read multiple parameters from file.
void setClassName(const char *className)
Set class name string.
File containing preprocessor macros for error handling.
#define UTIL_CHECK(condition)
Assertion macro suitable for serial or parallel production code.
PSCF package top-level namespace.
Utility classes for scientific computation.