10#include <prdc/cuda/RField.h>
11#include <prdc/crystal/UnitCell.h>
13#include <pscf/mesh/Mesh.h>
14#include <pscf/math/IntVec.h>
15#include <pscf/cuda/DeviceArray.h>
17#include <util/containers/DArray.h>
150 {
return isAllocated_; }
156 {
return hasMinimumImages_; }
204 bool hasMinimumImages_;
220 {
return *unitCellPtr_; }
224 {
return *meshPtr_; }
257 return dKSqSlices_[i];
265 return implicitInverse_;
268 #ifndef RPG_WAVE_LIST_TPP
Dynamic array on the GPU device with aligned data.
An IntVec<D, T> is a D-component vector of elements of integer type T.
Description of a regular grid of points in a periodic domain.
Field of real double precision values on an FFT mesh.
Base template for UnitCell<D> classes, D=1, 2 or 3.
Class to calculate and store properties of wavevectors.
bool hasdKSq() const
Has the dKSq array been computed?
DeviceArray< cudaReal > const & dKSq() const
Get the full dKSq array on the device by reference.
void computedKSq()
Compute derivatives of |k|^2 w/ respect to unit cell parameters.
bool isAllocated() const
Has memory been allocated for arrays?
bool hasKSq() const
Has the kSq array been computed?
DeviceArray< int > const & minImages() const
Get the array of minimum images on the device by reference.
void computeMinimumImages()
Compute minimum images of wavevectors.
void clearUnitCellData()
Clear all internal data that depends on lattice parameters.
void allocate(Mesh< D > const &m, UnitCell< D > const &c)
Allocate memory and set association with a Mesh and UnitCell object.
DeviceArray< bool > const & implicitInverse() const
Get the implicitInverse array by reference.
void computeKSq()
Compute sq.
bool hasMinimumImages() const
Have minimum images been computed?
RField< D > const & kSq() const
Get the kSq array on the device by reference.
bool hasVariableAngle() const
Does this unit cell have an angle that can change?
Dynamically allocatable contiguous array template.
#define UTIL_CHECK(condition)
Assertion macro suitable for serial or parallel production code.
Fields, FFTs, and utilities for periodic boundary conditions (CUDA)
Periodic fields and crystallography.
PSCF package top-level namespace.
Utility classes for scientific computation.