Time-Resolved Ensemble Generator using Coarse-Grained ENM Langevin Dynamics
Project description
synth-dynamics: Time-Resolved Ensemble Generator
synth-dynamics is a fast, lightweight molecular dynamics engine designed to generate meaningful conformational ensembles of proteins. Unlike full-atom simulations (like GROMACS or Amber), synth-dynamics uses a Coarse-Grained Anisotropic Network Model (ANM) and Langevin dynamics to capture the essential global motions of proteins with minimal computational overhead.
This tool is designed to bridge the gap between static structures and time-averaged experimental observables, such as NMR relaxation parameters, SAXS Kratky plots, or FRET efficiency distributions.
Key Features
- Coarse-Grained Simulation: Models proteins using C-alpha atoms and harmonic "spring" networks.
- Fast Langevin Engine: Propagates coordinates using a stable, overdamped Langevin integrator.
- Experimental Integration: Perfect for generating the structural ensembles needed for
synth-nmrorsynth-saxs. - Easy to Use: Simple API for loading PDBs, configuring forcefields, and running simulations.
- Extensively Tested: 100% test coverage ensuring reliability and correctness.
Installation
synth-dynamics requires Python 3.10+ and the following dependencies:
pip install numpy MDAnalysis scipy
To install the documentation theme:
pip install sphinx_rtd_theme
Quick Start
Running a simulation is straightforward:
from synth_dynamics import System, ANMForceField, LangevinIntegrator, Simulation
# 1. Load the system (automatically filters for C-alpha atoms)
system = System("protein.pdb")
# 2. Define the Anisotropic Network Model forcefield
# Cutoff (15A) and spring constant determine the flexibility
ff = ANMForceField(system.equilibrium_coords, cutoff=15.0, spring_constant=1.0)
# 3. Initialize the Langevin integrator (dt in fs, T in Kelvin)
integrator = LangevinIntegrator(dt=0.1, temperature=300.0, friction=1.0)
# 4. Run and save the trajectory
sim = Simulation(system, ff, integrator)
sim.run(n_steps=1000, output_path="trajectory.dcd", stride=10)
Documentation
Full API documentation and usage guides are available in the docs/ directory. You can build the HTML documentation locally:
cd docs
sphinx-build -b html . _build/html
Testing
To run the test suite and verify coverage:
PYTHONPATH=. pytest --cov=synth_dynamics tests/
License
This project is licensed under the MIT License - see the LICENSE file for details (if applicable).
Related Projects
This library is part of the synth-pdb ecosystem — use it to generate trajectories for synth-nmr or synth-saxs ensemble averaging:
- synth-pdb — Core protein structure generator
- synth-nmr — NMR observables simulator
- synth-saxs — SAXS profile simulator
- synth-cryo-em — Cryo-EM map simulator
- diff-biophys — Differentiable JAX biophysics kernels
Contributing
Contributions are welcome! Please open an issue or pull request on GitHub. Run pre-commit run --all-files before submitting.
Citation
@software{synth_dynamics,
author = {Elkins, George},
title = {synth-dynamics: Coarse-grained protein dynamics for ensemble generation},
year = {2024},
url = {https://github.com/elkins/synth-dynamics},
version = {0.1.0}
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file synth_dynamics-0.1.1.tar.gz.
File metadata
- Download URL: synth_dynamics-0.1.1.tar.gz
- Upload date:
- Size: 12.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c71ba445706b14323a5a011545cc96419086c6ddac309714590cf1f1458302bb
|
|
| MD5 |
3683033955ff0b28247d6dc5278224ce
|
|
| BLAKE2b-256 |
1276809779a96e0689beef7ff625c21926c0f52db9236be426f9b6d494e50a80
|
File details
Details for the file synth_dynamics-0.1.1-py3-none-any.whl.
File metadata
- Download URL: synth_dynamics-0.1.1-py3-none-any.whl
- Upload date:
- Size: 7.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0fb7945d658b937419f34c026d68779654a2c70b70c983bcf7e330158c3f6d07
|
|
| MD5 |
fba3cc0595dd7bf678c86b002a180222
|
|
| BLAKE2b-256 |
ad7006fe5cbaab35d5f65dbde2cec6aceb829874a681771010e7e1dea744fb33
|