Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
af3d2ff
A first commit with some initial description of the
Bibobu Nov 13, 2023
c700bad
Some edits to continue the initial lesson.
Bibobu Nov 13, 2023
8ded3f9
Added a basic structure of the tutorial in three steps. Added simple
Bibobu Nov 23, 2023
59c61e2
made some minor changes to the text
simongravelle Nov 23, 2023
da47092
Added labels to files at the top.
Bibobu Nov 25, 2023
c88f9a5
Changes visualizing file name to american english spelling
Bibobu Nov 25, 2023
70641e3
Corrected a file name in Beginner.rst
Bibobu Nov 26, 2023
1cc9d24
Adding the end of the file setting_up_simulations and reference to
Bibobu Nov 26, 2023
8cd58c3
Added a mention to the general [Classics] ref.
Bibobu Dec 18, 2023
d8c1bc0
Homogen. references to commands, added some [Classics] ref.
Bibobu Dec 18, 2023
c353468
Continued the writing of running_and_pp.
Bibobu Dec 18, 2023
af102ea
Revert "Continued the writing of running_and_pp."
Bibobu Dec 18, 2023
8767856
Revert "Homogen. references to commands, added some [Classics] ref."
Bibobu Dec 18, 2023
0f485c8
Revert "Added a mention to the general [Classics] ref."
Bibobu Dec 18, 2023
7a7ca18
Update src/file_format.rst
Bibobu Jan 15, 2024
a01bbf8
Update src/file_format.rst
Bibobu Jan 15, 2024
fa9d9cc
Update src/file_format.rst
Bibobu Jan 15, 2024
4773a5e
Update src/file_format.rst
Bibobu Jan 15, 2024
83794c0
Update src/file_format.rst
Bibobu Jan 15, 2024
e8ac14a
Update src/file_format.rst
Bibobu Jan 15, 2024
c27c722
Update src/file_format.rst
Bibobu Jan 15, 2024
c9c4f23
Update src/file_format.rst
Bibobu Jan 15, 2024
b0650bc
Update src/file_format.rst
Bibobu Jan 15, 2024
a94cec0
Update src/setting_up_simulations.rst
Bibobu Jan 15, 2024
62ebc91
Update src/setting_up_simulations.rst
Bibobu Jan 15, 2024
547295c
Update src/file_format.rst
Bibobu Jan 15, 2024
871f8c6
Some rst formating in file_format.rst.
Bibobu Jan 15, 2024
79e4a61
Re-added the mention of [Classics] MD texts.
Bibobu Jan 15, 2024
18528b2
Mentioned the last version of LAMMPS is assumed in the text.
Bibobu Jan 15, 2024
9db8f73
Added links to several commands' manual pages.
Bibobu Jan 15, 2024
8e200dc
Added mention of [Classics].
Bibobu Jan 15, 2024
245d0b7
Continued writing of running and post_processing.
Bibobu Jan 15, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 16 additions & 0 deletions src/Advanced.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
.. _Advanced:

Advanced Section
================

These pages provide introduction tutorials for people familiar with molecular
simulation who want to "get things done" in LAMMPS

..
From G.Clavier:
WIP: This section might use or refer to more of the material in the How-to
section of the manual

.. toctree::
:maxdepth: 1

17 changes: 17 additions & 0 deletions src/Beginner.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
.. _Beginner:

Beginner Section
================

These pages provide introduction tutorials for people unfamiliar with molecular
simulation softwares and practice.

.. toctree::
:maxdepth: 1

file_format
setting_up_simulations
running_and_post_processing
variables_computes_fixes
averages_and_on_the_fly_computation
visualizing_trajectories
17 changes: 17 additions & 0 deletions src/Confirmed.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
.. _Confirmed:

Confirmed Section
=================

These pages provide introduction tutorials for people who have a good knowledge
of LAMMPS and want to go deeper in setting complicated simulation environment
or Python coupling.

..
From G.Clavier:
WIP: This section might get technical but given the current state of LAMMPS
questions in the forum, this is not the most pressing matter IMO.

.. toctree::
:maxdepth: 1

60 changes: 60 additions & 0 deletions src/Learning_MD.rst
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,63 @@ Learning Molecular Dynamics with LAMMPS (version |version|)
LAMMPS is a classical molecular dynamics simulation code focusing on
materials modeling.

Quoting the first paragraph of the overview section of the manual_:

LAMMPS is a classical molecular dynamics (MD) code that models ensembles of
particles in a liquid, solid, or gaseous state. It can model atomic,
polymeric, biological, solid-state (metals, ceramics, oxides), granular,
coarse-grained, or macroscopic systems using a variety of interatomic
potentials (force fields) and boundary conditions. It can model 2d or 3d
systems with sizes ranging from only a few particles up to billions.

In this tutorials, you will find step-by-step guides that aim at giving you
some fundamental comprehension of the code, basic input/output manipulation and
visualization of your simulation in order to give you some autonomy in the use
of the LAMMPS software. This does not replace proper teaching of statistical
mechanics and direct adivising from skilled users close to you and your work
environment but should give you some basic understanding to start your learning
of molecular simulation.

These tutorials assume you are familiar with text file manipulation, basic
command-line use and your computer environment. They also assume you already
have the last version of LAMMPS executable installed. If not, contact your IT
departement or follow the `installation guide
<https://docs.lammps.org/Install.html>`_ from the manual. If necessary, also
see `how to run LAMMPS executable dedicated section.
<https://docs.lammps.org/Run_head.html>`_ LAMMPS usage is generally easier on
UNIX like systems (Linux distributions, macOS) so most examples will assume
this type of environment. On Windows systems, you can set-up WSL to be in an
equivalent environment.

As for now the tutorial is organised in three main sections, mainly:

1. Beginner: for people who have no experience whatsoever with molecular
simulation codes
2. Advanced: for people with some familiarity with molecular simulation that
want to know how to do more refined things in LAMMPS.
3. Confirmed: Detailed discussions on the howto examples from the manual.

.. note:
As this is a LAMMPS tutorial and not a molecular simulation tutorial, some
topics of general knowledge will not be covered in details here. You will
find more information in classical textbooks such as Allen and Tildesley
"Computer simulation of fluids", Frenkel and Smit "Understanding molecular
simulation" and many others statistical physics textbooks. Such topics shall
be noted with a reference to "Classical textbooks".

****************
Table of content
****************

.. toctree::
:maxdepth: 2
:numbered: 2
:caption: Table of content
:name: tutorialtoc
:includehidden:

Beginner
Advanced
Confirmed

.. _manual: https://docs.lammps.org
6 changes: 6 additions & 0 deletions src/averages_and_on_the_fly_computation.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
.. _averages-calculations:

=====================================================
Using averages and computing values during simulation
=====================================================

211 changes: 211 additions & 0 deletions src/file_format.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,211 @@
.. _file-format:

================================
Introduction to the file formats
================================

LAMMPS internally keeps track of the evolution of atomistic systems. Such a
system is described as a `simulation box` containing an ensemble of particles
interacting with one another according to set of rules, and each with their own
position, velocities etc.

In this section, you will learn how to create a very simple simulation box
using LAMMPS built-in tools.

Running a minimal LAMMPS input
------------------------------

In an empty directory, open a text file and copy the following text inside:

.. code-block:: LAMMPS

atom_style atomic
lattice sc 1.
region box block 0 5 0 5 0 5
create_box 1 box
create_atoms 1 box

mass 1 1

write_data data.lmp
write_dump all atom dump.lammpstrj

Let's save the file with the name `in.lmp`. Now in the command-line you can
run the following command to execute LAMMPS with this input:

.. code-block:: bash

lmp -i in.lmp

You should see a bunch of lines appear in your screen. The first one should start
with `LAMMPS` followed by a parentheses with the specification of the version
of the code you are using. The last line should read something like
`Total wall time: 00:00:00`. If you've never executed LAMMPS before,
congratulation! This is maybe your first successful (very simple) simulation!

You will also notice that two files appeared in the directory: `data.lmp` and
`dump.lammpstrj`. Let's start by opening the first one.

Data file format
****************

The first file of the two is usually referred to as a `data file`. Its format
is rather strict, containing:

* a "header" block, which must come first in the file, and
* several "data sections", each of which:

