2006-09-22 00:22:34 +08:00
|
|
|
<HTML>
|
|
|
|
<CENTER><A HREF = "http://lammps.sandia.gov">LAMMPS WWW Site</A> - <A HREF = "Manual.html">LAMMPS Documentation</A> - <A HREF = "Section_commands.html#comm">LAMMPS Commands</A>
|
|
|
|
</CENTER>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<HR>
|
|
|
|
|
|
|
|
<H3>jump command
|
|
|
|
</H3>
|
|
|
|
<P><B>Syntax:</B>
|
|
|
|
</P>
|
|
|
|
<PRE>jump file label
|
|
|
|
</PRE>
|
|
|
|
<UL><LI>file = filename of new input script to switch to
|
|
|
|
<LI>label = optional label within file to jump to
|
|
|
|
</UL>
|
|
|
|
<P><B>Examples:</B>
|
|
|
|
</P>
|
|
|
|
<PRE>jump newfile
|
2010-09-28 03:12:19 +08:00
|
|
|
jump in.run2 runloop
|
|
|
|
jump SELF runloop
|
2006-09-22 00:22:34 +08:00
|
|
|
</PRE>
|
|
|
|
<P><B>Description:</B>
|
|
|
|
</P>
|
|
|
|
<P>This command closes the current input script file, opens the file with
|
|
|
|
the specified name, and begins reading LAMMPS commands from that file.
|
2008-10-07 23:02:40 +08:00
|
|
|
Unlike the <A HREF = "include.html">include</A> command, the original file is not
|
|
|
|
returned to, although by using multiple jump commands it is possible
|
|
|
|
to chain from file to file or back to the original file.
|
2006-09-22 00:22:34 +08:00
|
|
|
</P>
|
2010-09-28 03:12:19 +08:00
|
|
|
<P>If the word "SELF" is used for the filename, then the current input
|
|
|
|
script is re-opened and read again.
|
|
|
|
</P>
|
|
|
|
<P>IMPORTANT NOTE: The SELF option is not guaranteed to work when the
|
|
|
|
current input script is being read through stdin (standard input),
|
|
|
|
e.g.
|
|
|
|
</P>
|
|
|
|
<PRE>lmp_g++ < in.script
|
|
|
|
</PRE>
|
|
|
|
<P>since the SELF option invokes the C-library rewind() call, which may
|
2014-02-13 00:13:51 +08:00
|
|
|
not be supported for stdin on some systems or by some MPI
|
|
|
|
implementations. This can be worked around by using the <A HREF = "Section_start.html#start_7">-in
|
|
|
|
command-line argument</A>, e.g.
|
2010-09-28 03:12:19 +08:00
|
|
|
</P>
|
|
|
|
<PRE>lmp_g++ -in in.script
|
|
|
|
</PRE>
|
2014-01-10 06:24:40 +08:00
|
|
|
<P>or by using the <A HREF = "Section_start.html#start_7">-var command-line
|
|
|
|
argument</A> to pass the script name as a
|
|
|
|
variable to the input script. In the latter case, a
|
|
|
|
<A HREF = "variable.html">variable</A> called "fname" could be used in place of
|
|
|
|
SELF, e.g.
|
|
|
|
</P>
|
|
|
|
<PRE>lmp_g++ -var fname in.script < in.script
|
2010-09-28 03:12:19 +08:00
|
|
|
</PRE>
|
|
|
|
<P>The 2nd argument to the jump command is optional. If specified, it is
|
|
|
|
treated as a label and the new file is scanned (without executing
|
|
|
|
commands) until the label is found, and commands are executed from
|
|
|
|
that point forward. This can be used to loop over a portion of the
|
|
|
|
input script, as in this example. These commands perform 10 runs,
|
|
|
|
each of 10000 steps, and create 10 dump files named file.1, file.2,
|
|
|
|
etc. The <A HREF = "next.html">next</A> command is used to exit the loop after 10
|
|
|
|
iterations. When the "a" variable has been incremented for the tenth
|
|
|
|
time, it will cause the next jump command to be skipped.
|
2006-09-22 00:22:34 +08:00
|
|
|
</P>
|
|
|
|
<PRE>variable a loop 10
|
|
|
|
label loop
|
|
|
|
dump 1 all atom 100 file.$a
|
|
|
|
run 10000
|
|
|
|
undump 1
|
|
|
|
next a
|
|
|
|
jump in.lj loop
|
|
|
|
</PRE>
|
|
|
|
<P>If the jump <I>file</I> argument is a variable, the jump command can be
|
|
|
|
used to cause different processor partitions to run different input
|
|
|
|
scripts. In this example, LAMMPS is run on 40 processors, with 4
|
2008-03-19 05:09:15 +08:00
|
|
|
partitions of 10 procs each. An in.file containing the example
|
|
|
|
variable and jump command will cause each partition to run a different
|
2006-09-22 00:22:34 +08:00
|
|
|
simulation.
|
|
|
|
</P>
|
|
|
|
<PRE>mpirun -np 40 lmp_ibm -partition 4x10 -in in.file
|
|
|
|
</PRE>
|
|
|
|
<PRE>variable f world script.1 script.2 script.3 script.4
|
|
|
|
jump $f
|
|
|
|
</PRE>
|
2014-03-18 06:52:40 +08:00
|
|
|
<P>Here is an example of a loop which checks every 1000 steps if the
|
|
|
|
system temperature has reached a certain value, and if so, breaks out
|
|
|
|
of the loop to finish the run. Note that any variable could be
|
|
|
|
checked, so long as it is current on the timestep when the run
|
|
|
|
completes. As explained on the <A HREF = "variable.html">variable</A> doc page,
|
|
|
|
this can be insured by includig the variable in thermodynamic output.
|
|
|
|
</P>
|
|
|
|
<PRE>variable myTemp equal temp
|
|
|
|
label loop
|
|
|
|
variable a loop 1000
|
|
|
|
run 1000
|
|
|
|
if "${myTemp} < 300.0" then "jump SELF break"
|
|
|
|
next a
|
|
|
|
jump SELF loop
|
|
|
|
label break
|
|
|
|
print "ALL DONE"
|
|
|
|
</PRE>
|
|
|
|
<P>Here is an example of a double loop which uses the if and
|
|
|
|
<A HREF = "jump.html">jump</A> commands to break out of the inner loop when a
|
|
|
|
condition is met, then continues iterating thru the outer loop.
|
2008-10-07 23:02:40 +08:00
|
|
|
</P>
|
|
|
|
<PRE>label loopa
|
|
|
|
variable a loop 5
|
|
|
|
label loopb
|
|
|
|
variable b loop 5
|
|
|
|
print "A,B = $a,$b"
|
|
|
|
run 10000
|
2014-03-18 06:52:40 +08:00
|
|
|
if "$b > 2" then "jump SELF break"
|
2008-10-07 23:02:40 +08:00
|
|
|
next b
|
|
|
|
jump in.script loopb
|
|
|
|
label break
|
2014-03-18 06:52:40 +08:00
|
|
|
variable b delete
|
|
|
|
next a
|
|
|
|
jump SELF loopa
|
2008-10-07 23:02:40 +08:00
|
|
|
</PRE>
|
2006-09-22 00:22:34 +08:00
|
|
|
<P><B>Restrictions:</B>
|
|
|
|
</P>
|
|
|
|
<P>If you jump to a file and it does not contain the specified label,
|
|
|
|
LAMMPS will come to the end of the file and exit.
|
|
|
|
</P>
|
|
|
|
<P><B>Related commands:</B>
|
|
|
|
</P>
|
|
|
|
<P><A HREF = "variable.html">variable</A>, <A HREF = "include.html">include</A>, <A HREF = "label.html">label</A>,
|
|
|
|
<A HREF = "next.html">next</A>
|
|
|
|
</P>
|
|
|
|
<P><B>Default:</B> none
|
|
|
|
</P>
|
|
|
|
</HTML>
|