High-Performance Computing at the NIH
GitHub YouTube @nih_hpc RSS Feed
CHARMM on Biowulf

CHARMM (Chemistry at HARvard Macromolecular Mechanics) [1]:

Major new features:
[1] CHARMM: The Biomolecular simulation Program J. Comp. Chem. 30, 1545-1615 (2009).
[2] New faster CHARMM molecular dynamics engine J. Comp. Chem. 35, 406-413 (2014).
Cover Scripts

In order provide support for multiple executable types using a range of parallel communication methods and hardware via a common interface, cover scripts have been made available in /usr/local/apps/charmm/bin on Biowulf, each named for the CHARMM release version they support. The recommended setup is to use

module load charmm

to modify the command search path for your shell (bash or csh); the cover script will load any additional modules required. Besides the cover scripts, a tool for extracting data from CHARMM output log files, getprop.csh, is also available. Descriptions of the cover script commands, syntax listings, and usage examples are given in this section. General usage notes for running CHARMM via the SLURM queue and using the X11 graphics are given below, after the cover script descriptions.

Latest CHARMM release: c39b2

Recommended version for all applications; includes DOMDEC, DOMDEC_GPU, and many other new features. (The OpenMM and Q-Chem interfaces are not currently available, but could be easily added if there is sufficient interest.) Typing 'c39b2 -help' on Biowulf gives the following syntax and notes listing:

 biowulf /<6>charmm [5] module load charmm
 biowulf /<6>charmm [6] c39b2 -help
        Syntax; square brackets indicate [ optional args ]
                        SINGLE PROC
c39b2 [options] [ charmm-args ] < file.inp >& file.out

  Omit "< file.inp >& file.out" for interactive use (e.g. graphics)

c39b2 [options] ompi Nproc file.inp [ charmm-args ] >& file.out  # OpenMPI

c39b2 -h | -help   # this listing

  [options] ; must precede parallel keywords, order dependent
verbose       :: prints additional environment info; must be *first*
ddg           :: domdec_gpu; requires node with GPU (-p gpu)
sse           :: override AVX architecture detection
  PM Ewald type override option; default includes COLFFT and DOMDEC:
async         :: alt. (slower) PME method, incl. REPDSTR and MSCALE

  Parallel args; input filename required as 3rd arg
ompi    :: use the OpenMPI parallel library
Nproc   :: number of MPI processes; one per core, or one per GPU (ddg)

charmm-args   :: optional script @ vars, in the form N:27 or RUN=15 etc.
                   (N.B. must follow any options and parallel args)


c39b2 MDL:2 < minmodel.inp >& minmodel.out          # single proc min
c39b2 ompi 16 minmodel.inp MDL:2 >& minmodel.out    # minimization
c39b2 ompi 64 dyn.inp >& dyn.out                    # COLFFT or DOMDEC
c39b2 ddg ompi 8 dyn.inp >& dyn.out                 # DOMDEC_GPU
c39b2 ompi 64 dyn.inp -chsize 450000 >& dyn.out     # 450000 atom limit
c39b2 sse ompi 64 dyn.inp >& dyn.out                # force use of SSE on AVX host
c39b2 async ompi 32 dyn.inp >& dyn.out              # async; P21 symmetry, REPDSTR

The above usage examples illustrate the positional keywords; parallel usage requires the ompi keyword, followed by two more arguments for the number of cores (not SLURM cpus!) and finally the input file name. The optional mutually exclusive arguments ddg and async invoke different executables, compiled with different feature sets and with different run-time library requirements; the c39b2 cover script loads the modules needed, e.g. CUDA for ddg, and then invokes the requested executable. The async keyword includes support for features such as replica exchange MD, non-orthogonal crystal lattices, simulation of the assymetric unit with rotations of the simulation cell, and a number of other custom features; the fast DOMDEC code is NOT supported.

