# compute orientorder/atom command

# compute orientorder/atom/kk command

## Syntax

```
compute ID group-ID orientorder/atom keyword values ...
```

ID, group-ID are documented in compute command

orientorder/atom = style name of this compute command

one or more keyword/value pairs may be appended

keyword =

*cutoff*or*nnn*or*degrees*or*components*or*chunksize**cutoff*value = distance cutoff*nnn*value = number of nearest neighbors*degrees*values = nlvalues, l1, l2,...*wl*value = yes or no*wl/hat*value = yes or no*components*value = ldegree*chunksize*value = number of atoms in each pass

## Examples

```
compute 1 all orientorder/atom
compute 1 all orientorder/atom degrees 5 4 6 8 10 12 nnn NULL cutoff 1.5
compute 1 all orientorder/atom wl/hat yes
compute 1 all orientorder/atom components 6
```

## Description

Define a computation that calculates a set of bond-orientational order parameters \(Q_l\) for each atom in a group. These order parameters were introduced by Steinhardt et al. as a way to characterize the local orientational order in atomic structures. For each atom, \(Q_l\) is a real number defined as follows:

The first equation defines the spherical harmonic order parameters.
These are complex number components of the 3D analog of the 2D order
parameter \(q_n\), which is implemented as LAMMPS compute
hexorder/atom.
The summation is over the *nnn* nearest
neighbors of the central atom.
The angles theta and phi are the standard spherical polar angles
defining the direction of the bond vector \(r_{ij}\).
The second equation defines \(Q_l\), which is a
rotationally invariant non-negative amplitude obtained by summing
over all the components of degree *l*.

The optional keyword *cutoff* defines the distance cutoff
used when searching for neighbors. The default value, also
the maximum allowable value, is the cutoff specified
by the pair style.

The optional keyword *nnn* defines the number of nearest
neighbors used to calculate \(Q_l\). The default value is 12.
If the value is NULL, then all neighbors up to the
specified distance cutoff are used.

The optional keyword *degrees* defines the list of order parameters to
be computed. The first argument *nlvalues* is the number of order
parameters. This is followed by that number of non-negative integers giving the
degree of each order parameter. Because \(Q_2\) and all odd-degree order
parameters are zero for atoms in cubic crystals (see
Steinhardt), the default order parameters are \(Q_4\),
\(Q_6\), \(Q_8\), \(Q_{10}\), and \(Q_{12}\). For the FCC
crystal with *nnn* =12, \(Q_4 = \sqrt{\frac{7}{192}} = 0.19094...\).
The numerical values of all order
parameters up to \(Q_12\) for a range of commonly encountered
high-symmetry structures are given in Table I of Mickel et al.,
and these can be reproduced with this compute.

The optional keyword *wl* will output the third-order invariants \(W_l\)
(see Eq. 1.4 in Steinhardt) for the same degrees as
for the \(Q_l\) parameters. For the FCC crystal with *nnn* =12,
\(W_4\) = -sqrt(14/143).(49/4096)/Pi^1.5 = -0.0006722136…

The optional keyword *wl/hat* will output the normalized third-order
invariants \(\hat{W}_l\) (see Eq. 2.2 in Steinhardt)
for the same degrees as for the \(Q_l\) parameters. For the FCC crystal
with *nnn* =12, \(\hat{W}_4 = -\frac{7}{3} \sqrt{\frac{2}{429}} = -0.159317...\)
The numerical
values of \(\hat{W}_l\) for a range of commonly encountered high-symmetry
structures are given in Table I of Steinhardt, and these
can be reproduced with this keyword.

The optional keyword *components* will output the components of the
normalized complex vector \(\bar{Y}_{lm}\) of degree *ldegree*, which must be
explicitly included in the keyword *degrees*. This option can be used
in conjunction with compute coord_atom to
calculate the ten Wolde’s criterion to identify crystal-like
particles, as discussed in ten Wolde.

