Workflows for atomistic modeling of oxide glasses
Project description
amorphouspy
[!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), and SHIK (Sundararaman) 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 (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.
License
Apache License 2.0. See LICENSE.
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 amorphouspy-0.5.3.tar.gz.
File metadata
- Download URL: amorphouspy-0.5.3.tar.gz
- Upload date:
- Size: 16.6 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
da26728631ecdc8503ca0fddd9b2e5c20e10eaefea5e7bea3c55ae1c874be984
|
|
| MD5 |
d5d1d762e63536fa69955bef7b937aab
|
|
| BLAKE2b-256 |
41a6efe5a981580f4e37da1256f0ebee076a5cf175252ad020efd292153b2953
|
Provenance
The following attestation bundles were made for amorphouspy-0.5.3.tar.gz:
Publisher:
publish_pypi.yml on glasagent/amorphouspy
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
amorphouspy-0.5.3.tar.gz -
Subject digest:
da26728631ecdc8503ca0fddd9b2e5c20e10eaefea5e7bea3c55ae1c874be984 - Sigstore transparency entry: 1283788880
- Sigstore integration time:
-
Permalink:
glasagent/amorphouspy@a1b2db9313ee5f37ff73ef41aa08d3e1e564a9e0 -
Branch / Tag:
refs/tags/v0.5.3 - Owner: https://github.com/glasagent
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish_pypi.yml@a1b2db9313ee5f37ff73ef41aa08d3e1e564a9e0 -
Trigger Event:
release
-
Statement type:
File details
Details for the file amorphouspy-0.5.3-py3-none-any.whl.
File metadata
- Download URL: amorphouspy-0.5.3-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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a92dfc19890cee1a39aa42af48191983ea3ea67f7c49b2d44a759269a1d70d5a
|
|
| MD5 |
55b6dd25169bf7f39d7d1ccc3ef40d64
|
|
| BLAKE2b-256 |
0602bd8caf5ee95f30feb1ea6975ff62c25c87f2fafff42b7d38474b2d1a22e4
|
Provenance
The following attestation bundles were made for amorphouspy-0.5.3-py3-none-any.whl:
Publisher:
publish_pypi.yml on glasagent/amorphouspy
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
amorphouspy-0.5.3-py3-none-any.whl -
Subject digest:
a92dfc19890cee1a39aa42af48191983ea3ea67f7c49b2d44a759269a1d70d5a - Sigstore transparency entry: 1283788984
- Sigstore integration time:
-
Permalink:
glasagent/amorphouspy@a1b2db9313ee5f37ff73ef41aa08d3e1e564a9e0 -
Branch / Tag:
refs/tags/v0.5.3 - Owner: https://github.com/glasagent
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish_pypi.yml@a1b2db9313ee5f37ff73ef41aa08d3e1e564a9e0 -
Trigger Event:
release
-
Statement type: