compute stress/atom command
compute centroid/stress/atom command
Syntax
compute ID group-ID style temp-ID keyword ...
ID, group-ID are documented in compute command
style = stress/atom or centroid/stress/atom
temp-ID = ID of compute that calculates temperature, can be NULL if not needed
zero or more keywords may be appended
keyword = ke or pair or bond or angle or dihedral or improper or kspace or fix or virial
Examples
compute 1 mobile stress/atom NULL
compute 1 mobile stress/atom myRamp
compute 1 all stress/atom NULL pair bond
compute 1 all centroid/stress/atom NULL bond dihedral improper
Description
Define a computation that computes per-atom stress tensor for each
atom in a group. In case of compute stress/atom, the tensor for
each atom is symmetric with 6 components and is stored as a 6-element
vector in the following order:
The stress tensor for atom
The first term is a kinetic energy contribution for atom
In case of compute stress/atom, the virial contribution is:
The first term is a pairwise energy contribution where
In case of compute centroid/stress/atom, the virial contribution is:
As with compute stress/atom, the first, second, third, fourth and
fifth terms are pairwise, bond, angle, dihedral and improper
contributions, but instead of assigning the virial contribution
equally to each atom, only the force
If no extra keywords are listed, the kinetic contribution and all of the virial contribution terms are included in the per-atom stress tensor. If any extra keywords are listed, only those terms are summed to compute the tensor. The virial keyword means include all terms except the kinetic energy ke.
Note that the stress for each atom is due to its interaction with all other atoms in the simulation, not just with other atoms in the group.
Details of how compute stress/atom obtains the virial for individual
atoms for either pairwise or many-body potentials, and including the
effects of periodic boundary conditions is discussed in
(Thompson). The basic idea for many-body
potentials is to treat each component of the force computation between
a small cluster of atoms in the same manner as in the formula above
for bond, angle, dihedral, etc interactions. Namely the quantity
Details of how compute centroid/stress/atom obtains the virial for
individual atoms are given in (Surblys2019) and
(Surblys2021), where the
idea is that the virial of the atom
The dihedral_style charmm style calculates pairwise interactions between 1-4 atoms. The virial contribution of these terms is included in the pair virial, not the dihedral virial.
The KSpace contribution is calculated using the method in (Heyes) for the Ewald method and by the methodology described in (Sirk) for PPPM. The choice of KSpace solver is specified by the kspace_style pppm command. Note that for PPPM, the calculation requires 6 extra FFTs each timestep that per-atom stress is calculated. Thus it can significantly increase the cost of the PPPM calculation if it is needed on a large fraction of the simulation timesteps.
The temp-ID argument can be used to affect the per-atom velocities used in the kinetic energy contribution to the total stress. If the kinetic energy is not included in the stress, than the temperature compute is not used and can be specified as NULL. If the kinetic energy is included and you wish to use atom velocities as-is, then temp-ID can also be specified as NULL. If desired, the specified temperature compute can be one that subtracts off a bias to leave each atom with only a thermal velocity to use in the formula above, e.g. by subtracting a background streaming velocity. See the doc pages for individual compute commands to determine which ones include a bias.
Note that as defined in the formula, per-atom stress is the negative of the per-atom pressure tensor. It is also really a stress*volume formulation, meaning the computed quantity is in units of pressure*volume. It would need to be divided by a per-atom volume to have units of stress (pressure), but an individual atom’s volume is not well defined or easy to compute in a deformed solid or a liquid. See the compute voronoi/atom command for one possible way to estimate a per-atom volume.
Thus, if the diagonal components of the per-atom stress tensor are
summed for all atoms in the system and the sum is divided by
These lines in an input script for a 3d system should yield that result. I.e. the last 2 columns of thermo output will be the same:
compute peratom all stress/atom NULL
compute p all reduce sum c_peratom[1] c_peratom[2] c_peratom[3]
variable press equal -(c_p[1]+c_p[2]+c_p[3])/(3*vol)
thermo_style custom step temp etotal press v_press
Note
The per-atom stress does not include any Lennard-Jones tail corrections to the pressure added by the pair_modify tail yes command, since those are contributions to the global system pressure.
The compute stress/atom can be used in a number of ways. Here is an example to compute a 1-d pressure profile in x-direction across the complete simulation box. You will need to adjust the number of bins and the selections for time averaging to your specific simulation. This assumes that the dimensions of the simulation cell does not change.
# set number of bins
variable nbins index 20
variable fraction equal 1.0/v_nbins
# define bins as chunks
compute cchunk all chunk/atom bin/1d x lower ${fraction} units reduced
compute stress all stress/atom NULL
# apply conversion to pressure early since we have no variable style for processing chunks
variable press atom -(c_stress[1]+c_stress[2]+c_stress[3])/(3.0*vol*${fraction})
compute binpress all reduce/chunk cchunk sum v_press
fix avg all ave/time 10 40 400 c_binpress mode vector file ave_stress.txt
Output info
Compute stress/atom calculates a per-atom array with 6 columns, which can be accessed by indices 1-6 by any command that uses per-atom values from a compute as input. Compute centroid/stress/atom produces a per-atom array with 9 columns, but otherwise can be used in an identical manner to compute stress/atom. See the Howto output page for an overview of LAMMPS output options.
The ordering of the 6 columns for stress/atom is as follows: xx, yy, zz, xy, xz, yz. The ordering of the 9 columns for centroid/stress/atom is as follows: xx, yy, zz, xy, xz, yz, yx, zx, zy.
The per-atom array values will be in pressure*volume units as discussed above.
Restrictions
Currently, compute centroid/stress/atom does not support pair styles with many-body interactions (EAM is an exception, since its computations are performed pairwise), nor granular pair styles with pairwise forces which are not aligned with the vector between the pair of particles. All bond styles are supported. All angle, dihedral, improper styles are supported with the exception of INTEL and KOKKOS variants of specific styles. It also does not support models with long-range Coulombic or dispersion forces, i.e. the kspace_style command in LAMMPS. It also does not implement the following fixes which add rigid-body constraints: fix rigid/* and the OpenMP accelerated version of fix rigid/small, while all other fix rigid/*/small are implemented.
LAMMPS will generate an error if one of these options is included in your model. Extension of centroid stress calculations to these force and fix styles is planned for the future.
Default
By default the compute includes contributions from the keywords:
ke pair bond angle dihedral improper kspace fix
(Heyes) Heyes, Phys Rev B, 49, 755 (1994).
(Sirk) Sirk, Moore, Brown, J Chem Phys, 138, 064505 (2013).
(Thompson) Thompson, Plimpton, Mattson, J Chem Phys, 131, 154107 (2009).
(Surblys2019) Surblys, Matsubara, Kikugawa, Ohara, Phys Rev E, 99, 051301(R) (2019).
(Surblys2021) Surblys, Matsubara, Kikugawa, Ohara, J Appl Phys 130, 215104 (2021).