# fix ffl command

## Syntax

fix ID id-group ffl tau Tstart Tstop seed [flip-type]

• ID, group-ID are documented in fix command

• ffl = style name of this fix command

• tau = thermostat parameter (positive real)

• Tstart, Tstop = temperature ramp during the run

• seed = random number seed to use for generating noise (positive integer)

• one more value may be appended

flip-type  = determines the flipping type, can be chosen between rescale - no_flip - hard - soft, if no flip type is given, rescale will be chosen by default


## Examples

fix 3 boundary ffl 10 300 300 31415
fix 1 all ffl 100 500 500 9265 soft


## Description

Apply a Fast-Forward Langevin Equation (FFL) thermostat as described in (Hijazi). Contrary to fix langevin, this fix performs both thermostatting and evolution of the Hamiltonian equations of motion, so it should not be used together with fix nve – at least not on the same atom groups.

The time-evolution of a single particle undergoing Langevin dynamics is described by the equations

$\begin{equation} \frac {dq}{dt} = \frac{p}{m}, \end{equation}$
$\begin{equation} \frac {dp}{dt} = -\gamma p + W + F, \end{equation}$

where $$F$$ is the physical force, $$\gamma$$ is the friction coefficient, and $$W$$ is a Gaussian random force.

The friction coefficient is the inverse of the thermostat parameter : $$\gamma = 1/\tau$$, with $$\tau$$ the thermostat parameter tau. The thermostat parameter is given in the time units, $$\gamma$$ is in inverse time units.

Equilibrium sampling a temperature T is obtained by specifying the target value as the Tstart and Tstop arguments, so that the internal constants depending on the temperature are computed automatically.

The random number 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 flipping type flip-type can be chosen between 4 types described in (Hijazi). The flipping operation occurs during the thermostatting step and it flips the momenta of the atoms. If no_flip is chosen, no flip will be executed and the integration will be the same as a standard Langevin thermostat (Bussi). The other flipping types are : rescale - hard - soft.

Restart, fix_modify, output, run start/stop, minimize info:

The instantaneous values of the extended variables are written to binary restart files. 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. Note however that you should use a different seed each time you restart, otherwise the same sequence of random numbers will be used each time, which might lead to stochastic synchronization and subtle artifacts in the sampling.

This fix can ramp its target temperature over multiple runs, using the start and stop keywords of the run command. See the run command for details of how to do this.

The fix_modify energy option is supported by this fix to add the energy change induced by Langevin thermostatting to the system’s potential energy as part of thermodynamic output.

This fix computes a global scalar which can be accessed by various output commands. The scalar is the cumulative energy change due to this fix. The scalar value calculated by this fix is “extensive”.

## Restrictions

In order to perform constant-pressure simulations please use fix press/berendsen, rather than fix npt, to avoid duplicate integration of the equations of motion.

This fix is part of the USER-MISC package. It is only enabled if LAMMPS was built with that package. See the Build package doc page for more info.