The sse keyword uses an older version of the Intel chipset floating point microarchitecture instructions, and is mainly used for testing.

Which options to use depends on the details of the types of calculations or operations being done, the type of molecular system, the boundary conditions, and probably other factors.

SLURM Batch Jobs

For a non-parallel CHARMM job such as model building or ad hoc trajectory analysis, the commands and setup have few requirements. The job script (build.csh) can be simply:

module load charmm
c39b2 < build-psf.inp >& build-psf.out

The above can be submitted to the batch queue via:

sbatch build.csh

For parallel usage, the following script (sbatch.csh) illustrates submitting a SLURM batch job which will use the 16 physical cores on each of 4 nodes (64 total cores:


# use subdir name for job id and log file names
set id = $cwd:t

# nodes
@ n = 4
# tasks, for 16 core nodes
@ nt = 16 * $n

sbatch --ntasks=$nt -J $id -o $id.%j job.csh

Assuming the Infiniband (multinode) nodes will be used, the job.csh script contains:

#SBATCH --partition=multinode
#SBATCH --exclusive
#SBATCH --ntasks-per-core=1

module load charmm
c39b2 ompi $SLURM_NTASKS charmmrun.inp >& charmmrun.out

The environment variable SLURM_SUBMIT_DIR points to the working directory where 'sbatch' was run, and SLURM_NTASKS contains the value given with the --ntasks= argument to sbatch. The above is suitable for most parallel CHARMM usage, other than the DOMDEC_GPU code invoked via the ddg cover script keyword (see below). A more detailed example for long simulations, also using separate scripts for job submission and job execution, is given in the Daisy Chaining section below. Of course, one could submit job.csh directly via e.g.:

sbatch --ntasks=64 -J MyJob -o MyJob.%j job.csh

where %j represents the SLURM job number.

Using GPUs

The DOMDEC_GPU code invoked via the ddg cover script keyword uses both an MPI library (OpenMPI in this case) and OpenMP threads, and therefore requires changes to the SLURM sbatch arguments. The changes are shown in the example below (sbatchGPU.csh); the --nodes= argument must be included, and the --ntasks= value must be twice the number of nodes, as each node has two GPU devices.


# use subdir name for job id and log file names
set id = $cwd:t

# nodes
@ n = 4
# tasks, for nodes with 2 GPUs
@ nt = 2 * $n

# use all eight GPUs on four nodes
sbatch --ntasks=$nt --nodes=$n -J $id -o $id.%j gpujob.csh

A minimal job script follows, which illustrates additional changes to the information given to SLURM, via directives that do not depend on the number of nodes requested. Other than requesting --exclusive use of the node, all of the directives are distinct from those in the job.csh example above for general parallel usage.

#SBATCH --partition=gpu
#SBATCH --exclusive
#SBATCH --cpus-per-task=8
#SBATCH --gres=gpu:k20x:2

module load charmm
c39b2 ddg ompi $SLURM_NTASKS charmmgpu.inp >& charmmgpu.out

Interactive Usage

For a variety of tasks such as model building, analysis, and graphics, foreground interactive use of CHARMM can be advantageous, esp. when developing and testing a new input script. The SLURM sinteractive command makes this fairly easy (system prompts in bold, user input in italics):

 biowulf /<2>EwaldNVE [69] sinteractive
salloc.exe: Granted job allocation 1693180
salloc.exe: Waiting for resource configuration
salloc.exe: Nodes cn0032 are ready for job

 cn0032 /<2>EwaldNVE [1] module load charmm
 cn0032 /<2>EwaldNVE [2] c39b2 < build-psf.inp >& build-psf.out
 cn0032 /<2>EwaldNVE [3] exit
salloc.exe: Relinquishing job allocation 1693180
salloc.exe: Job allocation 1693180 has been revoked.

By adding a couple SLURM options, one can also run parallel minimization jobs as well:

 biowulf /<2>EwaldNVE [70] sinteractive -n 8 --ntasks-per-core=1
salloc.exe: Granted job allocation 1693189
salloc.exe: Waiting for resource configuration
salloc.exe: Nodes cn0254 are ready for job

 cn0254 /<2>EwaldNVE [1] module load charmm
 cn0254 /<2>EwaldNVE [2] c39b2 < build-psf.inp >& build-psf.out
 cn0254 /<2>EwaldNVE [3] c39b2 ompi 8 minmodel.inp >& minmodel.out &
 cn0254 /<2>EwaldNVE [4] exit
salloc.exe: Relinquishing job allocation 1693189

For troubleshooting, it may be useful to pipe the output, and both save it in file (via 'tee') and view it in the 'less' browser, e.g.:

 cn0254 /<2>EwaldNVE [3] c39b2 ompi 8 minmodel.inp |& tee minmodel.out | less

Finally, CHARMM itself can be run interactively, via simply:

 biowulf /<2>EwaldNVE [71] sinteractive
salloc.exe: Granted job allocation 1693592
salloc.exe: Waiting for resource configuration
salloc.exe: Nodes cn0103 are ready for job

 cn0103 /<2>EwaldNVE [1] module load charmm
 cn0103 /<2>EwaldNVE [2] c39b2
Linux cn0103 2.6.32-504.16.2.el6.x86_64 #1 SMP Wed Apr 22 06:48:29 UTC 2015 x86_64 x86_64 x86_64 GNU/Linux
 14:22:15 up 116 days, 23:33,  0 users,  load average: 7.55, 7.97, 7.99
[+] Loading Intel 2015.1.133 Compilers ...
>>>========>>  FOR SYNTAX AND NOTES, TRY    "c39b2 -help"
-rwxrwxr-x 1 venabler 30966207 Jun  1 13:11 /usr/local/apps/charmm/c39b2/em64t/ifortavx.x11
                 Chemistry at HARvard Macromolecular Mechanics
           (CHARMM) - Developmental Version 39b2   February 15, 2015            
       Copyright(c) 1984-2014  President and Fellows of Harvard College
                              All Rights Reserved
     Current operating system: Linux-2.6.32-504.16.2.el6.x86_64(x86_64)@cn0     
                 Created on  9/1/15 at 14:22:15 by user: root        

            Maximum number of ATOMS:    360720, and RESidues:      120240

At this point the program is expecting input, starting with a title; it is recommended to type bomlev -1 as the first command, as that will forgive typing errors and allow the program to continue. It also recommended to have the initial setup commands (reading RTF and PARAM files, PSF and COOR files, etc.) in a 'stream' file, so that those actions can be done vie e.g.

stream init.str

The same applies to other complex setups, such as establishing restraints, or graphics setup.

Note that the graphics uses X11, so the initial login to biowulf should use either the -X or the -Y option of the ssh command, to enable X11 tunneling for the graphics display.

Force Field Parameters

Recent versions of the distributed CHARMM parameters, including the latest release, are available in /usr/local/apps/charmm as subdirectories toppar2014 and toppar2015. The latter contains a number of corrections and additions from the past year, esp. for the CHARMM General Force Field (CGenFF). For convenience, the environment variables TOPPAR2014 and TOPPAR2015 are defined when the 'charmm' module is loaded to point to these directories, and can be used for pathnames in program input via

read rtf card name "$TOPPAR2015/top_all36_prot.rtf"
read para flex card name "$TOPPAR2015/par_all36_prot.prm"

Note that the double quotes (") are required for pathnames that contain mixed upper and lower case letters.

Daisy Chaining

In order to run a long series of CHARMM calculations, a systematic method has been developed over many years and operating systems. There are several basic concepts:

The sbatch.csh or sbatchGPU.csh scripts shown above in the Batch jobs section can be used as the submit scripts; they can also be found in /usr/local/apps/charmm/scripts or obtained via the links at the end of this section. A detailed description of this system of scripts, albeit for a PBS queue, can be found in this post in the Script Archive forum at www.charmm.org; the changes for SLURM on Biowulf are shown in the following dyn.csh example:

#SBATCH --partition=multinode
#SBATCH --exclusive
#SBATCH --ntasks-per-core=1

# ASSUMPTION (1): output files are named    dyn.res  dyn.trj  dyn.out
# ASSUMPTION (2): previous restart file read as  dyn.rea


if ( ! -d Res ) mkdir Res
if ( ! -d Out ) mkdir Out
if ( ! -d Crd ) mkdir Crd
if ( ! -d Trj ) mkdir Trj

set chm = "/usr/local/apps/charmm/bin/c39b2 ompi $SLURM_NTASKS"
set nrun = 1
set d = $cwd:t

@ krun = 1
 while ( $krun <= $nrun )

if ( -e next.seqno ) then
 $chm dyn.inp D:$d > dyn.out
 $chm dynstrt.inp D:$d > dyn.out

set okay = true
if ( -e dyn.res && -e dyn.dcd ) then
 @ res = `wc dyn.res | awk '{print $1}'`
 @ tsz = `ls -s dyn.dcd | awk '{print $1}'`
 @ nrm = `grep ' NORMAL TERMINATION ' dyn.out | wc -l`
 if ( $res > 100 && $tsz > 0 && $nrm == 1 ) then
  cp dyn.res dyn.rea
  if ( -e next.seqno ) then
   @ i = `cat next.seqno` 
   @ i = 1
  mv dyn.out Out/dyn$i.out
  mv dyn.crd Crd/dyn$i.crd
  mv dyn.res Res/dyn$i.res
  mv dyn.dcd Trj/dyn$i.dcd
  gzip -f Out/dyn$i.out Res/dyn$i.res Crd/dyn$i.crd
  if ( -e last.seqno ) then
    @ l = `cat last.seqno`
    if ( $i == $l ) then
      @ i += 1
      echo $i > next.seqno 
  @ i += 1
  echo $i > next.seqno
  set okay = false
 set okay = false

if ( $okay == true ) then
 if ( $krun == $nrun ) ./sbatch.csh
 @ krun += 1
 set ts = `date +%m%d.%H%M`
 date > msg.tmp
 echo $cwd >> msg.tmp
 head -64 dyn.out >> msg.tmp
 tail -64 dyn.out >> msg.tmp
 mv dyn.out dyn.err.$ts
 mail -s "$SLURM_JOB_NAME $SLURM_JOB_ID $ts" $USER@helix.nih.gov < msg.tmp


The above can be used for most parallel CHARMM usage (except for GPUs); for some types of calculations, the async keyword may be needed as well.

Plain text versions of the scripts are given in the following links; after downloading, rename them to .csh files, and allow them to be executed via e.g.

mv sbatch.txt sbatch.csh
chmod u+x sbatch.csh

Script download links:   sbatch.txt   dyn.txt     sbatchGPU.txt   dyngpu.txt

The plot below is from CHARMM benchmarks run during the beta test phase of Biowulf, and shows results for DOMDEC on Infiniband nodes (solid lines) and DOMDEC_GPU on gpu nodes (dotted lines), for even numbers from 2 through 16 nodes. The timings in ns/day are from short MD simulations, run with a 1 fs integration time step, for 3 molecular systems of different sizes and shapes:

Note that the ns/day rate would be doubled with the use of a 2 fs time step, which is often done for more exploratory sampling, but not necessarily recommended for the best accuracy and precision. Simulations systems that cannot use DOMDEC will be somewhat slower, and will not scale well past about 64 cores.

Other CHARMM resources

The CHARMM program is provided and maintained on Biowulf by the NHLBI Laboratory of Computational Biology

CHARMM on Biowulf / Rick_Venable@nih.gov