diff --git a/doc/read_data.html b/doc/read_data.html index 34f9e03af..e484763c1 100644 --- a/doc/read_data.html +++ b/doc/read_data.html @@ -1,704 +1,704 @@ <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>read_data command </H3> <P><B>Syntax:</B> </P> <PRE>read_data file </PRE> <UL><LI>file = name of data file to read in </UL> <P><B>Examples:</B> </P> <PRE>read_data data.lj read_data ../run7/data.polymer.gz </PRE> <P><B>Description:</B> </P> <P>Read in a data file containing information LAMMPS needs to run a simulation. The file can be ASCII text or a gzipped text file (detected by a .gz suffix). This is one of 3 ways to specify initial atom coordinates; see the <A HREF = "read_restart.html">read_restart</A> and <A HREF = "create_atoms.html">create_atoms</A> commands for alternative methods. </P> <P>The structure of the data file is important, though many settings and sections are optional or can come in any order. See the examples directory for sample data files for different problems. </P> <P>A data file has a header and a body. The header appears first. The first line of the header is always skipped; it typically contains a description of the file. Then lines are read one at a time. Lines can have a trailing comment starting with '#' that is ignored. If the line is blank (only whitespace after comment is deleted), it is skipped. If the line contains a header keyword, the corresponding value(s) is read from the line. If it doesn't contain a header keyword, the line begins the body of the file. </P> <P>The body of the file contains zero or more sections. The first line of a section has only a keyword. The next line is skipped. The remaining lines of the section contain values. The number of lines depends on the section keyword as described below. Zero or more blank lines can be used between sections. Sections can appear in any order, with a few exceptions as noted below. </P> <P>The formatting of individual lines in the data file (indentation, spacing between words and numbers) is not important except that header and section keywords (e.g. atoms, xlo xhi, Masses, Bond Coeffs) must be capitalized as shown and can't have extra white space between their words - e.g. two spaces or a tab between "Bond" and "Coeffs" is not valid. </P> <HR> <P>These are the recognized header keywords. Header lines can come in any order. The value(s) are read from the beginning of the line. Thus the keyword <I>atoms</I> should be in a line like "1000 atoms"; the keyword <I>ylo yhi</I> should be in a line like "-10.0 10.0 ylo yhi"; the keyword <I>xy xz yz</I> should be in a line like "0.0 5.0 6.0 xy xz yz". All these settings have a default value of 0, except the lo/hi box size defaults are -0.5 and 0.5. A line need only appear if the value is different than the default. </P> <UL><LI><I>atoms</I> = # of atoms in system <LI><I>bonds</I> = # of bonds in system <LI><I>angles</I> = # of angles in system <LI><I>dihedrals</I> = # of dihedrals in system <LI><I>impropers</I> = # of impropers in system <LI><I>atom types</I> = # of atom types in system <LI><I>bond types</I> = # of bond types in system <LI><I>angle types</I> = # of angle types in system <LI><I>dihedral types</I> = # of dihedral types in system <LI><I>improper types</I> = # of improper types in system <LI><I>xlo xhi</I> = simulation box boundaries in x dimension <LI><I>ylo yhi</I> = simulation box boundaries in y dimension <LI><I>zlo zhi</I> = simulation box boundaries in z dimension <LI><I>xy xz yz</I> = simulation box tilt factors for triclinic domain </UL> <P>The initial simulation box size is determined by the lo/hi settings. In any dimension, the system may be periodic or non-periodic; see the <A HREF = "boundary.html">boundary</A> command. </P> <P>If the <I>xy xz yz</I> line does not appear, then LAMMPS will set up an axis-aligned (orthogonal) simulation box. If the line does appear, LAMMPS creates a non-orthogonal simulation domain shaped as a parallelepiped with triclinic symmetry. See the <A HREF = "region.html">region prism</A> command for a description of how the extent of the parallelepiped is defined. The parallelepiped has its "origin" at (xlo,ylo,zlo) and 3 edge vectors starting from the origin given by a = (xhi-xlo,0,0); b = (xy,yhi-ylo,0); c = (xz,yz,zhi-zlo). Note that if your simulation will tilt the box, e.g. via the <A HREF = "fix_deform.html">fix deform</A> command, the simulation box must be triclinic, even if the tilt factors are initially 0.0. </P> <P>The tilt factors (xy,xz,yz) can not skew the box more than half the distance of the parallel box length. For example, if xlo = 2 and xhi = 12, then the x box length is 10 and the xy tilt factor must be between -5 and 5. Similarly, both xz and yz must be between -(xhi-xlo)/2 and +(yhi-ylo)/2. Note that this is not a limitation, since if the maximum tilt factor is 5 (as in this example), then configurations with tilt = ..., -15, -5, 5, 15, 25, ... are all equivalent. </P> <P>When a triclinic system is used, the simulation domain must be periodic in any dimensions with a non-zero tilt factor, as defined by the <A HREF = "boundary.html">boundary</A> command. I.e. if the xy tilt factor is non-zero, then both the x and y dimensions must be periodic. Similarly, x and z must be periodic if xz is non-zero and y and z must be periodic if yz is non-zero. </P> <P>For 2d simulations, the <I>zlo zhi</I> values should be set to bound the z coords for atoms that appear in the file; the default of -0.5 0.5 is valid if all z coords are 0.0. For 2d triclinic simulations, the xz and yz tilt factors must be 0.0. </P> <P>If the system is periodic (in a dimension), then atom coordinates can be outside the bounds; they will be remapped (in a periodic sense) back inside the box. </P> <P>IMPORTANT NOTE: If the system is non-periodic (in a dimension), then all atoms in the data file must have coordinates (in that dimension) that are "greater than or equal to" the lo value and "less than or equal to" the hi value. If the non-periodic dimension is of style "fixed" (see the <A HREF = "boundary.html">boundary</A> command), then the atom coords must be strictly "less than" the hi value, due to the way LAMMPS assign atoms to processors. Note that you should not make the lo/hi values radically smaller/larger than the extent of the atoms. For example, if your atoms extend from 0 to 50, you should not specify the box bounds as -10000 and 10000. This is because LAMMPS uses the specified box size to layout the 3d grid of processors. A huge (mostly empty) box will be sub-optimal for performance and may cause a parallel simulation to lose atoms if LAMMPS shrink-wraps the box around the atoms. </P> <HR> <P>These are the section keywords for the body of the file. </P> <UL><LI><I>Atoms, Velocities, Masses, Shapes, Dipoles</I> = atom-property sections <LI><I>Bonds, Angles, Dihedrals, Impropers</I> = molecular topology sections <LI><I>Pair Coeffs, Bond Coeffs, Angle Coeffs, Dihedral Coeffs, Improper Coeffs</I> = force field sections <LI><I>BondBond Coeffs, BondAngle Coeffs, MiddleBondTorsion Coeffs, EndBondTorsion Coeffs, AngleTorsion Coeffs, AngleAngleTorsion Coeffs, BondBond13 Coeffs, AngleAngle Coeffs</I> = class 2 force field sections </UL> <P>Each section is listed below in alphabetic order. The format of each section is described including the number of lines it must contain and rules (if any) for where it can appear in the data file. </P> <P>Any individual line in the various sections can have a trailing comment starting with "#" for annotation purposes. E.g. in the Atoms section: </P> <PRE>10 1 17 -1.0 10.0 5.0 6.0 # salt ion </PRE> <HR> <P><I>Angle Coeffs</I> section: </P> <UL><LI>one line per angle type <LI>line syntax: ID coeffs <PRE> ID = angle type (1-N) coeffs = list of coeffs </PRE> <LI>example: <PRE> 6 70 108.5 0 0 </PRE> </UL> <P>The number and meaning of the coefficients are specific to the defined angle style. See the <A HREF = "angle_style.html">angle_style</A> and <A HREF = "angle_coeff.html">angle_coeff</A> commands for details. Coefficients can also be set via the <A HREF = "angle_coeff.html">angle_coeff</A> command in the input script. </P> <HR> <P><I>AngleAngle Coeffs</I> section: </P> <UL><LI>one line per improper type <LI>line syntax: ID coeffs <PRE> ID = improper type (1-N) coeffs = list of coeffs (see <A HREF = "improper_coeff.html">improper_coeff</A>) </PRE> </UL> <HR> <P><I>AngleAngleTorsion Coeffs</I> section: </P> <UL><LI>one line per dihedral type <LI>line syntax: ID coeffs <PRE> ID = dihedral type (1-N) coeffs = list of coeffs (see <A HREF = "dihedral_coeff.html">dihedral_coeff</A>) </PRE> </UL> <HR> <P><I>Angles</I> section: </P> <UL><LI>one line per angle <LI>line syntax: ID type atom1 atom2 atom3 <PRE> ID = number of angle (1-Nangles) type = angle type (1-Nangletype) atom1,atom2,atom3 = IDs of 1st,2nd,3rd atoms in angle </PRE> example: <BR> <PRE> 2 2 17 29 430 </PRE> </UL> <P>The 3 atoms are ordered linearly within the angle. Thus the central atom (around which the angle is computed) is the atom2 in the list. E.g. H,O,H for a water molecule. The <I>Angles</I> section must appear after the <I>Atoms</I> section. All values in this section must be integers (1, not 1.0). </P> <HR> <P><I>AngleTorsion Coeffs</I> section: </P> <UL><LI>one line per dihedral type <LI>line syntax: ID coeffs <PRE> ID = dihedral type (1-N) coeffs = list of coeffs (see <A HREF = "dihedral_coeff.html">dihedral_coeff</A>) </PRE> </UL> <HR> <P><I>Atoms</I> section: </P> <UL><LI>one line per atom <LI>line syntax: depends on atom style </UL> <P>An <I>Atoms</I> section must appear in the data file if natoms > 0 in the header section. The atoms can be listed in any order. These are the line formats for each <A HREF = "atom_style.html">atom style</A> in LAMMPS. As discussed below, each line can optionally have 3 flags (nx,ny,nz) appended to it, which indicate which image of a periodic simulation box the atom is in. These may be important to include for some kinds of analysis. </P> <DIV ALIGN=center><TABLE BORDER=1 > <TR><TD >angle</TD><TD > atom-ID molecule-ID atom-type x y z</TD></TR> <TR><TD >atomic</TD><TD > atom-ID atom-type x y z</TD></TR> <TR><TD >bond</TD><TD > atom-ID molecule-ID atom-type x y z</TD></TR> <TR><TD >charge</TD><TD > atom-ID atom-type q x y z</TD></TR> <TR><TD >dipole</TD><TD > atom-ID atom-type q x y z mux muy muz</TD></TR> <TR><TD >dpd</TD><TD > atom-ID atom-type x y z</TD></TR> <TR><TD >ellipsoid</TD><TD > atom-ID atom-type x y z quatw quati quatj quatk</TD></TR> <TR><TD >full</TD><TD > atom-ID molecule-ID atom-type q x y z</TD></TR> <TR><TD >granular</TD><TD > atom-ID atom-type diameter density x y z</TD></TR> <TR><TD >molecular</TD><TD > atom-ID molecule-ID atom-type x y z</TD></TR> <TR><TD >peri</TD><TD > atom-ID atom-type volume density x y z</TD></TR> <TR><TD >hybrid</TD><TD > atom-ID atom-type x y z sub-style1 sub-style2 ... </TD></TR></TABLE></DIV> <P>The keywords have these meanings: </P> <UL><LI>atom-ID = integer ID of atom <LI>molecule-ID = integer ID of molecule the atom belongs to <LI>type-ID = type of atom (1-Ntype) <LI>q = charge on atom (charge units) <LI>diameter = diameter of atom (distance units) <LI>density = density of atom (mass/distance^3 units) <LI>volume = volume of atom (distance^3 units) <LI>x,y,z = coordinates of atom <LI>mux,muy,muz = direction of dipole moment of atom <LI>quatw,quati,quatj,quatk = quaternion components for orientation of atom </UL> <P>The units for these quantities depend on the unit style; see the <A HREF = "units.html">units</A> command for details. </P> <P>For 2d simulations specify z as 0.0, or a value within the <I>zlo zhi</I> setting in the data file header. </P> <P>The atom-ID is used to identify the atom throughout the simulation and in dump files. Normally, it is a unique value from 1 to Natoms for each atom. Unique values larger than Natoms can be used, but they will cause extra memory to be allocated on each processor, if an atom map array is used (see the <A HREF = "atom_modify.html">atom_modify</A> command). If an atom map array is not used (e.g. an atomic system with no bonds), velocities are not assigned in the data file, and you don't care if unique atom IDs appear in dump files, then the atom-IDs can all be set to 0. </P> <P>The molecule ID is a 2nd identifier attached to an atom. Normally, it is a number from 1 to N, identifying which molecule the atom belongs to. It can be 0 if it is an unbonded atom or if you don't care to keep track of molecule assignments. </P> <P>The values <I>quatw</I>, <I>quati</I>, <I>quatj</I>, and <I>quatk</I> set the orientation of the atom as a quaternion (4-vector). Note that the <A HREF = "shape.html">shape</A> command or "Shapes" section of the data file specifies the aspect ratios of an ellipsoidal particle, which is oriented by default with its x-axis along the simulation box's x-axis, and similarly for y and z. If this body is rotated (via the right-hand rule) by an angle theta around a unit vector (a,b,c), then the quaternion that represents its new orientation is given by (cos(theta/2), a*sin(theta/2), b*sin(theta/2), c*sin(theta/2)). These 4 components are quatw, quati, quatj, and quatk as specified above. LAMMPS normalizes each atom's quaternion in case (a,b,c) was not a unit vector. </P> <P>For atom_style hybrid, following the 5 initial values (ID,type,x,y,z), specific values for each sub-style must be listed. The order of the sub-styles is the same as they were listed in the <A HREF = "atom_style.html">atom_style</A> command. The sub-style specific values are those that are not the 5 standard ones (ID,type,x,y,z). For example, for the "charge" sub-style, a "q" value would appear. For the "full" sub-style, a "molecule-ID" and "q" would appear. These are listed in the same order they appear as listed above. </P> <P>Thus if </P> <PRE>atom_style hybrid charge granular </PRE> <P>were used in the input script, each atom line would have these fields: </P> <PRE>atom-ID atom-type x y z q diameter density </PRE> <P>Atom lines (all lines or none of them) can optionally list 3 trailing integer values: nx,ny,nz. For periodic dimensions, they specify which -image of the box the atom is considered to be in. An image of 0 means -it is inside the box as defined. A value of 2 means add 2 box lengths -to get the true value. A value of -1 means subtract 1 box length to -get the true value. LAMMPS updates these flags as atoms cross -periodic boundaries during the simulation. The flags can be output -with atom snapshots via the <A HREF = "dump.html">dump</A> command. +image of the simulation box the atom is considered to be in. An image +of 0 means it is inside the box as defined. A value of 2 means add 2 +box lengths to get the true value. A value of -1 means subtract 1 box +length to get the true value. LAMMPS updates these flags as atoms +cross periodic boundaries during the simulation. The flags can be +output with atom snapshots via the <A HREF = "dump.html">dump</A> command. </P> <P>If nx,ny,nz values are not set in the data file, LAMMPS initializes them to 0. If image information is needed for later analysis and they are not all initially 0, it's important to set them correctly in the data file. Also, if you plan to use the <A HREF = "replicate.html">replicate</A> command to generate a larger system, these flags must be listed correctly for bonded atoms when the bond crosses a periodic boundary. I.e. the values of the image flags should be different by 1 (in the appropriate dimension) for the two atoms in such a bond. </P> <P>Atom velocities and other atom quantities not defined above are set to 0.0 when the <I>Atoms</I> section is read. Velocities can be set later by a <I>Velocities</I> section in the data file or by a <A HREF = "velocity.html">velocity</A> or <A HREF = "set.html">set</A> command in the input script. </P> <HR> <P><I>Bond Coeffs</I> section: </P> <UL><LI>one line per bond type <LI>line syntax: ID coeffs <PRE> ID = bond type (1-N) coeffs = list of coeffs </PRE> <LI>example: <PRE> 4 250 1.49 </PRE> </UL> <P>The number and meaning of the coefficients are specific to the defined bond style. See the <A HREF = "bond_style.html">bond_style</A> and <A HREF = "bond_coeff.html">bond_coeff</A> commands for details. Coefficients can also be set via the <A HREF = "bond_coeff.html">bond_coeff</A> command in the input script. </P> <HR> <P><I>BondAngle Coeffs</I> section: </P> <UL><LI>one line per angle type <LI>line syntax: ID coeffs <PRE> ID = angle type (1-N) coeffs = list of coeffs (see class 2 section of <A HREF = "angle_coeff.html">angle_coeff</A>) </PRE> </UL> <HR> <P><I>BondBond Coeffs</I> section: </P> <UL><LI>one line per angle type <LI>line syntax: ID coeffs <PRE> ID = angle type (1-N) coeffs = list of coeffs (see class 2 section of <A HREF = "angle_coeff.html">angle_coeff</A>) </PRE> </UL> <HR> <P><I>BondBond13 Coeffs</I> section: </P> <UL><LI>one line per dihedral type <LI>line syntax: ID coeffs <PRE> ID = dihedral type (1-N) coeffs = list of coeffs (see class 2 section of <A HREF = "dihedral_coeff.html">dihedral_coeff</A>) </PRE> </UL> <HR> <P><I>Bonds</I> section: </P> <UL><LI>one line per bond <LI>line syntax: ID type atom1 atom2 <PRE> ID = bond number (1-Nbonds) type = bond type (1-Nbondtype) atom1,atom2 = IDs of 1st,2nd atoms in bond </PRE> <LI>example: <PRE> 12 3 17 29 </PRE> </UL> <P>The <I>Bonds</I> section must appear after the <I>Atoms</I> section. All values in this section must be integers (1, not 1.0). </P> <HR> <P><I>Dihedral Coeffs</I> section: </P> <UL><LI>one line per dihedral type <LI>line syntax: ID coeffs <PRE> ID = dihedral type (1-N) coeffs = list of coeffs </PRE> <LI>example: <PRE> 3 0.6 1 0 1 </PRE> </UL> <P>The number and meaning of the coefficients are specific to the defined dihedral style. See the <A HREF = "dihedral_style.html">dihedral_style</A> and <A HREF = "dihedral_coeff.html">dihedral_coeff</A> commands for details. Coefficients can also be set via the <A HREF = "dihedral_coeff.html">dihedral_coeff</A> command in the input script. </P> <HR> <P><I>Dihedrals</I> section: </P> <UL><LI>one line per dihedral <LI>line syntax: ID type atom1 atom2 atom3 atom4 <PRE> ID = number of dihedral (1-Ndihedrals) type = dihedral type (1-Ndihedraltype) atom1,atom2,atom3,atom4 = IDs of 1st,2nd,3rd,4th atoms in dihedral </PRE> <LI>example: <PRE> 12 4 17 29 30 21 </PRE> </UL> <P>The 4 atoms are ordered linearly within the dihedral. The <I>Dihedrals</I> section must appear after the <I>Atoms</I> section. All values in this section must be integers (1, not 1.0). </P> <HR> <P><I>Dipoles</I> section: </P> <UL><LI>one line per atom type line syntax: ID dipole-moment <PRE> ID = atom type (1-N) dipole-moment = value of dipole moment </PRE> <LI>example: <PRE> 2 0.5 </PRE> </UL> <P>This defines the dipole moment of each atom type (which can be 0.0 for some types). This can also be set via the <A HREF = "dipole.html">dipole</A> command in the input script. </P> <HR> <P><I>EndBondTorsion Coeffs</I> section: </P> <UL><LI>one line per dihedral type <LI>line syntax: ID coeffs <PRE> ID = dihedral type (1-N) coeffs = list of coeffs (see class 2 section of <A HREF = "dihedral_coeff.html">dihedral_coeff</A>) </PRE> </UL> <HR> <P><I>Improper Coeffs</I> section: </P> <UL><LI>one line per improper type <LI>line syntax: ID coeffs <PRE> ID = improper type (1-N) coeffs = list of coeffs </PRE> <LI>example: <PRE> 2 20 0.0548311 </PRE> </UL> <P>The number and meaning of the coefficients are specific to the defined improper style. See the <A HREF = "improper_style.html">improper_style</A> and <A HREF = "improper_coeff.html">improper_coeff</A> commands for details. Coefficients can also be set via the <A HREF = "improper_coeff.html">improper_coeff</A> command in the input script. </P> <HR> <P><I>Impropers</I> section: </P> <UL><LI>one line per improper <LI>line syntax: ID type atom1 atom2 atom3 atom4 <PRE> ID = number of improper (1-Nimpropers) type = improper type (1-Nimpropertype) atom1,atom2,atom3,atom4 = IDs of 1st,2nd,3rd,4th atoms in improper </PRE> <LI>example: <PRE> 12 3 17 29 13 100 </PRE> </UL> <P>The ordering of the 4 atoms determines the definition of the improper angle used in the formula for each <A HREF = "improper_style.html">improper style</A>. See the doc pages for individual styles for details. </P> <P>The <I>Impropers</I> section must appear after the <I>Atoms</I> section. All values in this section must be integers (1, not 1.0). </P> <HR> <P><I>Masses</I> section: </P> <UL><LI>one line per atom type <LI>line syntax: ID mass <PRE> ID = atom type (1-N) mass = mass value </PRE> <LI>example: <PRE> 3 1.01 </PRE> </UL> <P>This defines the mass of each atom type. This can also be set via the <A HREF = "mass.html">mass</A> command in the input script. This section should not be used for atom styles that define a mass for individual atoms - e.g. atom style granular. </P> <HR> <P><I>MiddleBondTorsion Coeffs</I> section: </P> <UL><LI>one line per dihedral type <LI>line syntax: ID coeffs <PRE> ID = dihedral type (1-N) coeffs = list of coeffs (see class 2 section of <A HREF = "dihedral_coeff.html">dihedral_coeff</A>) </PRE> </UL> <HR> <P><I>Pair Coeffs</I> section: </P> <UL><LI>one line per atom type <LI>line syntax: ID coeffs <PRE> ID = atom type (1-N) coeffs = list of coeffs </PRE> <LI>example: <PRE> 3 0.022 2.35197 0.022 2.35197 </PRE> </UL> <P>The number and meaning of the coefficients are specific to the defined pair style. See the <A HREF = "pair_style.html">pair_style</A> and <A HREF = "pair_coeff.html">pair_coeff</A> commands for details. Coefficients can also be set via the <A HREF = "pair_coeff.html">pair_coeff</A> command in the input script. </P> <HR> <P><I>Shapes</I> section: </P> <UL><LI>one line per atom type <LI>line syntax: ID x y z <PRE> ID = atom type (1-N) x = x diameter y = y diameter z = z diameter </PRE> <LI>example: <PRE> 3 2.0 1.0 1.0 </PRE> </UL> <P>This defines the shape of each atom type. This can also be set via the <A HREF = "mass.html">shape</A> command in the input script. This section should only be used for atom styles that define a shape, e.g. atom style dipole or ellipsoid. </P> <HR> <P><I>Velocities</I> section: </P> <UL><LI>one line per atom <LI>line syntax: depends on atom style </UL> <DIV ALIGN=center><TABLE BORDER=1 > <TR><TD >all styles except those listed</TD><TD > atom-ID vx vy vz</TD></TR> <TR><TD >dipole</TD><TD > atom-ID vx vy vz wx wy wz</TD></TR> <TR><TD >ellipsoid</TD><TD > atom-ID vx vy vz lx ly lz</TD></TR> <TR><TD >granular</TD><TD > atom-ID vx vy vz wx wy wz </TD></TR></TABLE></DIV> <P>where the keywords have these meanings: </P> <UL><LI>vx,vy,vz = translational velocity of atom <LI>lx,ly,lz = angular momentum of aspherical atom <LI>wx,wy,wz = angular velocity of granular atom </UL> <P>The velocity lines can appear in any order. This section can only be used after an <I>Atoms</I> section. This is because the <I>Atoms</I> section must have assigned a unique atom ID to each atom so that velocities can be assigned to them. </P> <P>Vx,vy,vz are in <A HREF = "units.html">units</A> of velocity. Lx, ly, lz are in units of angular momentum (distance-velocity-mass). Wx,Wy,Wz are in units of angular velocity (radians/time). </P> <P>Translational velocities can also be set by the <A HREF = "velocity.html">velocity</A> command in the input script. </P> <HR> <P><B>Restrictions:</B> </P> <P>To read gzipped data files, you must compile LAMMPS with the -DLAMMPS_GZIP option - see the <A HREF = "Section_start.html#2_2">Making LAMMPS</A> section of the documentation. </P> <P><B>Related commands:</B> </P> <P><A HREF = "read_restart.html">read_restart</A>, <A HREF = "create_atoms.html">create_atoms</A> </P> <P><B>Default:</B> none </P> </HTML> diff --git a/doc/read_data.txt b/doc/read_data.txt index 4f5675dc7..e793f02dd 100644 --- a/doc/read_data.txt +++ b/doc/read_data.txt @@ -1,612 +1,612 @@ "LAMMPS WWW Site"_lws - "LAMMPS Documentation"_ld - "LAMMPS Commands"_lc :c :link(lws,http://lammps.sandia.gov) :link(ld,Manual.html) :link(lc,Section_commands.html#comm) :line read_data command :h3 [Syntax:] read_data file :pre file = name of data file to read in :ul [Examples:] read_data data.lj read_data ../run7/data.polymer.gz :pre [Description:] Read in a data file containing information LAMMPS needs to run a simulation. The file can be ASCII text or a gzipped text file (detected by a .gz suffix). This is one of 3 ways to specify initial atom coordinates; see the "read_restart"_read_restart.html and "create_atoms"_create_atoms.html commands for alternative methods. The structure of the data file is important, though many settings and sections are optional or can come in any order. See the examples directory for sample data files for different problems. A data file has a header and a body. The header appears first. The first line of the header is always skipped; it typically contains a description of the file. Then lines are read one at a time. Lines can have a trailing comment starting with '#' that is ignored. If the line is blank (only whitespace after comment is deleted), it is skipped. If the line contains a header keyword, the corresponding value(s) is read from the line. If it doesn't contain a header keyword, the line begins the body of the file. The body of the file contains zero or more sections. The first line of a section has only a keyword. The next line is skipped. The remaining lines of the section contain values. The number of lines depends on the section keyword as described below. Zero or more blank lines can be used between sections. Sections can appear in any order, with a few exceptions as noted below. The formatting of individual lines in the data file (indentation, spacing between words and numbers) is not important except that header and section keywords (e.g. atoms, xlo xhi, Masses, Bond Coeffs) must be capitalized as shown and can't have extra white space between their words - e.g. two spaces or a tab between "Bond" and "Coeffs" is not valid. :line These are the recognized header keywords. Header lines can come in any order. The value(s) are read from the beginning of the line. Thus the keyword {atoms} should be in a line like "1000 atoms"; the keyword {ylo yhi} should be in a line like "-10.0 10.0 ylo yhi"; the keyword {xy xz yz} should be in a line like "0.0 5.0 6.0 xy xz yz". All these settings have a default value of 0, except the lo/hi box size defaults are -0.5 and 0.5. A line need only appear if the value is different than the default. {atoms} = # of atoms in system {bonds} = # of bonds in system {angles} = # of angles in system {dihedrals} = # of dihedrals in system {impropers} = # of impropers in system {atom types} = # of atom types in system {bond types} = # of bond types in system {angle types} = # of angle types in system {dihedral types} = # of dihedral types in system {improper types} = # of improper types in system {xlo xhi} = simulation box boundaries in x dimension {ylo yhi} = simulation box boundaries in y dimension {zlo zhi} = simulation box boundaries in z dimension {xy xz yz} = simulation box tilt factors for triclinic domain :ul The initial simulation box size is determined by the lo/hi settings. In any dimension, the system may be periodic or non-periodic; see the "boundary"_boundary.html command. If the {xy xz yz} line does not appear, then LAMMPS will set up an axis-aligned (orthogonal) simulation box. If the line does appear, LAMMPS creates a non-orthogonal simulation domain shaped as a parallelepiped with triclinic symmetry. See the "region prism"_region.html command for a description of how the extent of the parallelepiped is defined. The parallelepiped has its "origin" at (xlo,ylo,zlo) and 3 edge vectors starting from the origin given by a = (xhi-xlo,0,0); b = (xy,yhi-ylo,0); c = (xz,yz,zhi-zlo). Note that if your simulation will tilt the box, e.g. via the "fix deform"_fix_deform.html command, the simulation box must be triclinic, even if the tilt factors are initially 0.0. The tilt factors (xy,xz,yz) can not skew the box more than half the distance of the parallel box length. For example, if xlo = 2 and xhi = 12, then the x box length is 10 and the xy tilt factor must be between -5 and 5. Similarly, both xz and yz must be between -(xhi-xlo)/2 and +(yhi-ylo)/2. Note that this is not a limitation, since if the maximum tilt factor is 5 (as in this example), then configurations with tilt = ..., -15, -5, 5, 15, 25, ... are all equivalent. When a triclinic system is used, the simulation domain must be periodic in any dimensions with a non-zero tilt factor, as defined by the "boundary"_boundary.html command. I.e. if the xy tilt factor is non-zero, then both the x and y dimensions must be periodic. Similarly, x and z must be periodic if xz is non-zero and y and z must be periodic if yz is non-zero. For 2d simulations, the {zlo zhi} values should be set to bound the z coords for atoms that appear in the file; the default of -0.5 0.5 is valid if all z coords are 0.0. For 2d triclinic simulations, the xz and yz tilt factors must be 0.0. If the system is periodic (in a dimension), then atom coordinates can be outside the bounds; they will be remapped (in a periodic sense) back inside the box. IMPORTANT NOTE: If the system is non-periodic (in a dimension), then all atoms in the data file must have coordinates (in that dimension) that are "greater than or equal to" the lo value and "less than or equal to" the hi value. If the non-periodic dimension is of style "fixed" (see the "boundary"_boundary.html command), then the atom coords must be strictly "less than" the hi value, due to the way LAMMPS assign atoms to processors. Note that you should not make the lo/hi values radically smaller/larger than the extent of the atoms. For example, if your atoms extend from 0 to 50, you should not specify the box bounds as -10000 and 10000. This is because LAMMPS uses the specified box size to layout the 3d grid of processors. A huge (mostly empty) box will be sub-optimal for performance and may cause a parallel simulation to lose atoms if LAMMPS shrink-wraps the box around the atoms. :line These are the section keywords for the body of the file. {Atoms, Velocities, Masses, Shapes, Dipoles} = atom-property sections {Bonds, Angles, Dihedrals, Impropers} = molecular topology sections {Pair Coeffs, Bond Coeffs, Angle Coeffs, Dihedral Coeffs, \ Improper Coeffs} = force field sections {BondBond Coeffs, BondAngle Coeffs, MiddleBondTorsion Coeffs, \ EndBondTorsion Coeffs, AngleTorsion Coeffs, AngleAngleTorsion Coeffs, \ BondBond13 Coeffs, AngleAngle Coeffs} = class 2 force field sections :ul Each section is listed below in alphabetic order. The format of each section is described including the number of lines it must contain and rules (if any) for where it can appear in the data file. Any individual line in the various sections can have a trailing comment starting with "#" for annotation purposes. E.g. in the Atoms section: 10 1 17 -1.0 10.0 5.0 6.0 # salt ion :pre :line {Angle Coeffs} section: one line per angle type :ulb,l line syntax: ID coeffs :l ID = angle type (1-N) coeffs = list of coeffs :pre example: :l 6 70 108.5 0 0 :pre :ule The number and meaning of the coefficients are specific to the defined angle style. See the "angle_style"_angle_style.html and "angle_coeff"_angle_coeff.html commands for details. Coefficients can also be set via the "angle_coeff"_angle_coeff.html command in the input script. :line {AngleAngle Coeffs} section: one line per improper type :ulb,l line syntax: ID coeffs :l ID = improper type (1-N) coeffs = list of coeffs (see "improper_coeff"_improper_coeff.html) :pre :ule :line {AngleAngleTorsion Coeffs} section: one line per dihedral type :ulb,l line syntax: ID coeffs :l ID = dihedral type (1-N) coeffs = list of coeffs (see "dihedral_coeff"_dihedral_coeff.html) :pre :ule :line {Angles} section: one line per angle :ulb,l line syntax: ID type atom1 atom2 atom3 :l ID = number of angle (1-Nangles) type = angle type (1-Nangletype) atom1,atom2,atom3 = IDs of 1st,2nd,3rd atoms in angle :pre example: :b 2 2 17 29 430 :pre :ule The 3 atoms are ordered linearly within the angle. Thus the central atom (around which the angle is computed) is the atom2 in the list. E.g. H,O,H for a water molecule. The {Angles} section must appear after the {Atoms} section. All values in this section must be integers (1, not 1.0). :line {AngleTorsion Coeffs} section: one line per dihedral type :ulb,l line syntax: ID coeffs :l ID = dihedral type (1-N) coeffs = list of coeffs (see "dihedral_coeff"_dihedral_coeff.html) :pre :ule :line {Atoms} section: one line per atom line syntax: depends on atom style :ul An {Atoms} section must appear in the data file if natoms > 0 in the header section. The atoms can be listed in any order. These are the line formats for each "atom style"_atom_style.html in LAMMPS. As discussed below, each line can optionally have 3 flags (nx,ny,nz) appended to it, which indicate which image of a periodic simulation box the atom is in. These may be important to include for some kinds of analysis. angle: atom-ID molecule-ID atom-type x y z atomic: atom-ID atom-type x y z bond: atom-ID molecule-ID atom-type x y z charge: atom-ID atom-type q x y z dipole: atom-ID atom-type q x y z mux muy muz dpd: atom-ID atom-type x y z ellipsoid: atom-ID atom-type x y z quatw quati quatj quatk full: atom-ID molecule-ID atom-type q x y z granular: atom-ID atom-type diameter density x y z molecular: atom-ID molecule-ID atom-type x y z peri: atom-ID atom-type volume density x y z hybrid: atom-ID atom-type x y z sub-style1 sub-style2 ... :tb(s=:) The keywords have these meanings: atom-ID = integer ID of atom molecule-ID = integer ID of molecule the atom belongs to type-ID = type of atom (1-Ntype) q = charge on atom (charge units) diameter = diameter of atom (distance units) density = density of atom (mass/distance^3 units) volume = volume of atom (distance^3 units) x,y,z = coordinates of atom mux,muy,muz = direction of dipole moment of atom quatw,quati,quatj,quatk = quaternion components for orientation of atom :ul The units for these quantities depend on the unit style; see the "units"_units.html command for details. For 2d simulations specify z as 0.0, or a value within the {zlo zhi} setting in the data file header. The atom-ID is used to identify the atom throughout the simulation and in dump files. Normally, it is a unique value from 1 to Natoms for each atom. Unique values larger than Natoms can be used, but they will cause extra memory to be allocated on each processor, if an atom map array is used (see the "atom_modify"_atom_modify.html command). If an atom map array is not used (e.g. an atomic system with no bonds), velocities are not assigned in the data file, and you don't care if unique atom IDs appear in dump files, then the atom-IDs can all be set to 0. The molecule ID is a 2nd identifier attached to an atom. Normally, it is a number from 1 to N, identifying which molecule the atom belongs to. It can be 0 if it is an unbonded atom or if you don't care to keep track of molecule assignments. The values {quatw}, {quati}, {quatj}, and {quatk} set the orientation of the atom as a quaternion (4-vector). Note that the "shape"_shape.html command or "Shapes" section of the data file specifies the aspect ratios of an ellipsoidal particle, which is oriented by default with its x-axis along the simulation box's x-axis, and similarly for y and z. If this body is rotated (via the right-hand rule) by an angle theta around a unit vector (a,b,c), then the quaternion that represents its new orientation is given by (cos(theta/2), a*sin(theta/2), b*sin(theta/2), c*sin(theta/2)). These 4 components are quatw, quati, quatj, and quatk as specified above. LAMMPS normalizes each atom's quaternion in case (a,b,c) was not a unit vector. For atom_style hybrid, following the 5 initial values (ID,type,x,y,z), specific values for each sub-style must be listed. The order of the sub-styles is the same as they were listed in the "atom_style"_atom_style.html command. The sub-style specific values are those that are not the 5 standard ones (ID,type,x,y,z). For example, for the "charge" sub-style, a "q" value would appear. For the "full" sub-style, a "molecule-ID" and "q" would appear. These are listed in the same order they appear as listed above. Thus if atom_style hybrid charge granular :pre were used in the input script, each atom line would have these fields: atom-ID atom-type x y z q diameter density :pre Atom lines (all lines or none of them) can optionally list 3 trailing integer values: nx,ny,nz. For periodic dimensions, they specify which -image of the box the atom is considered to be in. An image of 0 means -it is inside the box as defined. A value of 2 means add 2 box lengths -to get the true value. A value of -1 means subtract 1 box length to -get the true value. LAMMPS updates these flags as atoms cross -periodic boundaries during the simulation. The flags can be output -with atom snapshots via the "dump"_dump.html command. +image of the simulation box the atom is considered to be in. An image +of 0 means it is inside the box as defined. A value of 2 means add 2 +box lengths to get the true value. A value of -1 means subtract 1 box +length to get the true value. LAMMPS updates these flags as atoms +cross periodic boundaries during the simulation. The flags can be +output with atom snapshots via the "dump"_dump.html command. If nx,ny,nz values are not set in the data file, LAMMPS initializes them to 0. If image information is needed for later analysis and they are not all initially 0, it's important to set them correctly in the data file. Also, if you plan to use the "replicate"_replicate.html command to generate a larger system, these flags must be listed correctly for bonded atoms when the bond crosses a periodic boundary. I.e. the values of the image flags should be different by 1 (in the appropriate dimension) for the two atoms in such a bond. Atom velocities and other atom quantities not defined above are set to 0.0 when the {Atoms} section is read. Velocities can be set later by a {Velocities} section in the data file or by a "velocity"_velocity.html or "set"_set.html command in the input script. :line {Bond Coeffs} section: one line per bond type :ulb,l line syntax: ID coeffs :l ID = bond type (1-N) coeffs = list of coeffs :pre example: :l 4 250 1.49 :pre :ule The number and meaning of the coefficients are specific to the defined bond style. See the "bond_style"_bond_style.html and "bond_coeff"_bond_coeff.html commands for details. Coefficients can also be set via the "bond_coeff"_bond_coeff.html command in the input script. :line {BondAngle Coeffs} section: one line per angle type :ulb,l line syntax: ID coeffs :l ID = angle type (1-N) coeffs = list of coeffs (see class 2 section of "angle_coeff"_angle_coeff.html) :pre :ule :line {BondBond Coeffs} section: one line per angle type :ulb,l line syntax: ID coeffs :l ID = angle type (1-N) coeffs = list of coeffs (see class 2 section of "angle_coeff"_angle_coeff.html) :pre :ule :line {BondBond13 Coeffs} section: one line per dihedral type :ulb,l line syntax: ID coeffs :l ID = dihedral type (1-N) coeffs = list of coeffs (see class 2 section of "dihedral_coeff"_dihedral_coeff.html) :pre :ule :line {Bonds} section: one line per bond :ulb,l line syntax: ID type atom1 atom2 :l ID = bond number (1-Nbonds) type = bond type (1-Nbondtype) atom1,atom2 = IDs of 1st,2nd atoms in bond :pre example: :l 12 3 17 29 :pre :ule The {Bonds} section must appear after the {Atoms} section. All values in this section must be integers (1, not 1.0). :line {Dihedral Coeffs} section: one line per dihedral type :ulb,l line syntax: ID coeffs :l ID = dihedral type (1-N) coeffs = list of coeffs :pre example: :l 3 0.6 1 0 1 :pre :ule The number and meaning of the coefficients are specific to the defined dihedral style. See the "dihedral_style"_dihedral_style.html and "dihedral_coeff"_dihedral_coeff.html commands for details. Coefficients can also be set via the "dihedral_coeff"_dihedral_coeff.html command in the input script. :line {Dihedrals} section: one line per dihedral :ulb,l line syntax: ID type atom1 atom2 atom3 atom4 :l ID = number of dihedral (1-Ndihedrals) type = dihedral type (1-Ndihedraltype) atom1,atom2,atom3,atom4 = IDs of 1st,2nd,3rd,4th atoms in dihedral :pre example: :l 12 4 17 29 30 21 :pre :ule The 4 atoms are ordered linearly within the dihedral. The {Dihedrals} section must appear after the {Atoms} section. All values in this section must be integers (1, not 1.0). :line {Dipoles} section: one line per atom type :ulb,l line syntax: ID dipole-moment : ID = atom type (1-N) dipole-moment = value of dipole moment :pre example: :l 2 0.5 :pre :ule This defines the dipole moment of each atom type (which can be 0.0 for some types). This can also be set via the "dipole"_dipole.html command in the input script. :line {EndBondTorsion Coeffs} section: one line per dihedral type :ulb,l line syntax: ID coeffs :l ID = dihedral type (1-N) coeffs = list of coeffs (see class 2 section of "dihedral_coeff"_dihedral_coeff.html) :pre :ule :line {Improper Coeffs} section: one line per improper type :ulb,l line syntax: ID coeffs :l ID = improper type (1-N) coeffs = list of coeffs :pre example: :l 2 20 0.0548311 :pre :ule The number and meaning of the coefficients are specific to the defined improper style. See the "improper_style"_improper_style.html and "improper_coeff"_improper_coeff.html commands for details. Coefficients can also be set via the "improper_coeff"_improper_coeff.html command in the input script. :line {Impropers} section: one line per improper :ulb,l line syntax: ID type atom1 atom2 atom3 atom4 :l ID = number of improper (1-Nimpropers) type = improper type (1-Nimpropertype) atom1,atom2,atom3,atom4 = IDs of 1st,2nd,3rd,4th atoms in improper :pre example: :l 12 3 17 29 13 100 :pre :ule The ordering of the 4 atoms determines the definition of the improper angle used in the formula for each "improper style"_improper_style.html. See the doc pages for individual styles for details. The {Impropers} section must appear after the {Atoms} section. All values in this section must be integers (1, not 1.0). :line {Masses} section: one line per atom type :ulb,l line syntax: ID mass :l ID = atom type (1-N) mass = mass value :pre example: :l 3 1.01 :pre :ule This defines the mass of each atom type. This can also be set via the "mass"_mass.html command in the input script. This section should not be used for atom styles that define a mass for individual atoms - e.g. atom style granular. :line {MiddleBondTorsion Coeffs} section: one line per dihedral type :ulb,l line syntax: ID coeffs :l ID = dihedral type (1-N) coeffs = list of coeffs (see class 2 section of "dihedral_coeff"_dihedral_coeff.html) :pre :ule :line {Pair Coeffs} section: one line per atom type :ulb,l line syntax: ID coeffs :l ID = atom type (1-N) coeffs = list of coeffs :pre example: :l 3 0.022 2.35197 0.022 2.35197 :pre :ule The number and meaning of the coefficients are specific to the defined pair style. See the "pair_style"_pair_style.html and "pair_coeff"_pair_coeff.html commands for details. Coefficients can also be set via the "pair_coeff"_pair_coeff.html command in the input script. :line {Shapes} section: one line per atom type :ulb,l line syntax: ID x y z :l ID = atom type (1-N) x = x diameter y = y diameter z = z diameter :pre example: :l 3 2.0 1.0 1.0 :pre :ule This defines the shape of each atom type. This can also be set via the "shape"_mass.html command in the input script. This section should only be used for atom styles that define a shape, e.g. atom style dipole or ellipsoid. :line {Velocities} section: one line per atom line syntax: depends on atom style :ul all styles except those listed: atom-ID vx vy vz dipole: atom-ID vx vy vz wx wy wz ellipsoid: atom-ID vx vy vz lx ly lz granular: atom-ID vx vy vz wx wy wz :tb(s=:) where the keywords have these meanings: vx,vy,vz = translational velocity of atom lx,ly,lz = angular momentum of aspherical atom wx,wy,wz = angular velocity of granular atom :ul The velocity lines can appear in any order. This section can only be used after an {Atoms} section. This is because the {Atoms} section must have assigned a unique atom ID to each atom so that velocities can be assigned to them. Vx,vy,vz are in "units"_units.html of velocity. Lx, ly, lz are in units of angular momentum (distance-velocity-mass). Wx,Wy,Wz are in units of angular velocity (radians/time). Translational velocities can also be set by the "velocity"_velocity.html command in the input script. :line [Restrictions:] To read gzipped data files, you must compile LAMMPS with the -DLAMMPS_GZIP option - see the "Making LAMMPS"_Section_start.html#2_2 section of the documentation. [Related commands:] "read_restart"_read_restart.html, "create_atoms"_create_atoms.html [Default:] none