1#ifndef RPG_PROPAGATOR_H
2#define RPG_PROPAGATOR_H
11#include <prdc/cuda/RField.h>
12#include <pscf/cuda/DeviceArray.h>
13#include <pscf/solvers/PropagatorTmpl.h>
14#include <util/containers/DArray.h>
19 template <
int D>
class Mesh;
265 return qFields_[ns_-1];
323 {
return isAllocated_; }
331 { blockPtr_ = █ }
334 #ifndef RPG_PROPAGATOR_TPP
Dynamic array on the GPU device with aligned data.
Description of a regular grid of points in a periodic domain.
Field of real double precision values on an FFT mesh.
Template for propagator classes.
void setIsSolved(bool isSolved)
const Propagator< D > & partner() const
const Propagator< D > & source(int id) const
Block within a branched polymer.
MDE solver for one-direction of one block.
RField< D > CField
Monomer concentration field type.
Block< D > & block()
Get the associated Block object by reference.
int ns() const
Get the number of chain contour points.
RField< D > Field
Generic field (function of position).
void solve()
Solve the modified diffusion equation (MDE) for this block.
DeviceArray< cudaReal > const & qAll()
Return the full array of q-fields (after propagator is solved).
double computeQ()
Compute and return partition function for the molecule.
void allocate(int ns, const Mesh< D > &mesh)
Allocate propagator arrays.
RField< D > const & head()
Return q-field at beginning of block (initial condition).
void computeHead()
Compute initial QField at head from tail QFields of sources.
RField< D > const & tail() const
Return q-field at end of block (after propagator is solved).
RField< D > const & q(int i) const
Return const q-field at specified step by reference (after solving).
RField< D > WField
Chemical potential field type.
bool isAllocated() const
Has memory been allocated for this propagator?
void setBlock(Block< D > &block)
Associate this propagator with a block.
RField< D > QField
Propagator q-field type.
void reallocate(int ns)
Reallocate memory used by this propagator.
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.