forked from lijiext/lammps
git-svn-id: svn://svn.icms.temple.edu/lammps-ro/trunk@14063 f3b2605a-c512-4ea7-a41b-209d697bcdaa
This commit is contained in:
parent
ac2ab62f03
commit
c622ab1e6d
|
@ -358,7 +358,7 @@ performed with dump style <em>xtc</em>.</p>
|
||||||
<p>The text-based dump styles have a default C-style format string which
|
<p>The text-based dump styles have a default C-style format string which
|
||||||
simply specifies %d for integers and %g for floating-point values.
|
simply specifies %d for integers and %g for floating-point values.
|
||||||
The <em>format</em> keyword can be used to override the default with a new
|
The <em>format</em> keyword can be used to override the default with a new
|
||||||
C-style format string. Do not include a trailing “n” newline
|
C-style format string. Do not include a trailing “\n” newline
|
||||||
character in the format string. This option has no effect on the
|
character in the format string. This option has no effect on the
|
||||||
<em>dcd</em> and <em>xtc</em> dump styles since they write binary files. Note that
|
<em>dcd</em> and <em>xtc</em> dump styles since they write binary files. Note that
|
||||||
for the <em>cfg</em> style, the first two fields (atom id and type) are not
|
for the <em>cfg</em> style, the first two fields (atom id and type) are not
|
||||||
|
|
|
@ -257,7 +257,7 @@ performed with dump style {xtc}.
|
||||||
The text-based dump styles have a default C-style format string which
|
The text-based dump styles have a default C-style format string which
|
||||||
simply specifies %d for integers and %g for floating-point values.
|
simply specifies %d for integers and %g for floating-point values.
|
||||||
The {format} keyword can be used to override the default with a new
|
The {format} keyword can be used to override the default with a new
|
||||||
C-style format string. Do not include a trailing "\n" newline
|
C-style format string. Do not include a trailing "\\n" newline
|
||||||
character in the format string. This option has no effect on the
|
character in the format string. This option has no effect on the
|
||||||
{dcd} and {xtc} dump styles since they write binary files. Note that
|
{dcd} and {xtc} dump styles since they write binary files. Note that
|
||||||
for the {cfg} style, the first two fields (atom id and type) are not
|
for the {cfg} style, the first two fields (atom id and type) are not
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -166,7 +166,7 @@
|
||||||
<em>python</em> arg = function
|
<em>python</em> arg = function
|
||||||
<em>equal</em> or <em>atom</em> args = one formula containing numbers, thermo keywords, math operations, group functions, atom values and vectors, compute/fix/variable references
|
<em>equal</em> or <em>atom</em> args = one formula containing numbers, thermo keywords, math operations, group functions, atom values and vectors, compute/fix/variable references
|
||||||
numbers = 0.0, 100, -5.4, 2.8e-4, etc
|
numbers = 0.0, 100, -5.4, 2.8e-4, etc
|
||||||
constants = PI, version
|
constants = PI, version, on, off, true, false, yes, no
|
||||||
thermo keywords = vol, ke, press, etc from <a class="reference internal" href="thermo_style.html"><em>thermo_style</em></a>
|
thermo keywords = vol, ke, press, etc from <a class="reference internal" href="thermo_style.html"><em>thermo_style</em></a>
|
||||||
math operators = (), -x, x+y, x-y, x*y, x/y, x^y, x%y,
|
math operators = (), -x, x+y, x-y, x*y, x/y, x^y, x%y,
|
||||||
x == y, x != y, x &lt y, x &lt= y, x &gt y, x &gt= y, x && y, x || y, !x
|
x == y, x != y, x &lt y, x &lt= y, x &gt y, x &gt= y, x && y, x || y, !x
|
||||||
|
@ -187,6 +187,7 @@
|
||||||
angmom(group,dim,region), torque(group,dim,region),
|
angmom(group,dim,region), torque(group,dim,region),
|
||||||
inertia(group,dimdim,region), omega(group,dim,region)
|
inertia(group,dimdim,region), omega(group,dim,region)
|
||||||
special functions = sum(x), min(x), max(x), ave(x), trap(x), slope(x), gmask(x), rmask(x), grmask(x,y), next(x)
|
special functions = sum(x), min(x), max(x), ave(x), trap(x), slope(x), gmask(x), rmask(x), grmask(x,y), next(x)
|
||||||
|
feature functions = is_active(category,feature,exact), is_defined(category,id,exact)
|
||||||
atom value = id[i], mass[i], type[i], mol[i], x[i], y[i], z[i], vx[i], vy[i], vz[i], fx[i], fy[i], fz[i], q[i]
|
atom value = id[i], mass[i], type[i], mol[i], x[i], y[i], z[i], vx[i], vy[i], vz[i], fx[i], fy[i], fz[i], q[i]
|
||||||
atom vector = id, mass, type, mol, x, y, z, vx, vy, vz, fx, fy, fz, q
|
atom vector = id, mass, type, mol, x, y, z, vx, vy, vz, fx, fy, fz, q
|
||||||
compute references = c_ID, c_ID[i], c_ID[i][j]
|
compute references = c_ID, c_ID[i], c_ID[i][j]
|
||||||
|
@ -526,12 +527,15 @@ When they invoke the atom-style variable, only atoms in the group are
|
||||||
inlcuded in the formula evaluation. The variable evaluates to 0.0 for
|
inlcuded in the formula evaluation. The variable evaluates to 0.0 for
|
||||||
atoms not in the group.</p>
|
atoms not in the group.</p>
|
||||||
<p>Constants are set at compile time and cannot be changed. <em>PI</em> will
|
<p>Constants are set at compile time and cannot be changed. <em>PI</em> will
|
||||||
return the number 3.14159265358979323846, <em>version</em> will return a
|
return the number 3.14159265358979323846; <em>on</em>, <em>true</em> or <em>yes</em> will
|
||||||
numeric version code of the current LAMMPS version (e.g. version
|
return 1.0; <em>off</em>, <em>false</em> or <em>no</em> will return 0.0; <em>version</em> will
|
||||||
2 Sep 2015 will return the number 20150902). The corresponding value
|
return a numeric version code of the current LAMMPS version (e.g.
|
||||||
for newer versions of LAMMPS will be larger, for older versions of
|
version 2 Sep 2015 will return the number 20150902). The corresponding
|
||||||
LAMMPS will be smaller. This can be used to make input scripts adapt
|
value for newer versions of LAMMPS will be larger, for older versions
|
||||||
automatically to LAMMPS versions, for example:</p>
|
of LAMMPS will be smaller. This can be used to have input scripts
|
||||||
|
adapt automatically to LAMMPS versions, when non-backwards compatible
|
||||||
|
syntax changes are introduced. Here is an illustrative example (which
|
||||||
|
will not work, since the <em>version</em> has been introduced more recently):</p>
|
||||||
<div class="highlight-python"><div class="highlight"><pre>if $(version<20140513) then "communicate vel yes" else "comm_modify vel yes"
|
<div class="highlight-python"><div class="highlight"><pre>if $(version<20140513) then "communicate vel yes" else "comm_modify vel yes"
|
||||||
</pre></div>
|
</pre></div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -828,6 +832,60 @@ the variable is deleted, similar to how the <a class="reference internal" href="
|
||||||
operates.</p>
|
operates.</p>
|
||||||
</div>
|
</div>
|
||||||
<hr class="docutils" />
|
<hr class="docutils" />
|
||||||
|
<div class="section" id="feature-functions">
|
||||||
|
<h3>Feature Functions<a class="headerlink" href="#feature-functions" title="Permalink to this headline">¶</a></h3>
|
||||||
|
<p>Feature functions allow to probe the running LAMMPS executable for
|
||||||
|
whether specific features are either active, defined, or available.
|
||||||
|
The functions take two arguments, a <em>category</em> and a corresponding
|
||||||
|
<em>argument</em>. The arguments are strings thus cannot be formulas
|
||||||
|
themselves (only $-style immediate variable expansion is possible).
|
||||||
|
Return value is either 1.0 or 0.0 depending on whether the function
|
||||||
|
evaluates to true or false, respectively.</p>
|
||||||
|
<p>The <em>is_active()</em> function allows to query for active settings which
|
||||||
|
are grouped by categories. Currently supported categories and
|
||||||
|
arguments are:</p>
|
||||||
|
<ul class="simple">
|
||||||
|
<li><em>package</em> (argument = <em>cuda</em> or <em>gpu</em> or <em>intel</em> or <em>kokkos</em> or <em>omp</em>)</li>
|
||||||
|
<li><em>newton</em> (argument = <em>pair</em> or <em>bond</em> or <em>any</em>)</li>
|
||||||
|
<li><em>pair</em> (argument = <em>single</em> or <em>respa</em> or <em>manybody</em> or <em>tail</em> or <em>shift</em>)</li>
|
||||||
|
<li><em>comm_style</em> (argument = <em>brick</em> or <em>tiled</em>)</li>
|
||||||
|
<li><em>min_style</em> (argument = any of the compiled in minimizer styles)</li>
|
||||||
|
<li><em>run_style</em> (argument = any of the compiled in run styles)</li>
|
||||||
|
<li><em>atom_style</em> (argument = any of the compiled in atom styles)</li>
|
||||||
|
<li><em>pair_style</em> (argument = any of the compiled in pair styles)</li>
|
||||||
|
<li><em>bond_style</em> (argument = any of the compiled in bond styles)</li>
|
||||||
|
<li><em>angle_style</em> (argument = any of the compiled in angle styles)</li>
|
||||||
|
<li><em>dihedral_style</em> (argument = any of the compiled in dihedral styles)</li>
|
||||||
|
<li><em>improper_style</em> (argument = any of the compiled in improper styles)</li>
|
||||||
|
<li><em>kspace_style</em> (argument = any of the compiled in kspace styles)</li>
|
||||||
|
</ul>
|
||||||
|
<p>Most of the settings are self-explanatory, the <em>single</em> argument in the
|
||||||
|
<em>pair</em> category allows to check whether a pair style supports a
|
||||||
|
Pair::single() function as needed by compute group/group and others
|
||||||
|
features or LAMMPS, <em>respa</em> allows to check whether the inner/middle/outer
|
||||||
|
mode of r-RESPA is supported. In the various style categories,
|
||||||
|
the checking is also done using suffix flags, if available and enabled.</p>
|
||||||
|
<p>Example 1: disable use of suffix for pppm when using GPU package (i.e. run it on the CPU concurrently to running the pair style on the GPU), but do use the suffix otherwise (e.g. with USER-OMP).</p>
|
||||||
|
<div class="highlight-python"><div class="highlight"><pre>pair_style lj/cut/coul/long 14.0
|
||||||
|
if $(is_active(package,gpu)) then "suffix off"
|
||||||
|
kspace_style pppm
|
||||||
|
</pre></div>
|
||||||
|
</div>
|
||||||
|
<p>Example 2: use r-RESPA with inner/outer cutoff, if supported by pair style, otherwise fall back to using pair and reducing the outer time step</p>
|
||||||
|
<div class="highlight-python"><div class="highlight"><pre>timestep $(2.0*(1.0+*is_active(pair,respa))
|
||||||
|
if $(is_active(pair,respa)) then "run_style respa 4 3 2 2 improper 1 inner 2 5.5 7.0 outer 3 kspace 4" else "run_style respa 3 3 2 improper 1 pair 2 kspace 3"
|
||||||
|
</pre></div>
|
||||||
|
</div>
|
||||||
|
<p>The <em>is_defined()</em> function allows to query categories like <em>compute</em>,
|
||||||
|
<em>dump</em>, <em>fix</em>, <em>group</em>, <em>region</em>, and <em>variable</em> whether an entry
|
||||||
|
with the provided name or id is defined.</p>
|
||||||
|
<p>The <em>is_available()</em> function allows to query whether a specific
|
||||||
|
optional feature is available, i.e. compiled in. This currently
|
||||||
|
works for the following categories: <em>command</em>, <em>compute</em>, <em>fix</em>,
|
||||||
|
and <em>pair_style</em>. For all categories except <em>command</em> also appending
|
||||||
|
active suffixes is tried before reporting failure.</p>
|
||||||
|
</div>
|
||||||
|
<hr class="docutils" />
|
||||||
<div class="section" id="atom-values-and-vectors">
|
<div class="section" id="atom-values-and-vectors">
|
||||||
<h3>Atom Values and Vectors<a class="headerlink" href="#atom-values-and-vectors" title="Permalink to this headline">¶</a></h3>
|
<h3>Atom Values and Vectors<a class="headerlink" href="#atom-values-and-vectors" title="Permalink to this headline">¶</a></h3>
|
||||||
<p>Atom values take an integer argument I from 1 to N, where I is the
|
<p>Atom values take an integer argument I from 1 to N, where I is the
|
||||||
|
|
|
@ -44,7 +44,7 @@ style = {delete} or {index} or {loop} or {world} or {universe} or
|
||||||
{python} arg = function
|
{python} arg = function
|
||||||
{equal} or {atom} args = one formula containing numbers, thermo keywords, math operations, group functions, atom values and vectors, compute/fix/variable references
|
{equal} or {atom} args = one formula containing numbers, thermo keywords, math operations, group functions, atom values and vectors, compute/fix/variable references
|
||||||
numbers = 0.0, 100, -5.4, 2.8e-4, etc
|
numbers = 0.0, 100, -5.4, 2.8e-4, etc
|
||||||
constants = PI, version
|
constants = PI, version, on, off, true, false, yes, no
|
||||||
thermo keywords = vol, ke, press, etc from "thermo_style"_thermo_style.html
|
thermo keywords = vol, ke, press, etc from "thermo_style"_thermo_style.html
|
||||||
math operators = (), -x, x+y, x-y, x*y, x/y, x^y, x%y,
|
math operators = (), -x, x+y, x-y, x*y, x/y, x^y, x%y,
|
||||||
x == y, x != y, x < y, x <= y, x > y, x >= y, x && y, x || y, !x
|
x == y, x != y, x < y, x <= y, x > y, x >= y, x && y, x || y, !x
|
||||||
|
@ -65,6 +65,7 @@ style = {delete} or {index} or {loop} or {world} or {universe} or
|
||||||
angmom(group,dim,region), torque(group,dim,region),
|
angmom(group,dim,region), torque(group,dim,region),
|
||||||
inertia(group,dimdim,region), omega(group,dim,region)
|
inertia(group,dimdim,region), omega(group,dim,region)
|
||||||
special functions = sum(x), min(x), max(x), ave(x), trap(x), slope(x), gmask(x), rmask(x), grmask(x,y), next(x)
|
special functions = sum(x), min(x), max(x), ave(x), trap(x), slope(x), gmask(x), rmask(x), grmask(x,y), next(x)
|
||||||
|
feature functions = is_active(category,feature,exact), is_defined(category,id,exact)
|
||||||
atom value = id\[i\], mass\[i\], type\[i\], mol\[i\], x\[i\], y\[i\], z\[i\], vx\[i\], vy\[i\], vz\[i\], fx\[i\], fy\[i\], fz\[i\], q\[i\]
|
atom value = id\[i\], mass\[i\], type\[i\], mol\[i\], x\[i\], y\[i\], z\[i\], vx\[i\], vy\[i\], vz\[i\], fx\[i\], fy\[i\], fz\[i\], q\[i\]
|
||||||
atom vector = id, mass, type, mol, x, y, z, vx, vy, vz, fx, fy, fz, q
|
atom vector = id, mass, type, mol, x, y, z, vx, vy, vz, fx, fy, fz, q
|
||||||
compute references = c_ID, c_ID\[i\], c_ID\[i\]\[j\]
|
compute references = c_ID, c_ID\[i\], c_ID\[i\]\[j\]
|
||||||
|
@ -415,7 +416,7 @@ values, atom vectors, compute references, fix references, and
|
||||||
references to other variables.
|
references to other variables.
|
||||||
|
|
||||||
Number: 0.2, 100, 1.0e20, -15.4, etc
|
Number: 0.2, 100, 1.0e20, -15.4, etc
|
||||||
Constant: PI, version
|
Constant: PI, version, on, off, true, false, yes, no
|
||||||
Thermo keywords: vol, pe, ebond, etc
|
Thermo keywords: vol, pe, ebond, etc
|
||||||
Math operators: (), -x, x+y, x-y, x*y, x/y, x^y, x%y,
|
Math operators: (), -x, x+y, x-y, x*y, x/y, x^y, x%y,
|
||||||
Math operators: (), -x, x+y, x-y, x*y, x/y, x^y, x%y, x == y, x != y, x < y, x <= y, x > y, x >= y, x && y, x || y, !x
|
Math operators: (), -x, x+y, x-y, x*y, x/y, x^y, x%y, x == y, x != y, x < y, x <= y, x > y, x >= y, x && y, x || y, !x
|
||||||
|
@ -458,12 +459,15 @@ inlcuded in the formula evaluation. The variable evaluates to 0.0 for
|
||||||
atoms not in the group.
|
atoms not in the group.
|
||||||
|
|
||||||
Constants are set at compile time and cannot be changed. {PI} will
|
Constants are set at compile time and cannot be changed. {PI} will
|
||||||
return the number 3.14159265358979323846, {version} will return a
|
return the number 3.14159265358979323846; {on}, {true} or {yes} will
|
||||||
numeric version code of the current LAMMPS version (e.g. version
|
return 1.0; {off}, {false} or {no} will return 0.0; {version} will
|
||||||
2 Sep 2015 will return the number 20150902). The corresponding value
|
return a numeric version code of the current LAMMPS version (e.g.
|
||||||
for newer versions of LAMMPS will be larger, for older versions of
|
version 2 Sep 2015 will return the number 20150902). The corresponding
|
||||||
LAMMPS will be smaller. This can be used to make input scripts adapt
|
value for newer versions of LAMMPS will be larger, for older versions
|
||||||
automatically to LAMMPS versions, for example:
|
of LAMMPS will be smaller. This can be used to have input scripts
|
||||||
|
adapt automatically to LAMMPS versions, when non-backwards compatible
|
||||||
|
syntax changes are introduced. Here is an illustrative example (which
|
||||||
|
will not work, since the {version} has been introduced more recently):
|
||||||
|
|
||||||
if $(version<20140513) then "communicate vel yes" else "comm_modify vel yes" :pre
|
if $(version<20140513) then "communicate vel yes" else "comm_modify vel yes" :pre
|
||||||
|
|
||||||
|
@ -789,6 +793,64 @@ operates.
|
||||||
|
|
||||||
:line
|
:line
|
||||||
|
|
||||||
|
Feature Functions :h4
|
||||||
|
|
||||||
|
Feature functions allow to probe the running LAMMPS executable for
|
||||||
|
whether specific features are either active, defined, or available.
|
||||||
|
The functions take two arguments, a {category} and a corresponding
|
||||||
|
{argument}. The arguments are strings thus cannot be formulas
|
||||||
|
themselves (only $-style immediate variable expansion is possible).
|
||||||
|
Return value is either 1.0 or 0.0 depending on whether the function
|
||||||
|
evaluates to true or false, respectively.
|
||||||
|
|
||||||
|
The {is_active()} function allows to query for active settings which
|
||||||
|
are grouped by categories. Currently supported categories and
|
||||||
|
arguments are:
|
||||||
|
|
||||||
|
{package} (argument = {cuda} or {gpu} or {intel} or {kokkos} or {omp})
|
||||||
|
{newton} (argument = {pair} or {bond} or {any})
|
||||||
|
{pair} (argument = {single} or {respa} or {manybody} or {tail} or {shift})
|
||||||
|
{comm_style} (argument = {brick} or {tiled})
|
||||||
|
{min_style} (argument = any of the compiled in minimizer styles)
|
||||||
|
{run_style} (argument = any of the compiled in run styles)
|
||||||
|
{atom_style} (argument = any of the compiled in atom styles)
|
||||||
|
{pair_style} (argument = any of the compiled in pair styles)
|
||||||
|
{bond_style} (argument = any of the compiled in bond styles)
|
||||||
|
{angle_style} (argument = any of the compiled in angle styles)
|
||||||
|
{dihedral_style} (argument = any of the compiled in dihedral styles)
|
||||||
|
{improper_style} (argument = any of the compiled in improper styles)
|
||||||
|
{kspace_style} (argument = any of the compiled in kspace styles) :ul
|
||||||
|
|
||||||
|
Most of the settings are self-explanatory, the {single} argument in the
|
||||||
|
{pair} category allows to check whether a pair style supports a
|
||||||
|
Pair::single() function as needed by compute group/group and others
|
||||||
|
features or LAMMPS, {respa} allows to check whether the inner/middle/outer
|
||||||
|
mode of r-RESPA is supported. In the various style categories,
|
||||||
|
the checking is also done using suffix flags, if available and enabled.
|
||||||
|
|
||||||
|
Example 1: disable use of suffix for pppm when using GPU package (i.e. run it on the CPU concurrently to running the pair style on the GPU), but do use the suffix otherwise (e.g. with USER-OMP).
|
||||||
|
|
||||||
|
pair_style lj/cut/coul/long 14.0
|
||||||
|
if $(is_active(package,gpu)) then "suffix off"
|
||||||
|
kspace_style pppm :pre
|
||||||
|
|
||||||
|
Example 2: use r-RESPA with inner/outer cutoff, if supported by pair style, otherwise fall back to using pair and reducing the outer time step
|
||||||
|
|
||||||
|
timestep $(2.0*(1.0+*is_active(pair,respa))
|
||||||
|
if $(is_active(pair,respa)) then "run_style respa 4 3 2 2 improper 1 inner 2 5.5 7.0 outer 3 kspace 4" else "run_style respa 3 3 2 improper 1 pair 2 kspace 3" :pre
|
||||||
|
|
||||||
|
The {is_defined()} function allows to query categories like {compute},
|
||||||
|
{dump}, {fix}, {group}, {region}, and {variable} whether an entry
|
||||||
|
with the provided name or id is defined.
|
||||||
|
|
||||||
|
The {is_available()} function allows to query whether a specific
|
||||||
|
optional feature is available, i.e. compiled in. This currently
|
||||||
|
works for the following categories: {command}, {compute}, {fix},
|
||||||
|
and {pair_style}. For all categories except {command} also appending
|
||||||
|
active suffixes is tried before reporting failure.
|
||||||
|
|
||||||
|
:line
|
||||||
|
|
||||||
Atom Values and Vectors :h4
|
Atom Values and Vectors :h4
|
||||||
|
|
||||||
Atom values take an integer argument I from 1 to N, where I is the
|
Atom values take an integer argument I from 1 to N, where I is the
|
||||||
|
|
Loading…
Reference in New Issue