Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F92774136
jump.html
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Sat, Nov 23, 14:58
Size
4 KB
Mime Type
text/html
Expires
Mon, Nov 25, 14:58 (1 d, 23 h)
Engine
blob
Format
Raw Data
Handle
22510868
Attached To
rLAMMPS lammps
jump.html
View Options
<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
jump in.run2 runloop
jump SELF runloop
</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.
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.
</P>
<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
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.
</P>
<PRE>
lmp_g++ -in in.script
</PRE>
<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
</
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.
</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
partitions of 10 procs each. An in.file containing the example
variable and jump command will cause each partition to run a different
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>
<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.
</P>
<PRE>
label loopa
variable a loop 5
label loopb
variable b loop 5
print "A,B =
$
a,
$
b"
run 10000
if "
$
b > 2" then "jump SELF break"
next b
jump in.script loopb
label break
variable b delete
next a
jump SELF loopa
</PRE>
<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>
Event Timeline
Log In to Comment