13#include <pscf/solvers/MixtureTmpl.h>
14#include <pscf/inter/Interaction.h>
15#include <pscf/chem/Monomer.h>
16#include <util/containers/DArray.h>
17#include <util/containers/FArray.h>
22 template <
int D>
class Mesh;
25 template <
int D>
class FFT;
134 void setKuhn(
int monomerId,
double kuhn);
168 double phiTot = 1.0);
216 double stress(
int n)
const;
285 #ifndef RPC_MIXTURE_TPP
286 extern template class Mixture<1>;
287 extern template class Mixture<2>;
288 extern template class Mixture<3>;
Description of a regular grid of points in a periodic domain.
A mixture of polymer and solvent species.
Polymer & polymer(int id)
Monomer const & monomer(int id) const
Solvent & solvent(int id)
Fourier transform wrapper.
Field of real double precision values on an FFT mesh.
Base template for UnitCell<D> classes, D=1, 2 or 3.
Solver for a mixture of polymers and solvents.
void associate(Mesh< D > const &mesh, FFT< D > const &fft, UnitCell< D > const &cell)
Create an association with a mesh and fft, and allocate memory.
bool isCanonical()
Is this mixture being treated in canonical ensemble?
void compute(DArray< RField< D > > const &wFields, DArray< RField< D > > &cFields, double phiTot=1.0)
Compute partition functions and concentrations.
void allocate()
Allocate required internal memory for all solvers.
void readParameters(std::istream &in)
Read all parameters and initialize.
double stress(int n) const
Get derivative of free energy w/ respect to a unit cell parameter.
void setKuhn(int monomerId, double kuhn)
Reset statistical segment length for one monomer type.
void computeStress(double phiTot=1.0)
Compute derivatives of free energy w/ respect to cell parameters.
void createBlockCRGrid(DArray< RField< D > > &blockCFields) const
Get c-fields for all blocks and solvents as array of r-grid fields.
void clearUnitCellData()
Clear all data in solvers that depends on the unit cell parameters.
Dynamically allocatable contiguous array template.
A fixed size (static) contiguous array template.
ScalarParam< Type > & read(std::istream &in, const char *label, Type &value)
Add and read a new required ScalarParam < Type > object.
void setClassName(const char *className)
Set class name string.
ScalarParam< Type > & readOptional(std::istream &in, const char *label, Type &value)
Add and read a new optional ScalarParam < Type > object.
#define UTIL_CHECK(condition)
Assertion macro suitable for serial or parallel production code.
#define UTIL_ASSERT(condition)
Assertion macro suitable for debugging serial or parallel code.
Fields and FFTs for periodic boundary conditions (CPU)
PSCF package top-level namespace.