* starts with a capitalized keyword (such as "Atoms" or "Velocities")
* followed by a blank line
* and then a block of numbers (such as each atom's ID, x, y, and z velocities in "Velocities")

Let's slowly go through all of this.

The first part of the file is called `the header`. The first line of the file
is always a comment that LAMMPS does not read but which can contain
information on the way the file was generated. Here we see the LAMMPS version
and some more information like timestep and units. The following lines contain
the number of `atoms` (125), the number of `atom types` (1) and three lines
containing `xlo xhi` like indications. This header is simple, but generally,
headers can contain much more information. The first two lines are explicit,
you define a system with 125 atoms all of which have the same characteristics.
They all have the same characteristics because your simulation has only one `atom type`;
you will soon learn how to specify different interactions between particles
in LAMMPS by giving the particles different atom types.
The last three lines define the volume in which these atoms are contained. It
is a box with edge coordinates starting at 0 and ending at 5 in every direction
(x, y and z).

From here starts the body of the file. The order of the sections is not important
but all of them must come in the format:

.. code-block:: LAMMPS

Section name # Capitalized, correctly spelled
# blank line
Section input # Number of line and format depend on the section.

The first section you should see is the `Masses` section. In LAMMPS, masses are
usually assigned by atom types. Since you have only one atom type
in this simulation, this `Masses` section has only one line.

The `Atoms` section contains 125 lines, one per atom. The number on each line
are ordered and are for each particle:
* The particle ID which LAMMPS uses to refer to that particle internally
* The type of the particle
* The x, y and z coordinates in absolute distance value
* The xflag, yflag and zflag values, which you can put aside for now

Below you can also see the `Velocities` section which also contains 125 lines.
Each lines gives the particle ID followed by the instantaneous velocities of
the particles along the x, y and z axis in that order. The particle ID refers
to the same ID as in the `Atoms` section.

This data file is quite simple because our Very First LAMMPS Script had the
`atom_style` `atomic`, where each particle only has an ID number
and a three-dimensional position and velocity (and periodic image location).
More detailed simulations will use other `atom_style` commands,
such as `atom_style molecular`, which also tracks molecule ID
numbers and intramolecular arrangements like bonds,
angles, "dihedrals" and "impropers" (which you will learn about later).
You can see that LAMMPS includes a comment `# atomic` next to the
`Atoms` section name (here `# atomic`), and you can find a detailed
description of each format in the `read_data section of the manual`_.

You may have noticed our first LAMMPS script also produced a `dump file`.
We will now read through this dump file, and then learn how it is
different from a data file and how to use each file type.

Dump file format
****************

Following the previous sections, open the `dump.lammpstrj` file that should
have appeared in your directory. This is a `dump file` containing a single
`snapshot` You should see something like this:

.. code-block:: LAMMPS

ITEM: TIMESTEP
0
ITEM: NUMBER OF ATOMS
125
ITEM: BOX BOUNDS pp pp pp
0.0000000000000000e+00 5.0000000000000000e+00
0.0000000000000000e+00 5.0000000000000000e+00
0.0000000000000000e+00 5.0000000000000000e+00
ITEM: ATOMS id type xs ys zs
1 1 0 0 0
2 1 0.2 0 0
3 1 0.4 0 0
4 1 0.6 0 0
5 1 0.8 0 0
...

The dump file format is simpler than the data file. Each section is labeled
with a header directly followed by the data we wanted to dump. Here we used the
basic atom dump_style so we only have atoms' id, types and scaled coordinates
(that is coordinates divided by box length in each dimension).

From the TIMESTEP heading, you might guess that a dump file will
usually contain information about how a simulation changes `over time`,
and you would be correct! Thus, a `data` file is used to store the `complete`
state of a simulation with the `write_data` command, and in later lessons
you will see how to start a new simulation from that state with the
`read_data` command. On the other hand, a `dump` file stores information
about how the system changes over time, and can then be used for analyzing
simulation results.

If you (or your supervisor) have previously used other molecular dynamics
software, you may recognize that the dump file loosely corresponds to "coordinates"
or "trajectory" output files from other software. However, LAMMPS gives you
great flexibility in what you choose to output. For example, the default `dump` format
outputs scaled coordinates, but we will soon see how to output unscaled
coordinates instead. You may know that other molecular dynamics packages
store information that `does not` change throughout a simulation (such as
molecular bonds and particle charges) in "parameter", "topology" or
"configuration" files. In LAMMPS, this information is read from a `data` file, but
the `data` file also usually contains coordinates and velocities.

As an example of customizing the dump file,
in your `in.lmp` file, replace the `write_dump` line with the following:

.. code-block:: LAMMPS

write_dump all custom dump.lammpstrj id type x y z vx vy vz

Save the file, and run the code as previously:

.. code-block:: bash

lmp -i in.lmp

Now the `dump.lammpstrj` file should have changed to the following:

.. code-block:: LAMMPS

ITEM: TIMESTEP
0
ITEM: NUMBER OF ATOMS
125
ITEM: BOX BOUNDS pp pp pp
0.0000000000000000e+00 5.0000000000000000e+00
0.0000000000000000e+00 5.0000000000000000e+00
0.0000000000000000e+00 5.0000000000000000e+00
ITEM: ATOMS id type x y z vx vy vz
1 1 0 0 0 0 0 0
2 1 1 0 0 0 0 0
3 1 2 0 0 0 0 0
4 1 3 0 0 0 0 0
5 1 4 0 0 0 0 0
...

The `custom` format allows
you to write every properties of each atoms to the file. There are a series of
keywords that you can use depending on the `atom_style` and values that you
can also calculate through the use of LAMMPS computes and variables. More on
that in later tutorials.

For now on we haven't done much with our atoms. Let's see how to run an actual
simulation in the :ref:`setting-up-simulations` section.

.. _read_data section of the manual: https://docs.lammps.org/read_data.html
Binary file added src/images/Lennard-Jones.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading