12#include <prdc/cuda/RField.h>
13#include <pscf/solvers/PolymerTmpl.h>
14#include <util/containers/FArray.h>
19 template <
int D>
class UnitCell;
24 template <
int D>
class WaveList;
109 double phiTot = 1.0);
153 {
return stress_[n]; }
155 #ifndef RPG_POLYMER_TPP
Descriptor and MDE solver for an acyclic block polymer.
virtual void solve(double phiTot=1.0)
Field of real double precision values on an FFT mesh.
Descriptor and solver for a branched polymer species.
void computeStress()
Compute stress from a polymer chain, needs a pointer to basis.
void setMu(double mu)
Set the mu (chemical potential) for this species.
void compute(DArray< RField< D > > const &wFields, double phiTot=1.0)
Compute solution to MDE and block concentrations.
void setPhi(double phi)
Set the phi (volume fraction) for this species.
void setNParams(int nParams)
Store the number of lattice parameters in the unit cell.
double stress(int n)
Get derivative of free energy w/ respect to a unit cell parameter.
PolymerTmpl< Block< D > > Base
Alias for base class.
double phi() const
Get the overall volume fraction for this species.
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 mu() const
Get the chemical potential for this species (units kT=1).
Dynamically allocatable contiguous array template.
A fixed size (static) contiguous array template.
void setClassName(const char *className)
Set class name string.
Fields, FFTs, and utilities for periodic boundary conditions (CUDA)
Periodic fields and crystallography.
PSCF package top-level namespace.
Utility classes for scientific computation.