Skip to main content

Molecular simulation toolkit

Project description

mstk

A toolkit to make molecular simulation less painful

mstk is a Python toolkit designed to streamline the setup and management of molecular simulations, particularly geared towards non-biological applications in material science and chemical engineering. It simplifies atom typing, force field parameter assignment, and input file generation for major simulation engines.

Features

  • Assign atom types and force field parameters based on local chemical environment
  • Generate input files for LAMMPS, GROMACS, NAMD and OpenMM
  • Support Drude polarizable model, coarse-grained model, virtual site, linear angle...
  • Read/write common topology (PSF, ZMAT, PDB, LAMMPS, ...) and trajectory (GRO, XTC, DCD, LAMMPS, ...) files
  • Access local and remote job schedulers like Slurm

Installation

conda install -c conda-forge numpy pandas rdkit openmm chemfiles packmol
pip install mstk

Quick Example

Build a liquid mixture of 100 benzene and 1000 water molecules, ready for simulation.

from mstk.topology import Molecule, Topology
from mstk.forcefield import ForceField, Typer
from mstk.simsys import System
from mstk.wrapper import Packmol

# Create topology from SMILES
benzene = Molecule.from_smiles('c1ccccc1')
water = Molecule.from_smiles('O')
top = Topology([benzene, water])

# Assign atom types as defined in `data/forcefield/primitive.smt`
typer = Typer.open('primitive.smt')
typer.type(top)

# Build a bulk liquid simulation box with Packmol
packmol = Packmol('packmol')
top.cell.set_box([4.0, 4.0, 4.0])
top.scale_with_packmol([100, 1000], packmol=packmol)

# Assign force field parameters as defined in `data/forcefield/primitive.zff`
ff = ForceField.open('primitive.zff')
ff.assign_charge(top)
system = System(top, ff)

# Generate input files for LAMMPS, GROMACS and NAMD
system.export_lammps()
system.export_gromacs()
system.export_namd()

# Generate OpenMM system and topology
omm_sys = system.to_omm_system()
omm_top = top.to_omm_topology()

Important Note: The primitive atom typing and force field used above are for demonstration purpose only and are not well optimized for production use. For reliable simulation, please prepare you own smt and zff files or get them from a validated source.

Documentation

https://mstk.readthedocs.io/en/latest/index.html

TODO

  • Refactor algorithms across topology and analyzer modules
  • Separate ommhelper module into its own package
  • Remove analyzer module
  • Revise the implementation of Drude polarization and virtual sites

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mstk-0.3.29.tar.gz (242.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mstk-0.3.29-py3-none-any.whl (289.2 kB view details)

Uploaded Python 3

File details

Details for the file mstk-0.3.29.tar.gz.

File metadata

  • Download URL: mstk-0.3.29.tar.gz
  • Upload date:
  • Size: 242.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mstk-0.3.29.tar.gz
Algorithm Hash digest
SHA256 da7c3848544c0245ecd283d18e2df207fe978300afd0636db7e95fb2c99d20cb
MD5 29568b4b58c29677b8312abeb5b794a8
BLAKE2b-256 02aa185a0ea7cfdd7f1aec7b5a51202494ac143891415a80be083974a978b75f

See more details on using hashes here.

Provenance

The following attestation bundles were made for mstk-0.3.29.tar.gz:

Publisher: python-publish.yml on z-gong/mstk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mstk-0.3.29-py3-none-any.whl.

File metadata

  • Download URL: mstk-0.3.29-py3-none-any.whl
  • Upload date:
  • Size: 289.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mstk-0.3.29-py3-none-any.whl
Algorithm Hash digest
SHA256 b1fc723fdc8d3d20acb76a99e4fdb12b46ccf6e620bb28d3e35339f21dd5fb9b
MD5 f1e4bbc25d39439c7ef304a74741b878
BLAKE2b-256 7ba78a74d9ed553bd4097cf6f5a8a8b6f1c7825146bacfe713a403ba0d2ca141

See more details on using hashes here.

Provenance

The following attestation bundles were made for mstk-0.3.29-py3-none-any.whl:

Publisher: python-publish.yml on z-gong/mstk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page