forked from lijiext/lammps
191 lines
6.1 KiB
Plaintext
191 lines
6.1 KiB
Plaintext
.. index:: pair_style srp
|
|
|
|
pair_style srp command
|
|
======================
|
|
|
|
Syntax
|
|
""""""
|
|
|
|
pair_style srp cutoff btype dist keyword value ...
|
|
|
|
* cutoff = global cutoff for SRP interactions (distance units)
|
|
* btype = bond type to apply SRP interactions to (can be wildcard, see below)
|
|
* distance = *min* or *mid*
|
|
* zero or more keyword/value pairs may be appended
|
|
* keyword = *exclude*
|
|
.. parsed-literal::
|
|
|
|
*bptype* value = atom type for bond particles
|
|
*exclude* value = *yes* or *no*
|
|
|
|
|
|
|
|
Examples
|
|
""""""""
|
|
|
|
.. parsed-literal::
|
|
|
|
pair_style hybrid dpd 1.0 1.0 12345 srp 0.8 1 mid exclude yes
|
|
pair_coeff 1 1 dpd 60.0 4.5 1.0
|
|
pair_coeff 1 2 none
|
|
pair_coeff 2 2 srp 100.0 0.8
|
|
|
|
.. parsed-literal::
|
|
|
|
pair_style hybrid dpd 1.0 1.0 12345 srp 0.8 * min exclude yes
|
|
pair_coeff 1 1 dpd 60.0 50 1.0
|
|
pair_coeff 1 2 none
|
|
pair_coeff 2 2 srp 40.0
|
|
|
|
.. parsed-literal::
|
|
|
|
pair_style hybrid srp 0.8 2 mid
|
|
pair_coeff 1 1 none
|
|
pair_coeff 1 2 none
|
|
pair_coeff 2 2 srp 100.0 0.8
|
|
|
|
Description
|
|
"""""""""""
|
|
|
|
Style *srp* computes a soft segmental repulsive potential (SRP) that
|
|
acts between pairs of bonds. This potential is useful for preventing
|
|
bonds from passing through one another when a soft non-bonded
|
|
potential acts between beads in, for example, DPD polymer chains. An
|
|
example input script that uses this command is provided in
|
|
examples/USER/srp.
|
|
|
|
Bonds of specified type *btype* interact with one another through a
|
|
bond-pairwise potential, such that the force on bond *i* due to bond
|
|
*j* is as follows
|
|
|
|
.. image:: Eqs/pair_srp1.jpg
|
|
:align: center
|
|
|
|
where *r* and *rij* are the distance and unit vector between the two
|
|
bonds. Note that *btype* can be specified as an asterisk "*", which
|
|
case the interaction is applied to all bond types. The *mid* option
|
|
computes *r* and *rij* from the midpoint distance between bonds. The
|
|
*min* option computes *r* and *rij* from the minimum distance between
|
|
bonds. The force acting on a bond is mapped onto the two bond atoms
|
|
according to the lever rule,
|
|
|
|
.. image:: Eqs/pair_srp2.jpg
|
|
:align: center
|
|
|
|
where *L* is the normalized distance from the atom to the point of
|
|
closest approach of bond *i* and *j*. The *mid* option takes *L* as
|
|
0.5 for each interaction as described in :ref:`(Sirk) <Sirk>`.
|
|
|
|
The following coefficients must be defined via the
|
|
:doc:`pair_coeff <pair_coeff>` command as in the examples above, or in
|
|
the data file or restart file read by the :doc:`read_data <read_data>`
|
|
or :doc:`read_restart <read_restart>` commands:
|
|
|
|
* *C* (force units)
|
|
* *rc* (distance units)
|
|
|
|
The last coefficient is optional. If not specified, the global cutoff
|
|
is used.
|
|
|
|
.. note::
|
|
|
|
Pair style srp considers each bond of type *btype* to be a
|
|
fictitious "particle" of type *bptype*, where *bptype* is either the
|
|
largest atom type in the system, or the type set by the *bptype* flag.
|
|
Any actual existing particles with this atom type will be deleted at
|
|
the beginning of a run. This means you must specify the number of
|
|
types in your system accordingly; usually to be one larger than what
|
|
would normally be the case, e.g. via the :doc:`create_box <create_box>`
|
|
or by changing the header in your :doc:`data file <read_data>`. The
|
|
ficitious "bond particles" are inserted at the beginning of the run,
|
|
and serve as placeholders that define the position of the bonds. This
|
|
allows neighbor lists to be constructed and pairwise interactions to
|
|
be computed in almost the same way as is done for actual particles.
|
|
Because bonds interact only with other bonds, :doc:`pair_style hybrid <pair_hybrid>` should be used to turn off interactions
|
|
between atom type *bptype* and all other types of atoms. An error
|
|
will be flagged if :doc:`pair_style hybrid <pair_hybrid>` is not used.
|
|
|
|
The optional *exclude* keyword determines if forces are computed
|
|
between first neighbor (directly connected) bonds. For a setting of
|
|
*no*, first neighbor forces are computed; for *yes* they are not
|
|
computed. A setting of *no* cannot be used with the *min* option for
|
|
distance calculation because the the minimum distance between directly
|
|
connected bonds is zero.
|
|
|
|
Pair style *srp* turns off normalization of thermodynamic properties
|
|
by particle number, as if the command :doc:`thermo_modify norm no <thermo_modify>` had been issued.
|
|
|
|
The pairwise energy associated with style *srp* is shifted to be zero
|
|
at the cutoff distance *rc*.
|
|
|
|
|
|
----------
|
|
|
|
|
|
**Mixing, shift, table, tail correction, restart, rRESPA info**:
|
|
|
|
This pair styles does not support mixing.
|
|
|
|
This pair style does not support the :doc:`pair_modify <pair_modify>`
|
|
shift option for the energy of the pair interaction. Note that as
|
|
discussed above, the energy term is already shifted to be 0.0 at the
|
|
cutoff distance *rc*.
|
|
|
|
The :doc:`pair_modify <pair_modify>` table option is not relevant for
|
|
this pair style.
|
|
|
|
This pair style does not support the :doc:`pair_modify <pair_modify>`
|
|
tail option for adding long-range tail corrections to energy and
|
|
pressure.
|
|
|
|
This pair style writes global and per-atom information to :doc:`binary restart files <restart>`. Pair srp should be used with :doc:`pair_style hybrid <pair_hybrid>`, thus the pair_coeff commands need to be
|
|
specified in the input script when reading a restart file.
|
|
|
|
This pair style can only be used via the *pair* keyword of the
|
|
:doc:`run_style respa <run_style>` command. It does not support the
|
|
*inner*, *middle*, *outer* keywords.
|
|
|
|
|
|
----------
|
|
|
|
|
|
Restrictions
|
|
""""""""""""
|
|
|
|
|
|
This pair style is part of the USER-MISC package. It is only enabled
|
|
if LAMMPS was built with that package. See the Making LAMMPS section
|
|
for more info.
|
|
|
|
This pair style must be used with :doc:`pair_style hybrid <pair_hybrid>`.
|
|
|
|
This pair style requires the :doc:`newton <newton>` command to be *on*
|
|
for non-bonded interactions.
|
|
|
|
Related commands
|
|
""""""""""""""""
|
|
|
|
:doc:`pair_style hybrid <pair_hybrid>`, :doc:`pair_coeff <pair_coeff>`,
|
|
:doc:`pair dpd <pair_dpd>`
|
|
|
|
Default
|
|
"""""""
|
|
|
|
The default keyword value is exclude = yes.
|
|
|
|
|
|
----------
|
|
|
|
|
|
.. _Sirk:
|
|
|
|
|
|
|
|
**(Sirk)** Sirk TW, Sliozberg YR, Brennan JK, Lisal M, Andzelm JW, J
|
|
Chem Phys, 136 (13) 134903, 2012.
|
|
|
|
|
|
.. _lws: http://lammps.sandia.gov
|
|
.. _ld: Manual.html
|
|
.. _lc: Section_commands.html#comm
|