The optional keyword *chunksize* is only applicable when using the
the KOKKOS package and is ignored otherwise. This keyword controls
the number of atoms in each pass used to compute the bond-orientational
order parameters and is used to avoid running out of memory. For example
if there are 4000 atoms in the simulation and the *chunksize*
is set to 2000, the parameter calculation will be broken up
into two passes.

The value of \(Q_l\) is set to zero for atoms not in the
specified compute group, as well as for atoms that have less than
*nnn* neighbors within the distance cutoff, unless *nnn* is NULL.

The neighbor list needed to compute this quantity is constructed each time the calculation is performed (i.e. each time a snapshot of atoms is dumped). Thus it can be inefficient to compute/dump this quantity too frequently.

Note

If you have a bonded system, then the settings of special_bonds command can remove pairwise interactions between atoms in the same bond, angle, or dihedral. This is the default setting for the special_bonds command, and means those pairwise interactions do not appear in the neighbor list. Because this fix uses the neighbor list, it also means those pairs will not be included in the order parameter. This difficulty can be circumvented by writing a dump file, and using the rerun command to compute the order parameter for snapshots in the dump file. The rerun script can use a special_bonds command that includes all pairs in the neighbor list.

Styles with a *gpu*, *intel*, *kk*, *omp*, or *opt* suffix are
functionally the same as the corresponding style without the suffix.
They have been optimized to run faster, depending on your available
hardware, as discussed on the Speed packages doc
page. The accelerated styles take the same arguments and should
produce the same results, except for round-off and precision issues.

These accelerated styles are part of the GPU, USER-INTEL, KOKKOS, USER-OMP and OPT packages, respectively. They are only enabled if LAMMPS was built with those packages. See the Build package doc page for more info.

You can specify the accelerated styles explicitly in your input script by including their suffix, or you can use the -suffix command-line switch when you invoke LAMMPS, or you can use the suffix command in your input script.

See the Speed packages doc page for more instructions on how to use the accelerated styles effectively.

**Output info:**

This compute calculates a per-atom array with *nlvalues* columns,
giving the \(Q_l\) values for each atom, which are real numbers on the
range \(0 <= Q_l <= 1\).

If the keyword *wl* is set to yes, then the \(W_l\) values for each
atom will be added to the output array, which are real numbers.

If the keyword *wl/hat* is set to yes, then the \(\hat{W}_l\)
values for each atom will be added to the output array, which are real numbers.

If the keyword *components* is set, then the real and imaginary parts
of each component of (normalized) \(\bar{Y}_{lm}\) will be added to the
output array in the following order: \(Re(\bar{Y}_{-m}) Im(\bar{Y}_{-m})
Re(\bar{Y}_{-m+1}) Im(\bar{Y}_{-m+1}) ... Re(\bar{Y}_m) Im(\bar{Y}_m)\). This
way, the per-atom array will have a total of *nlvalues*+2*(2*l*+1)
columns.

These values can be accessed by any command that uses per-atom values from a compute as input. See the Howto output doc page for an overview of LAMMPS output options.

## Restrictions

none

## Default

The option defaults are *cutoff* = pair style cutoff, *nnn* = 12,
*degrees* = 5 4 6 8 10 12 i.e. \(Q_4\), \(Q_6\), \(Q_8\), \(Q_{10}\), and \(Q_{12}\),
*wl* = no, *wl/hat* = no, *components* off, and *chunksize* = 2000

**(Steinhardt)** P. Steinhardt, D. Nelson, and M. Ronchetti,
Phys. Rev. B 28, 784 (1983).

**(Mickel)** W. Mickel, S. C. Kapfer, G. E. Schroeder-Turkand, K. Mecke,
J. Chem. Phys. 138, 044501 (2013).

**(tenWolde)** P. R. ten Wolde, M. J. Ruiz-Montero, D. Frenkel,
J. Chem. Phys. 104, 9932 (1996).