Scalable molecular dynamics on CPU and GPU architectures with NAMD

James C. Phillips,David J. Hardy,Julio D. C. Maia,John E. Stone,João V. Ribeiro,Rafael C. Bernardi,Ronak Buch,Giacomo Fiorin,Jérôme Hénin,Wei Jiang,Ryan McGreevy,Marcelo C. R. Melo,Brian K. Radak,Robert D. Skeel,Abhishek Singharoy,Yi Wang,Benoît Roux,Aleksei Aksimentiev,Zaida Luthey-Schulten,Laxmikant V. Kalé,Klaus Schulten,Christophe Chipot,Emad Tajkhorshid
DOI: https://doi.org/10.1063/5.0014475
IF: 4.304
2020-07-28
The Journal of Chemical Physics
Abstract:NAMD is a molecular dynamics program designed for high-performance simulations of very large biological objects on CPU- and GPU-based architectures. NAMD offers scalable performance on petascale parallel supercomputers consisting of hundreds of thousands of cores, as well as on inexpensive commodity clusters commonly found in academic environments. It is written in C++ and leans on Charm++ parallel objects for optimal performance on low-latency architectures. NAMD is a versatile, multipurpose code that gathers state-of-the-art algorithms to carry out simulations in apt thermodynamic ensembles, using the widely popular CHARMM, AMBER, OPLS, and GROMOS biomolecular force fields. Here, we review the main features of NAMD that allow both equilibrium and enhanced-sampling molecular dynamics simulations with numerical efficiency. We describe the underlying concepts utilized by NAMD and their implementation, most notably for handling long-range electrostatics; controlling the temperature, pressure, and pH; applying external potentials on tailored grids; leveraging massively parallel resources in multiple-copy simulations; and hybrid quantum-mechanical/molecular-mechanical descriptions. We detail the variety of options offered by NAMD for enhanced-sampling simulations aimed at determining free-energy differences of either alchemical or geometrical transformations and outline their applicability to specific problems. Last, we discuss the roadmap for the development of NAMD and our current efforts toward achieving optimal performance on GPU-based architectures, for pushing back the limitations that have prevented biologically realistic billion-atom objects to be fruitfully simulated, and for making large-scale simulations less expensive and easier to set up, run, and analyze. NAMD is distributed free of charge with its source code at <a class="ref" href="http://www.ks.uiuc.edu">www.ks.uiuc.edu</a>.
chemistry, physical,physics, atomic, molecular & chemical
What problem does this paper attempt to address?
The paper mainly introduces the latest advancements of NAMD (Nanoscale Molecular Dynamics) and its scalability on high-performance computing architectures (including CPU and GPU). Specifically: 1. **Problems Addressed**: - The paper aims to address how to efficiently perform large-scale molecular dynamics simulations of biological systems using NAMD. - It particularly emphasizes NAMD's scalable performance on large parallel supercomputers as well as on cost-effective clusters. - The study also explores how NAMD handles key issues such as long-range electrostatic interactions, temperature control, pressure, and pH value. 2. **Target Users**: - The target users of the paper are experimental scientists and their collaborators, rather than programmers or computer experts. - By simplifying the interface and providing rich script support (such as Tcl and Python), it makes it easier for users to perform advanced simulations. 3. **Technical Features**: - NAMD is based on the Charm++ parallel programming system, enabling dynamic load balancing and efficient communication. - It supports various molecular force fields (such as CHARMM, AMBER, OPLS, and GROMOS) as well as polarizable force fields. - It offers advanced sampling methods, such as enhanced sampling strategies and free energy calculations. In summary, the paper mainly addresses how to efficiently simulate large-scale biological molecular systems using NAMD on high-performance computing platforms and provides detailed algorithmic and technical implementation details.