Weighted Ensemble Python (wepy)
Modular implementation and framework for running weighted ensemble (WE) simulations in pure python, where the aim is to have simple things simple and complicated things possible. The latter being the priority.
The goal of the architecture is that it should be highly modular to allow extension, but provide a “killer app” for most uses that just works, no questions asked.
Comes equipped with support for OpenMM molecular dynamics, parallelization using multiprocessing, the WExplore and REVO (Resampling Ensembles by Variance Optimization) resampling algorithms, and an HDF5 file format and library for storing and querying your WE datasets that can be used from the command line.
The deeper architecture of wepy
is intended to be loosely coupled,
so that unforeseen use cases can be accomodated, but tightly
integrated for the most common of use cases, i.e. molecular dynamics.
This allows freedom for fast development of new methods.
Full introduction.
Installation
Also see: Installation Instructions
To install from pip:
pip install wepy[all]
Which will install most dependencies.
To install the optional, but likely desired feature, OpenMM you should probably just use the omnia channel on conda, otherwise you will need to compile it yourself.
conda install -c omnia openmm
Check its installed by running the command line interface:
wepy --help
Citations
Current Zenodo DOI.
Cite software as:
Samuel D. Lotz, Nazanin Donyapour, Alex Dickson, Tom Dixon, Nicole Roussey, & Rob Hall. (2020, August 4). ADicksonLab/wepy: 1.0.0 Major version release (Version v1.0.0). Zenodo. http://doi.org/10.5281/zenodo.3973431
Accompanying journal article:
- ACS Omega article