keyword = *mesh* or *order* or *order/disp* or *mix/disp* or *overlap* or *minorder* or *force* or *gewald* or *gewald/disp* or *slab* or (nozforce* or *compute* or *cutoff/adjust* or *fftbench* or *collective* or *diff* or *kmax/ewald* or *force/disp/real* or *force/disp/kspace* or *splittol* or *disp/auto*\ :l
*mesh* value = x y z
x,y,z = grid size in each dimension for long-range Coulombics
*mesh/disp* value = x y z
x,y,z = grid size in each dimension for 1/r^6 dispersion
*order* value = N
N = extent of Gaussian for PPPM or MSM mapping of charge to grid
*order/disp* value = N
N = extent of Gaussian for PPPM mapping of dispersion term to grid
*mix/disp* value = *pair* or *geom* or *none*
*overlap* = *yes* or *no* = whether the grid stencil for PPPM is allowed to overlap into more than the nearest-neighbor processor
*minorder* value = M
M = min allowed extent of Gaussian when auto-adjusting to minimize grid communication
*force* value = accuracy (force units)
*gewald* value = rinv (1/distance units)
rinv = G-ewald parameter for Coulombics
*gewald/disp* value = rinv (1/distance units)
rinv = G-ewald parameter for dispersion
*slab* value = volfactor or *nozforce*
volfactor = ratio of the total extended volume used in the
2d approximation compared with the volume of the simulation domain
*nozforce* turns off kspace forces in the z direction
*compute* value = *yes* or *no*
*cutoff/adjust* value = *yes* or *no*
*pressure/scalar* value = *yes* or *no*
*fftbench* value = *yes* or *no*
*collective* value = *yes* or *no*
*diff* value = *ad* or *ik* = 2 or 4 FFTs for PPPM in smoothed or non-smoothed mode
*kmax/ewald* value = kx ky kz
kx,ky,kz = number of Ewald sum kspace vectors in each dimension
*force/disp/real* value = accuracy (force units)
*force/disp/kspace* value = accuracy (force units)
*splittol* value = tol
tol = relative size of two eigenvalues (see discussion below)
*disp/auto* value = yes or no
Examples
""""""""
.. parsed-literal::
kspace_modify mesh 24 24 30 order 6
kspace_modify slab 3.0
Description
"""""""""""
Set parameters used by the kspace solvers defined by the
:doc:`kspace_style <kspace_style>` command. Not all parameters are
relevant to all kspace styles.
The *mesh* keyword sets the grid size for kspace style *pppm* or
*msm*\ . In the case of PPPM, this is the FFT mesh, and each dimension
must be factorizable into powers of 2, 3, and 5. In the case of MSM,
this is the finest scale real-space mesh, and each dimension must be
factorizable into powers of 2. When this option is not set, the PPPM
or MSM solver chooses its own grid size, consistent with the
user-specified accuracy and pairwise cutoff. Values for x,y,z of
0,0,0 unset the option.
The *mesh/disp* keyword sets the grid size for kspace style
*pppm/disp*\ . This is the FFT mesh for long-range dispersion and ach
dimension must be factorizable into powers of 2, 3, and 5. When this
option is not set, the PPPM solver chooses its own grid size,
consistent with the user-specified accuracy and pairwise cutoff.
Values for x,y,z of 0,0,0 unset the option.
The *order* keyword determines how many grid spacings an atom's charge
extends when it is mapped to the grid in kspace style *pppm* or *msm*\ .
The default for this parameter is 5 for PPPM and 8 for MSM, which
means each charge spans 5 or 8 grid cells in each dimension,
respectively. For the LAMMPS implementation of MSM, the order can
range from 4 to 10 and must be even. For PPPM, the minimum allowed
setting is 2 and the maximum allowed setting is 7. The larger the
value of this parameter, the smaller that LAMMPS will set the grid
size, to achieve the requested accuracy. Conversely, the smaller the
order value, the larger the grid size will be. Note that there is an
inherent trade-off involved: a small grid will lower the cost of FFTs
or MSM direct sum, but a larger order parameter will increase the cost
of interpolating charge/fields to/from the grid.
The *order/disp* keyword determines how many grid spacings an atom's
dispersion term extends when it is mapped to the grid in kspace style
*pppm/disp*\ . It has the same meaning as the *order* setting for
Coulombics.
The *overlap* keyword can be used in conjunction with the *minorder*
keyword with the PPPM styles to adjust the amount of communication
that occurs when values on the FFT grid are exchangeed between
processors. This communication is distinct from the communication
inherent in the parallel FFTs themselves, and is required because
processors interpolate charge and field values using grid point values
owned by neighboring processors (i.e. ghost point communication). If
the *overlap* keyword is set to *yes* then this communication is
allowed to extend beyond nearest-neighbor processors, e.g. when using
lots of processors on a small problem. If it is set to *no* then the
communication will be limited to nearest-neighbor processors and the
*order* setting will be reduced if necessary, as explained by the
*minorder* keyword discussion. The *overlap* keyword is always set to
*yes* in MSM.
The *minorder* keyword allows LAMMPS to reduce the *order* setting if
necessary to keep the communication of ghost grid point limited to
exchanges between nearest-neighbor processors. See the discussion of
the *overlap* keyword for details. If the *overlap* keyword is set to
*yes*\ , which is the default, this is never needed. If it set to *no*
and overlap occurs, then LAMMPS will reduce the order setting, one
step at a time, until the ghost grid overlap only extends to nearest
neighbor processors. The *minorder* keyword limits how small the
*order* setting can become. The minimum allowed value for PPPM is 2,
which is the default. If *minorder* is set to the same value as
*order* then no reduction is allowed, and LAMMPS will generate an
error if the grid communcation is non-nearest-neighbor and *overlap*
is set to *no*\ . The *minorder* keyword is not currently supported in
MSM.
The PPPM order parameter may be reset by LAMMPS when it sets up the
FFT grid if the implied grid stencil extends beyond the grid cells
owned by neighboring processors. Typically this will only occur when
small problems are run on large numbers of processors. A warning will
be generated indicating the order parameter is being reduced to allow
LAMMPS to run the problem. Automatic adjustment of the order parameter
is not supported in MSM.
The *force* keyword overrides the relative accuracy parameter set by
the :doc:`kspace_style <kspace_style>` command with an absolute
accuracy. The accuracy determines the RMS error in per-atom forces
calculated by the long-range solver and is thus specified in force
units. A negative value for the accuracy setting means to use the
relative accuracy parameter. The accuracy setting is used in
conjunction with the pairwise cutoff to determine the number of
K-space vectors for style *ewald*\ , the FFT grid size for style
*pppm*\ , or the real space grid size for style *msm*\ .
The *gewald* keyword sets the value of the Ewald or PPPM G-ewald
parameter for charge as *rinv* in reciprocal distance units. Without
this setting, LAMMPS chooses the parameter automatically as a function
of cutoff, precision, grid spacing, etc. This means it can vary from
one simulation to the next which may not be desirable for matching a
KSpace solver to a pre-tabulated pairwise potential. This setting can
also be useful if Ewald or PPPM fails to choose a good grid spacing
and G-ewald parameter automatically. If the value is set to 0.0,
LAMMPS will choose the G-ewald parameter automatically. MSM does not
use the *gewald* parameter.
The *gewald/disp* keyword sets the value of the Ewald or PPPM G-ewald
parameter for dispersion as *rinv* in reciprocal distance units. It
has the same meaning as the *gewald* setting for Coulombics.
The *slab* keyword allows an Ewald or PPPM solver to be used for a
systems that are periodic in x,y but non-periodic in z - a
:doc:`boundary <boundary>` setting of "boundary p p f". This is done by
treating the system as if it were periodic in z, but inserting empty
volume between atom slabs and removing dipole inter-slab interactions
so that slab-slab interactions are effectively turned off. The
volfactor value sets the ratio of the extended dimension in z divided
by the actual dimension in z. The recommended value is 3.0. A larger
value is inefficient; a smaller value introduces unwanted slab-slab
interactions. The use of fixed boundaries in z means that the user
must prevent particle migration beyond the initial z-bounds, typically
by providing a wall-style fix. The methodology behind the *slab*
option is explained in the paper by :ref:`(Yeh) <Yeh>`. The *slab* option