2007-05-01 07:37:43 +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>if command
|
|
|
|
</H3>
|
|
|
|
<P><B>Syntax:</B>
|
|
|
|
</P>
|
2010-01-20 04:18:34 +08:00
|
|
|
<PRE>if value1 operator value2 then t1 t2 ... else e1 e2 ...
|
2007-05-01 07:37:43 +08:00
|
|
|
</PRE>
|
|
|
|
<UL><LI>value1 = 1st value
|
2007-06-20 20:56:17 +08:00
|
|
|
<LI>operator = "<" or "<=" or ">" or ">=" or "==" or "!="
|
2007-05-01 07:37:43 +08:00
|
|
|
<LI>value2 = 2nd value
|
|
|
|
<LI>then = required word
|
2010-01-20 04:18:34 +08:00
|
|
|
<LI>t1,t2,...,tN = one or more LAMMPS commands to execute if condition is met, each enclosed in quotes
|
2010-01-20 04:04:41 +08:00
|
|
|
<LI>else = optional argument
|
2010-01-20 04:18:34 +08:00
|
|
|
<LI>e1,e2,...,eN = one or more LAMMPS commands to execute if condition is not met, each enclosed in quotes (optional arguments)
|
2007-05-01 07:37:43 +08:00
|
|
|
</UL>
|
|
|
|
<P><B>Examples:</B>
|
|
|
|
</P>
|
2007-05-01 07:54:12 +08:00
|
|
|
<PRE>if ${steps} > 1000 then exit
|
2007-05-01 07:37:43 +08:00
|
|
|
if $x <= $y then "print X is smaller = $x" else "print Y is smaller = $y"
|
2007-05-01 07:54:12 +08:00
|
|
|
if ${eng} > 0.0 then "timestep 0.005"
|
|
|
|
if ${eng} > ${eng_previous} then "jump file1" else "jump file2"
|
2007-05-01 07:37:43 +08:00
|
|
|
</PRE>
|
|
|
|
<P><B>Description:</B>
|
|
|
|
</P>
|
2010-01-20 04:04:41 +08:00
|
|
|
<P>This command provides an in-then-else capability within an input
|
2007-05-01 07:37:43 +08:00
|
|
|
script. Two values are numerically compared to each other and the
|
|
|
|
result is TRUE or FALSE. Note that as in the examples above, either
|
2010-01-20 04:04:41 +08:00
|
|
|
of the two values can be variables, as defined by the
|
|
|
|
<A HREF = "variable.html">variable</A> command, so that when the if command is
|
|
|
|
executed, the variable(s) will be evaluated, which could calculate a
|
|
|
|
user-defined formula that reflects the current state of the
|
|
|
|
simulation.
|
2007-05-01 07:37:43 +08:00
|
|
|
</P>
|
2010-01-20 04:18:34 +08:00
|
|
|
<P>If the result of the if test is TRUE, then one or more commands (t1,
|
|
|
|
t2, ..., tN) are executed. If the result of the if test is FALSE and
|
2010-01-20 04:04:41 +08:00
|
|
|
no optional "else" argument is included, then the if command does
|
|
|
|
nothing. If the result of the if test is FALSE and the optional
|
2010-01-20 04:18:34 +08:00
|
|
|
"else" argument is included, then one or more commands (e1,
|
|
|
|
e2, ..., eN) are executed.
|
2010-01-20 04:04:41 +08:00
|
|
|
</P>
|
2010-01-20 04:18:34 +08:00
|
|
|
<P>Each then or else command (t1, e1, etc) can be any valid LAMMPS input
|
2010-01-20 04:04:41 +08:00
|
|
|
script command. Each command should be enclosed in quotes, so it will
|
2007-05-01 07:37:43 +08:00
|
|
|
be treated as a single argument, as in the examples above.
|
|
|
|
</P>
|
2010-01-20 04:04:41 +08:00
|
|
|
<P>Note that by using the line continuation character "&", the if command
|
|
|
|
can be spread across many lines, though it is still a single
|
|
|
|
command:
|
|
|
|
</P>
|
|
|
|
<PRE>if $a < $b then &
|
2010-09-09 08:04:08 +08:00
|
|
|
"print Minimum value = $a" &
|
2010-01-20 04:04:41 +08:00
|
|
|
"run 1000" &
|
|
|
|
else &
|
|
|
|
"print Minimum value = $b" &
|
|
|
|
"minimize 0.001 0.001 1000 10000"
|
|
|
|
</PRE>
|
|
|
|
<P>Note that if any executed comand is a bogus LAMMPS command, such as
|
|
|
|
"exit" in the first example above, then executing the command will
|
|
|
|
cause LAMMPS to halt.
|
2007-05-01 07:37:43 +08:00
|
|
|
</P>
|
2008-10-07 23:02:40 +08:00
|
|
|
<P>Note that by jumping to a label in the same input script, the if
|
|
|
|
command can be used to break out of a loop. See the <A HREF = "variable.html">variable
|
|
|
|
delete</A> for info on how to delete the associated loop
|
|
|
|
variable, so that it can be re-used later in the input script.
|
|
|
|
</P>
|
|
|
|
<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 in.script break"
|
|
|
|
next b
|
|
|
|
jump in.script loopb
|
|
|
|
label break
|
|
|
|
variable b delete
|
|
|
|
</PRE>
|
|
|
|
<PRE>next a
|
|
|
|
jump in.script loopa
|
|
|
|
</PRE>
|
2007-05-01 07:37:43 +08:00
|
|
|
<P><B>Restrictions:</B> none
|
|
|
|
</P>
|
|
|
|
<P><B>Related commands:</B>
|
|
|
|
</P>
|
2010-01-20 04:04:41 +08:00
|
|
|
<P><A HREF = "variable.html">variable</A>, <A HREF = "print.html">print</A>
|
2007-05-01 07:37:43 +08:00
|
|
|
</P>
|
|
|
|
<P><B>Default:</B> none
|
|
|
|
</P>
|
|
|
|
</HTML>
|