PSCF v1.2
EinsteinCrystalPerturbation

EinsteinCrystalPerturbation class templates in namespaces Rpc and Rpg are designed to enable use of Einstein crystal method of computing free energies by thermodynamic integration.

See also

Theory

The EinsteinCrystalPerturbation class defines a perturbation for a system with two types of monomer (nMonomer = 2) of the form

\[ H_{1} = (1-\lambda)[ H_{{\rm EC}} - H_{0} ] \]

in which \( \lambda \) is a parameter in the range \( \lambda \in [0, 1] \), \( H_{0} \) is the standard unperturbed Hamiltonian and \( H_{{\rm EC}} \) is the Einstein crystal Hamiltonian, described below. Adding this to the unperturbed Hamiltonian gives a total Hamiltonian

\[ H = \lambda H_{0} + (1-\lambda) H_{{\rm EC}} \]

that interpolates linearly between the Einstein crystal Hamiltonian and unperturbed Hamiltonians, giving the Einstein crystal in the limit \( \lambda = 0 \) and recovering the unperturbed standared model in the limit \( \lambda = 1 \).

The Einstein crystal Hamiltonian for a standard AB system with two monomer types and chi(0,0) = chi(1,1) = 0 is defined as an integral

\[ H_{{\rm EC}} = \int d{\bf r} \frac{1}{v \epsilon} [ W_{-}({\bf r}) - W_{-}^{({\bf r})}({\bf r}) ]^2 \]

in which \( W_{-}({\bf r}) = [w_{0}({\bf r}) - w_{1}({\bf r})]/2 \) is the exchange field, \( W_{-}^{({\bf r})}({\bf r}) \) is a "reference" exchange field configuration, and \( \epsilon \) is a user-supplied parameter that controls the strength of fluctuations about the reference field. By default, if the user does not supply a value for \( \epsilon \), it is set equal to \( \chi \).

The current version of the Einstein crystal method can also be applied to systems with more than two types of monomer if the projected chi matrix has no positive eigenvalues. In this more general situation, the Einstein crystal Hamiltonian is

\[ H_{{\rm EC}} = \sum_{i=0}^{M-2} \int d{\bf r} \frac{M}{2 v \epsilon_{i}} [ W_{i}({\bf r}) - W_{i}^{({\bf r})}({\bf r}) ]^2 \]

in which \( M \) is the number of monomer types (i.e., nMonomer), \( W_{i}({\bf r}) \) is the field component associated with eigenvector \( i \) of the projected \( \chi \) matrix, \( W_{i}^{({\bf r})}({\bf r}) \) is the corresponding component of the "reference" field configuration, and \( \epsilon_{0}, \ldots \epsilon_{M-2} \) are parameters that controls the strength of fluctuations about the reference field.
By default, if the user does not provide values for the \( M - 1 \) required \( \epsilon \) parameters, then \( \epsilon_{i} = -\lambda_{i} \) for all \( i = 0, \ldots, M -2 \), where \( \lambda_{i} \) is eigenvalue \( i \) of the projected chi matrix. This generalized definition, and default values for parameters, includes the description of a standard AB system that is given above as a special case, with \( \epsilon = \epsilon_{0} \).

The reference field configuration must be read from a file during setup of a simulation, and so the name of that file must be provided as parameter in the parameter file.

Parameter File

The parameter file format for this class is shown below:

EinsteinCrystalPerturbation{
lambda real
epsilon* Array[ real ]
referenceFieldFile string
}
RT real(CT const &a)
Return the real part of a complex number.

Note that the epsilon parameter array is optional. If this array is absent, \( \epsilon_i = -\lambda_{i} \) by default, which reduces to a \( \epsilon_{0} = \chi \) for a standard AB system. Meanings of these parameters are described briefly below:

Label Description
lambda charging parameter in range 0 [Einstein Crystal] to 1 [unperturbed]
epsilon array of values for coefficients used in harmonic penalty (optional)
referenceFieldName name of file containing reference field configuration