11#include <pscf/chem/SolventDescriptor.h>
12#include <rpg/solvers/Propagator.h>
13#include <prdc/cuda/RField.h>
16 template <
int D>
class Mesh;
131 cField_.allocate(meshPtr_->dimensions());
Description of a regular grid of points in a periodic domain.
int size() const
Get total number of grid points.
Field of real double precision values on an FFT mesh.
Solver and descriptor for a solvent species.
RField< D > const & cField() const
Get the monomer concentration field for this solvent.
void compute(RField< D > const &wField, double phiTot=1.0)
Compute monomer concentration field, q and phi and/or mu.
void allocate()
Allocate internal data containers.
void associate(Mesh< D > const &mesh)
Associate this object with a mesh.
Descriptor for a solvent species.
double size_
Size of this block = volume / monomer reference volume.
double size() const
Get the size (number of monomers) in this solvent.
int monomerId() const
Get the monomer type id.
int monomerId_
Identifier for the associated monomer type.
double phi() const
Get the overall volume fraction for this species.
Ensemble ensemble_
Statistical ensemble for this species (open or closed).
Ensemble ensemble()
Get the statistical ensemble for this species (open or closed).
double phi_
Volume fraction, set by either setPhi or a compute function.
double mu_
Chemical potential, set by either setPhi or a compute function.
double q_
Partition function, set in subclass by a compute function.
double mu() const
Get the chemical potential for this species (units kT=1).
double q() const
Get the molecular partition function for this species.
#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.