Skip to main content
NIHPA Author Manuscripts logoLink to NIHPA Author Manuscripts
. Author manuscript; available in PMC: 2022 Nov 3.
Published in final edited form as: J Open Source Softw. 2022 Jan 6;7(69):3981. doi: 10.21105/joss.03981

physical_validation: A Python package to assess the physical validity of molecular simulation results

Pascal T Merz 1, Wei-Tse Hsu 1, Matt W Thompson 1, Simon Boothroyd 2, Chris C Walker 1, Michael R Shirts 1
PMCID: PMC9632650  NIHMSID: NIHMS1819246  PMID: 36337282

Summary

Molecular simulations such as molecular dynamics (MD) and Monte Carlo (MC) simulations are powerful tools allowing the prediction of experimental observables in the study of systems such as proteins, membranes, and polymeric materials. The quality of predictions based on molecular simulations depend on the validity of the underlying physical assumptions. physical_validation allows users of molecular simulation programs to perform simple yet powerful tests of physical validity on their systems and setups. It can also be used by molecular simulation package developers to run representative test systems during development, increasing code correctness. The theoretical foundation of the physical validation tests were established by Merz & Shirts (2018), in which the physical_validation package was first mentioned.

Statement of need

For most of the history of molecular simulation-based research in chemistry, biophysics, physics and engineering, most users of molecular simulation packages were experts that contributed to the code bases themselves or were very familiar with the methodology used. Increased popularity of molecular simulation methods has led to a significantly increased user base and to an explosion of available methods. The simulation packages are faster and more powerful than ever, and even more than before require expertise to avoid using combinations of methods and parameters that could violate physical assumptions or affect reproducibility. Unphysical artifacts have frequently been reported to significantly affect physical observables such as the folding of proteins or DNA, the properties of lipid bilayers, the dynamics of peptides and polymers, or properties of simple liquids (see Merz & Shirts (2018) for further references).

Functionality

physical_validation tackles the problem of robustness in molecular simulations at two levels. The first level is the end-user level. physical_validation allows users to test their simulation results for a number of deviations from physical assumptions such as the distribution of the kinetic energy, the equipartition of kinetic energy throughout the system, the sampling of the correct ensemble in the configurational quantities, and the precision of the integrator. The combination of these tests allow to cover a wide range of potential unphysical simulation conditions (Merz & Shirts, 2018). This increases the confidence that users can have in their simulation results independently of and in addition to any code correctness tests provided by the developers of their simulation package. These validation tools explain their assumptions and conclusions using comprehensive output and figures, making their use suitable also for users new to the field of molecular simulations. Since physical_validation also returns its conclusions in machine-readable form, it can be included in pipelines allowing results to be tested for physical validity without user interaction. The second level of usage is by code developers. Unphysical behavior might not only result from poor or incompatible parameters and models, it might also stem from coding errors in the simulation programs. physical_validation can therefore be used to regularly run representative simulations as end-to-end tests in a continuous integration setup, ensuring that code changes do not introduce bugs that lead to unphysical results. GROMACS (Abraham et al., 2015), one of the leading MD packages, has been using physical_validation since 2019 to test every release version with a comprehensive set of simulations covering all major code paths.

Relation to prior work

Shirts (2013) and Merz & Shirts (2018) laid the theoretical foundation for the physical_validation package. Shirts (2013) introduced the ensemble validation tests, and implemented them in a simple python script which was made available accompanied by some examples on github.com/shirtsgroup/checkensemble. This script was used as a base for the ensemble validation tests in physical_validation. Merz & Shirts (2018) built upon the previous work by showing that combining the ensemble tests with kinetic energy distribution and equipartition checks as well as integrator convergence tests could detect many types of unphysical simulation conditions. Merz & Shirts (2018) first mentioned physical_validation and its use in the validation of GROMACS releases.

In the three years since the publication, the software has matured into a stable release. The ensemble tests now also support μVT ensembles, covering the full set of ensembles described by Shirts (2013). The user interface, the screen output and the plotting functionality were polished based on user feedback. The API was improved and is now considered stable, and the package can be installed using conda, both of which were much requested features from users looking to use the package in pipelines automating simulation protocols. While the version published in 2018 had no test coverage, the stable release is extensively covered by both unit and regression tests, reaching a test coverage of above 90%. Finally, the documentation was significantly improved based on user feedback.

Acknowledgements

  • Research reported in this publication was supported in part by the National Institute of General Medical Science of the National Institutes of Health under award number R01GM115790 (funding PTM) and R01RGM132386 (funding MTT), and also in part by the National Science Foundation under grant OAC-1835720 (funding WTH) and the U.S. Department of Energy, Office of Science, Office of Basic Energy Sciences, Materials Sciences and Engineering (MSE) Division, under Award Number DE-SC0018651 (funding CCW).

  • The Molecular Sciences Software Institute (MolSSI) for a MolSSI Software Fellowship to Pascal Merz

  • Can Pervane for helpful discussions in the early stages of the project

  • Nate Abraham for careful reading of the documentation

  • Lenny Fobe for help in the setup of the CI

References

  1. Abraham MJ, Murtola T, Schulz R, Páll S, Smith JC, Hess B, & Lindahl E (2015). GROMACS: High performance molecular simulations through multi-level parallelism from laptops to supercomputers. SoftwareX, 1–2, 19–25. 10.1016/j.softx.2015.06.001 [DOI] [Google Scholar]
  2. Merz PT, & Shirts MR (2018). Testing for physical validity in molecular simulations. PLOS ONE, 13(9), 1–22. 10.1371/journal.pone.0202764 [DOI] [PMC free article] [PubMed] [Google Scholar]
  3. Shirts MR (2013). Simple quantitative tests to validate sampling from thermodynamic ensembles. Journal of Chemical Theory and Computation, 9(2), 909–926. 10.1021/ct300688p [DOI] [PubMed] [Google Scholar]

RESOURCES