Skip to main content

Workflows for atomistic modeling of oxide glasses

Project description

amorphouspy

PyPI Documentation codecov DOI

amorphouspy logo

[!WARNING] This project is under active development and is not yet ready for production use. APIs and functionality may change without notice. Contributions and feedback are very welcome — feel free to open an issue or submit a pull request!

A Python package for atomistic simulations of glasses.

amorphouspy provides capabilities in the form of Python functions from generating initial structural models through running molecular dynamics simulations with LAMMPS, all the way to computing material properties and performing detailed structural analysis.

amorphouspy_api strings these Python functions together to end-to-end workflows using executorlib. It then exposes these workflows through web endpoints, which can e.g. be used by an agent powered by a large language model.

Find the documentation at glasagent.github.io/amorphouspy.

Key Features

amorphouspy

  • Structure Generation: Create random oxide glass structures from composition dicts (e.g. {"SiO2": 75, "Na2O": 15, "CaO": 10}) with automatic density estimation using Fluegel's empirical model.
  • Interatomic Potentials: Built-in support for PMMCS (Pedone), BJP (Bouhadja), SHIK (Sundararaman), Du/Teter, BMP (Bertani, Menziani, Pedone) classical force fields with automatic LAMMPS input generation. Support for machine-learning interatomic potentials will come later.
  • Melt-Quench Simulations: Multi-stage heating/cooling protocols with potential-specific temperature programs and ensemble control.
  • Structural Analysis: RDFs, coordination numbers, Qn distributions, bond angle distributions, ring statistics, cavity analysis.
  • Property Calculations: Elastic moduli (stress-strain finite differences), viscosity (Green-Kubo formalism), coefficient of thermal expansion (temperature scan or from NPT fluctuations).

amorphouspy_api

  • End-to-end Workflows: Submit a composition, get back the glass structure and all of its predicted properties
  • Job management API: Fully fledged job management API, including results database
  • Visualization: Interactive Plotly-based visualizations of glass structure and properties

Installation

Install the bleeding edge version via

# Install pixi (if not already installed)
curl -fsSL https://pixi.sh/install.sh | bash

# Clone repo and install environment from PyPI/conda-forge
git clone https://github.com/glasagent/amorphouspy.git
cd amorphouspy
pixi install

You can also install the amorphouspy package into existing environments from PyPI or conda-forge, see the Installation guide for details.

Quick Start

See the Tutorial for a step-by-step introduction.

Authors

Developed at the Bundesanstant für Materialforschung und -prüfung (BAM) in collaboration with SCHOTT AG and the Max Planck Institute for Sustainable Materials.

  • Achraf Atila — BAM — Core framework, analysis tools, potentials
  • Marcel Sadowski — Schott AG — CTE simulation module
  • Jan Janssen — MPI-SusMat — pyiron integration, lammpsparser
  • Leopold Talirz — Schott AG — API layer, project coordination

Acknowledgement

Supported by the Federal Ministry of Research, Technology and Space via the GlasAgent MaterialDigital 3 project.

BMFTR logo     MaterialDigital logo     GlasAgent logo

How to Cite

If you use amorphouspy in your research, please cite it using the citation information provided on our Zenodo record (see the "Citation" box on the right-hand side), or use the reference below.

@misc{amorphouspy,
  doi = {10.5281/ZENODO.19564118},
  url = {https://zenodo.org/doi/10.5281/zenodo.19564118},
  author = {Leopold Talirz, and Achraf Atila, and Jan Janssen, and Marcel Sadowski,  },
  title = {glasagent/amorphouspy: v0.6.0},
  publisher = {Zenodo},
  year = {2026},
  copyright = {Apache License 2.0}
}

License

Apache License 2.0. See LICENSE.

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

amorphouspy-0.6.0.tar.gz (45.8 MB view details)

Uploaded Source

Built Distribution

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

amorphouspy-0.6.0-py3-none-any.whl (1.8 MB view details)

Uploaded Python 3

File details

Details for the file amorphouspy-0.6.0.tar.gz.

File metadata

  • Download URL: amorphouspy-0.6.0.tar.gz
  • Upload date:
  • Size: 45.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for amorphouspy-0.6.0.tar.gz
Algorithm Hash digest
SHA256 f7cf143aa9e03fc9b9393261c661c2ad45a7d91de003c0232c556217e1e3cba1
MD5 236cc9ae7116c9a11e3337aeb2bb9740
BLAKE2b-256 10014b03de47cb8d74d64654cc2cf4fe83a0a49618c98b32470f6c6e89e4b511

See more details on using hashes here.

Provenance

The following attestation bundles were made for amorphouspy-0.6.0.tar.gz:

Publisher: publish_pypi.yml on glasagent/amorphouspy

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

File details

Details for the file amorphouspy-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: amorphouspy-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 1.8 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for amorphouspy-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fcb48dde0d5af2c7a2e84ed6ce8130bdab5bd4fa7b8a1846466c9334327bc0a1
MD5 928db55b11e5f7aef1728d2dbc11744f
BLAKE2b-256 62f604d98a16e464efea787425cb705976f2089e1914f1acc255235fec626a45

See more details on using hashes here.

Provenance

The following attestation bundles were made for amorphouspy-0.6.0-py3-none-any.whl:

Publisher: publish_pypi.yml on glasagent/amorphouspy

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