According to the official website, GROMACS is:
- a versatile package to perform molecular dynamics, i.e. simulate the Newtonian equations of motion for systems with hundreds to millions of particles.
- It is primarily designed for biochemical molecules like proteins, lipids and nucleic acids that have a lot of complicated bonded interactions, but since GROMACS is extremely fast at calculating the nonbonded interactions (that usually dominate simulations) many groups are also using it for research on non-biological systems, e.g. polymers.
Install the AUR or AUR[broken link: package not found] package. Be sure to edit the PKGBUILD to suit your system (i.e. for MPI or GPU support). Some of the cmake options you may want to add/modify in the PKGBUILD are (cf.the latest GROMACS installation guide):
-DGMX_DOUBLE=ON- Add if you need double precision. According to the GROMACS install guide, double precision is "slower, and not normally useful." If you set this flag, the default suffix for all GROMACS programs is set to
-DGMX_GPU=ON- Add in order to build with GPU support. Several other flags may be necessary; refer to the latest GROMACS installation guide.
-DGMX_MPI=ON- Add to create a build able to run across multiple compute nodes. You will also need to have an MPI library such as or AUR. If you do not need MPI support (i.e., you just run on a single computer), you do not need this flag. If you set this flag, the default suffix for all GROMACS programs is set to
-DGMX_SIMD=xxx- GROMACS should detect the best SIMD instructions for your processor, so this flag should not be needed. But if you have some kind of compilation error, you can specify the SIMD level here. A list of available options for
xxxis listed in the latest GROMACS installation guide.
-march=nativeto successfully compile with AVX2_256 instructions.
-DGMX_X11=ON- Set to use
gmx view, the built-in trajectory viewer. This flag requires the and packages.
-DREGRESSIONTEST_DOWNLOAD=ON- Set to test your GROMACS build. To run the tests set your build to run
make check. The package is required.
-DGMX_DEFAULT_SUFFIX=OFF- Set to turn of default suffix for GROMACS programs for MPI or double precision builds.
-DGMX_LIBS_SUFFIX=xxx- Set the default suffix to xxx for binaries and libraries, respectively.
Some other packages that may increase performance are:
- Boost library can be used to provide better implementation support for smart pointers and exception handling. - An external
- - Run-time detection of hardware capabilities can be improved by linking with hwloc
- - Hardware-optimized BLAS and LAPACK libraries are useful for a few of the GROMACS utilities focused on normal modes and matrix manipulation, but they do not provide any benefits for normal simulations.
The broken link: package not found] package contains the latest development source, and should not be used in production.AUR[
By default the top-level force field directory is located at
/usr/share/gromacs/top. This can be changed by setting a different directory to the
GMXLIB environment variable. This is useful if you make modifications to a force field, or if you have another set of force fields you would like to use.
Below is a basic workflow with most of the major commands mentioned. Every command should begin with
gmx. For more details on using GROMACS find a good tutorial and read the manual. A helpful flow chart is here.
gmxand the command. For example, the man page for gmx pdb2gmx is located at
Simulations require a structure file (
.pdb), a topology file (
.top), and a parameters file (
.mdp). The following steps illustrate how to obtain these.
Obtain structure file
Generate a topology
A topology file indicates how atomic particles interact with one another. One method for generating a topology file is to use gmx pdb2gmx. If your solute is in a file named
protein.pdb, do the following:
$ gmx pdb2gmx -f protein.pdb
If you did not obtain your structure file from a protein database, but instead created it yourself, most likely you will need to create a residue template file (
.rtp) for your molecule as well as update the
.pdb file. An example
.rtp file for OPLS methane is found here with its corresponding
.pdb file here. The
.rtp file must be placed in the force field directory for the force field you are going to use.
See below for alternative ways to generate or obtain topologies.
A quick way to create a simulation box full of water around a solute is to do:
$ gmx solvate -cp conf.gro -cs water -box X Y Z -o conf.gro -p topol.top
In the above the solute/protein's coordinates are initially stored in
conf.gro. A water model using water.gro (either found in the top-level force field directory or the current one) is used to fill the box with solvent, and the box dimensions are
Z. The topology file,
topol.top is updated and the new system is output to
-cs is omitted, a three-point water model is used. The other available water structures are
tip4pis simply a set of four-point water model coordinates and can correspond to any four-point water model, not just TIP4P.
If the system is not charge-neutral, ions should generally be added. For example if the net charge of your system is -2, to add two positive sodium ions do:
$ gmx grompp -f grompp.mdp $ gmx genion -s topol.tpr -np 2 -pname Na -o conf.gro -p topol.top
Then select the index group corresponding with the solvent, which will be replaced by the ions. The
-nname argument should correspond to an ion in the force field you are using.
.mdpfile does not need to correspond to any particular simulation step. It is only used to generate the
.tprfile for gmx genion.
A parameters file should be created for each different step of a set of simulations (e.g., minimization, equilibration, production). A list of all possible options is here.
Here is a sample parameter file for a ten second production run at standard conditions:
dt = 0.002 nsteps = 5000000 nstxout-compressed = 2500 coulombtype = PME rcoulomb = 1.0 vdwtype = Cut-off rvdw = 1.0 DispCorr = EnerPres tcoupl = Nose-Hoover nh-chain-length = 1 tc-grps = System tau-t = 2.0 ref-t = 298.15 pcoupl = Parrinello-Rahman tau_p = 2.0 compressibility = 4.46e-5 ref_p = 1.0 constraints = h-bonds continuation = yes
Simulations typically consist of two parts, described below.
First, there is a preprocessing step where the structure file, topology file, and parameters file are read in and written out to a single
.tpr file, also sometimes referred to as a topology file:
$ gmx grompp -f grompp.mdp -c conf.gro -p topol.top -o topol.tpr
grompp.mdp is the parameters file for this simulation step,
conf.gro is the structure file that begins this simulation step, and
topol.top is the topology file. A structure file (
.gro) is output at the end of every simulation, so it should be used with
-c in a simulation that continues from the previous one (e.g., an initial equilibration run should use the structure file output from a previous minimization step).
-tflag (instead of just a structure file with
-c), since it contains additional information. When using both the
-tflags gmx grompp checks for the checkpoint file first, and if it is not found, then falls back to the structure file indicated. If a structure file is not indicated in this case, the default filename
Next, there is the actual simulation. The
.tpr file is read in with the main program gmx mdrun to run the simulation:
$ gmx mdrun -s topol.tpr
In general these two parts are repeated for an energy minimization step, an equilibration step, and a production step. Multiple equilibration steps may be needed, especially when turning on pressure coupling. The production step and the last equilibration step should use the exact same parameters (
.mdp) except for the length of the simulation.
As an example, a set of simulations consisting of one minimization step, one equilbration step, and one production step might look like this:
#!/bin/bash gmx grompp -f min.mdp -o min.tpr -c conf.gro -p topol.top gmx mdrun -deffnm min gmx grompp -f eql.mdp -o eql.tpr -c min.gro -p topol.top gmx mdrun -deffnm eql gmx grompp -f prd.mdp -o prd.tpr -t eql.cpt -p topol.top gmx mdrun -deffnm prd
prd.mdp are parameter files for the minimization, equilibration, and production steps, respectively.
Acceleration & Parallelization
By default GROMACS uses all available processors on a single node. To run across multiple nodes, an MPI library is required. Using openmpi to run GROMACS takes the following form:
$ mpirun -np totalranks -npernode rankspernode --hostfile filename gmx mdrun -s topol.tpr
Here totalranks is the total number of MPI ranks to create, rankspernode is the number of MPI ranks per node, and filename is the hostfile used to determine on which hosts to run the processes.
OpenMPI be used together with OpenMP as seen here:
$ mpirun -np totalranks -npernode rankspernode --hostfile filename gmx mdrun -ntomp openmpthreads -s topol.tpr
If compiled without an external MPI library one can control MPI ranks and OMP threads, using GROMAC's thread-MPI. This will not be able to be run across multiple compute nodes:
$ gmx mdrun -ntmpi totalranks -ntomp openmpthreads -s topol.tpr
Here openmpthreads is the number of OpenMP threads to create. totalranks*openmpthreads should equal the total number of processors.
GROMACS automatically detects any available GPU's if it was compiled with GPU support. The number of MPI ranks must be a multiple of the number of GPU's to be used. Using a GPU requires the Verlet cut-off scheme, which is set with the parameter
cutoff-scheme in your
.mdp file. The command takes the basic form:
$ mpirun -np totalranks -npernode rankspernode --hostfile filename gmx mdrun -ntomp openmpthreads -s topol.tpr -gpu_id gpuids
Here gpuids is the zero-based id of each GPU in a list. That is, with only one GPU (
-np 1), you would use
-gp_uid 0. If two GPU's are available (
-np 2), you would use
-gpu_id 01. To use a GPU on multiple MPI ranks, simply list it's id the number of times to be used. For example, to use four MPI ranks on two GPUS one would use
-np 4, and
-gpu_id 0011, thus using each GPU on two MPI ranks. If running on two twenty-core machines, the command would look like:
$ mpirun -np 8 -npernode 4 --hostfile filename gmx mdrun -ntomp 5 -s topol.tpr -gpu_id 0011
If using GROMACS thread-MPI on one twenty core machine this would be:
$ gmx mdrun -ntmpi 4 -ntomp 5 -s topol.tpr -gpu_id 0011
See the man page on
mpirun as well as the GROMACS section on MPI acceleration and parallelization for more options.
Restart a simulation
To restart a simulation from a checkpoint file do:
$ gmx mdrun -s topol.tpr -cpi state.cpt
topol.tpr is the original
.tpr used in the simulation, and
state.cpt is the last checkpoint file from that simulation.
Extend a simulation
To extend a simulation create a modified
.tpr file and use it with gmx mdrun:
$ gmx convert-tpr -s topol.tpr -extend time -o tpxout.tpr $ gmx mdrun -s tpxout.tpr -cpi state.cpt
Where time is how much longer to run the simulation in picoseconds,
topol.tpr is the
.tpr file associated with the original simulation, and
state.cpt is the latest checkpoint file from that simulation. Instead of using
-extend one can also use
-until to specify the absolute ending time in picoseconds.
GROMACS comes with many analysis tools built-in. A list of all possible possible commands can be obtained by typing
gmx help commands or by opening the man page for gromacs.
Some of the more prominent analysis commands are:
gmx bar— calculate free energy difference estimates through Bennett's acceptance ratio.
gmx energy— writes energies to xvg files and display averages.
gmx rdf— calculate radial distribution functions.
gmx trjconv— convert and manipulates trajectory files.
gmx wham— Perform weighted histogram analysis after umbrella sampling.
See below for other available tools.
Index files are optionally used in almost all GROMACS analysis programs. The program gmx make_ndx controls the creation and modification of index files. Index files consist of group names and integer indices indicating the location of atomic sites in a trajectory frame. They are only required if the available residues found in a structure file do not group atomic sites together in the desired way. When running gmx make_ndx the user is presented with a prompt in order to select, combine, and split groups of atoms through various commands. Typing
h at the make_ndx prompt gives a full description of the commands available.
GROMACS uses git for version control, so familiarize yourself with its usage, especially the topic on collaboration. To begin contributing you need to sign up for a Gerrit account and add an ssh key. Then clone
ssh://email@example.com/gromacs.git where user is your user name. After cloning the repository, install the commit hook:
$ scp -p firstname.lastname@example.org:hooks/commit-msg .git/hooks/
When you are ready to share your changes, ensure your HEAD is up to date. Then push with the branch set as
HEAD:refs/for/mybranch, where mybranch is the name of the actual branch. In general three branches are used:
- master is used for long-term development of major features which may require large changes in code.
- release-x-y is for features that do not require as much code change, where x and y are the major and minor version numbers of the next release respectively.
- release-x-y-patches is for bug fixes and small documentation changes to a previous release.
Other branches can be seen on the Gerrit site.
If you want to push a draft commit, push with the branch set as
HEAD:refs/drafts/mybranch. In this case you must explicitly invite others to review your code.
For more information see the GROMACS page on Gerrit.
Tips and tricks
Create non-cubic box and fill with solvent
To create a non-cubic box filled with solvent, first do:
$ gmx editconf -f protein.pdb -bt boxtype -d dist -o box.gro
The above command creates a
boxtype box around the molecule in
dist nm in every direction. The box is saved as
boxtype can be
Then fill with solvent:
$ gmx solvate -cs tip4p -cp box.gro -o conf.gro -p topol.top
Use multiple solutes
If you want to use multiple solutes randomly inserted, first do:
$ gmx insert-molecules -box X Y Z -ci solute.pdb -nmol N -o box.gro
Where X, Y, and Z are the box dimensions in nanometers, and N is the number to insert. You will need to update your topology file with the inserted number of molecules.
Then fill with solvent:
$ gmx solvate -cs tip4p -cp box.gro -o conf.gro -p topol.top
Use a non-water solvent
To use a non-water solvent with standard tools such as gmx pdb2gmx and gmx solvate do the following:
- Create one solvent molecule's structure file and topology.
- Create a box containing a couple hundred of the solvent molecules (216 seems to be a standard) and run a short equilibration on the system at standard conditions.
- Copy the output structure file
.grofrom the simulation to
solvent.gro, where solvent is the name you wish to use for this molecule. Place this copy in the top level force field directory (where each force field has its own directory).
- Modify the topology file for the single solvent by removing everything but the
[moleculetype]section and name the molecule in the file as
- Rename the topology file as
solvent.itpand move it to the force field directory to which it applies.
watermodels.datfor the force field you wish to use with this solvent (located in the force field's directory), adding the solvent. You will simply add a line with
filename shortdescription longdescriptionwhere filename omits the file extension.
Now when you run gmx pdb2gmx this solvent model should be available for the applicable force field. Additionally you can use
-cs solvent when running gmx solvate.
Structure and Topology Databases
- Automated Topology Builder & Repository — repository for building blocks and interaction parameter files for molecules as well as an automated builder to help generate building blocks for novel molecules.
- RCSB Protein Data Bank — information about the 3D shapes of proteins, nucleic acids, and complex assemblies that helps students and researchers understand all aspects of biomedicine and agriculture, from protein synthesis to health and disease.
- SwissParam — provides topology and parameters for small organic molecules compatible with the CHARMM all atoms force field, for use with CHARMM and GROMACS.
- TraPPE Parameter Database[dead link 2020-03-29 ⓘ] — search by molecule name, or build your own, in order to obtain TraPPE force field parameters. Note that it is necessary to convert the parameters to the correct units.
- Virtual Chemistry — comparison of experimental and computational results for thousands of molecules. Contains validated topology input files for CGenFF, GAFF and OPLS/AA.
- GROMACS Redmine — project management page, where bugs, issues, and features are reported and tracked.
- GROMACS Gerrit — the project's code review system.
- GROMACS Mailing List — very active mailing list for users seeking help. Make sure to read the manual and search the archive before posting.
- GROMACS Manual — official GROMACS manual.
- GROMACS Online Reference
External libraries & programs
- libgmxcpp — a C++ toolkit used for reading in Gromacs files (.xtc and .ndx) for use in analyzing simulation results.
- libgmxfort — a Modern Fortran toolkit used for reading in Gromacs files (.xtc and .ndx) for use in analyzing simulation results.
- mdanalysis — an object-oriented python toolkit to analyze molecular dynamics trajectories in many popular formats.
- https://www.mdanalysis.org || AUR
- MDTraj — a modern, open library for the analysis of molecular dynamics trajectories.
- xdrfile — allows to read GROMACS trr and xtc files and also to convert from one format to another.
- http://gromacs.org || AUR
Free energy calculations
- alchemical_analysis — an open tool implementing some recommended practices for analyzing alchemical free energy calculations.
- Avogadro — an advanced molecule editor and visualizer designed for cross-platform use in computational chemistry, molecular modeling, bioinformatics, materials science, and related areas.
- https://avogadro.cc || AUR
- acpype — a tool based on Python to use Antechamber to generate topologies for chemical compounds and to interface with other python applications like CCPN tools or ARIA...Topologies files to be generated so far: CNS/XPLOR, GROMACS, CHARMM and AMBER.
- vmd — molecular visualization program for displaying, animating, and analyzing large biomolecular systems using 3-D graphics and built-in scripting.
- GromacsWrapper — a python package that wraps system calls to Gromacs tools into thin classes.