lammps/doc/html/_sources/fix_gld.txt

179 lines
6.6 KiB
Plaintext
Raw Normal View History

.. index:: fix gld
fix gld command
===============
Syntax
""""""
.. parsed-literal::
fix ID group-ID gld Tstart Tstop N_k seed series c_1 tau_1 ... c_N_k tau_N_k keyword values ...
* ID, group-ID are documented in :doc:`fix <fix>` command
* gld = style name of this fix command
* Tstart,Tstop = desired temperature at start/end of run (temperature units)
* N_k = number of terms in the Prony series representation of the memory kernel
* seed = random number seed to use for white noise (positive integer)
* series = *pprony* is presently the only available option
* c_k = the weight of the kth term in the Prony series (mass per time units)
* tau_k = the time constant of the kth term in the Prony series (time units)
* zero or more keyword/value pairs may be appended
.. parsed-literal::
keyword = *frozen* or *zero*
*frozen* value = *no* or *yes*
*no* = initialize extended variables using values drawn from equilibrium distribution at Tstart
*yes* = initialize extended variables to zero (i.e., from equilibrium distribution at zero temperature)
*zero* value = *no* or *yes*
*no* = do not set total random force to zero
*yes* = set total random force to zero
Examples
""""""""
.. parsed-literal::
fix 1 all gld 1.0 1.0 2 82885 pprony 0.5 1.0 1.0 2.0 frozen yes zero yes
fix 3 rouse gld 7.355 7.355 4 48823 pprony 107.1 0.02415 186.0 0.04294 428.6 0.09661 1714 0.38643
Description
"""""""""""
Applies Generalized Langevin Dynamics to a group of atoms, as
described in :ref:`(Baczewski) <Baczewski>`. This is intended to model the
effect of an implicit solvent with a temporally non-local dissipative
force and a colored Gaussian random force, consistent with the
Fluctuation-Dissipation Theorem. The functional form of the memory
kernel associated with the temporally non-local force is constrained
to be a Prony series.
.. note::
While this fix bears many similarities to :doc:`fix langevin <fix_langevin>`, it has one significant
difference. Namely, :doc:`fix gld <fix_gld>` performs time integration,
whereas :doc:`fix langevin <fix_langevin>` does NOT. To this end, the
specification of another fix to perform time integration, such as :doc:`fix nve <fix_nve>`, is NOT necessary.
With this fix active, the force on the *j*\ th atom is given as
.. image:: Eqs/fix_gld1.jpg
:align: center
Here, the first term is representative of all conservative (pairwise,
bonded, etc) forces external to this fix, the second is the temporally
non-local dissipative force given as a Prony series, and the third is
the colored Gaussian random force.
The Prony series form of the memory kernel is chosen to enable an
extended variable formalism, with a number of exemplary mathematical
features discussed in :ref:`(Baczewski) <Baczewski>`. In particular, 3N_k
extended variables are added to each atom, which effect the action of
the memory kernel without having to explicitly evaluate the integral
over time in the second term of the force. This also has the benefit
of requiring the generation of uncorrelated random forces, rather than
correlated random forces as specified in the third term of the force.
Presently, the Prony series coefficients are limited to being greater
than or equal to zero, and the time constants are limited to being
greater than zero. To this end, the value of series MUST be set to
*pprony*\ , for now. Future updates will allow for negative coefficients
and other representations of the memory kernel. It is with these
updates in mind that the series option was included.
The units of the Prony series coefficients are chosen to be mass per
time to ensure that the numerical integration scheme stably approaches
the Newtonian and Langevin limits. Details of these limits, and the
associated numerical concerns are discussed in
:ref:`(Baczewski) <Baczewski>`.
The desired temperature at each timestep is ramped from *Tstart* to
*Tstop* over the course of the next run.
The random # *seed* must be a positive integer. A Marsaglia random
number generator is used. Each processor uses the input seed to
generate its own unique seed and its own stream of random
numbers. Thus the dynamics of the system will not be identical on two
runs on different numbers of processors.
----------
The keyword/value option pairs are used in the following ways.
The keyword *frozen* can be used to specify how the extended variables
associated with the GLD memory kernel are initialized. Specifying no
(the default), the initial values are drawn at random from an
equilibrium distribution at *Tstart*\ , consistent with the
Fluctuation-Dissipation Theorem. Specifying yes, initializes the
extended variables to zero.
The keyword *zero* can be used to eliminate drift due to the
thermostat. Because the random forces on different atoms are
independent, they do not sum exactly to zero. As a result, this fix
applies a small random force to the entire system, and the
center-of-mass of the system undergoes a slow random walk. If the
keyword *zero* is set to *yes*\ , the total random force is set exactly
to zero by subtracting off an equal part of it from each atom in the
group. As a result, the center-of-mass of a system with zero initial
momentum will not drift over time.
----------
**Restart, run start/stop, minimize info:**
The instantaneous values of the extended variables are written to
:doc:`binary restart files <restart>`. Because the state of the random
number generator is not saved in restart files, this means you cannot
do "exact" restarts with this fix, where the simulation continues on
the same as if no restart had taken place. However, in a statistical
sense, a restarted simulation should produce the same behavior.
None of the :doc:`fix_modify <fix_modify>` options are relevant to this
fix. No global or per-atom quantities are stored by this fix for
access by various :ref:`output commands <howto_15>`.
This fix can ramp its target temperature over multiple runs, using the
*start* and *stop* keywords of the :doc:`run <run>` command. See the
:doc:`run <run>` command for details of how to do this.
This fix is not invoked during :doc:`energy minimization <minimize>`.
Restrictions
""""""""""""
This fix is part of the MISC package. It is only enabled if LAMMPS
was built with that package. See the :ref:`Making LAMMPS <start_3>` section for more info.
Related commands
""""""""""""""""
:doc:`fix langevin <fix_langevin>`, :doc:`fix viscous <fix_viscous>`,
:doc:`pair_style dpd/tstat <pair_dpd>`
Default
"""""""
The option defaults are frozen = no, zero = no.
----------
.. _Baczewski:
**(Baczewski)** A.D. Baczewski and S.D. Bond, J. Chem. Phys. 139, 044107 (2013).
.. _lws: http://lammps.sandia.gov
.. _ld: Manual.html
.. _lc: Section_commands.html#comm