<img style="float: right; max-width: 50px;" src="assets/icon.svg">
# CMTJ
[![PyPI](https://github.com/LemurPwned/cmtj/actions/workflows/main.yml/badge.svg?branch=master)](https://github.com/LemurPwned/cmtj/actions/workflows/main.yml)
[![pages-build-deployment](https://github.com/LemurPwned/cmtj/actions/workflows/pages/pages-build-deployment/badge.svg?branch=gh-pages)](https://github.com/LemurPwned/cmtj/actions/workflows/pages/pages-build-deployment)
[![Version](https://img.shields.io/pypi/v/cmtj)](https://pypi.org/project/cmtj/)
[![License](https://img.shields.io/pypi/l/cmtj.svg)](https://github.com/LemurPwned/cmtj/blob/master/LICENSE)
[![Streamlit](https://static.streamlit.io/badges/streamlit_badge_black_white.svg)](https://cmtj-app.streamlit.app/spectrum)
![Downloads](https://img.shields.io/pypi/dm/cmtj.svg)
## Table of contents
- [CMTJ](#cmtj)
- [Table of contents](#table-of-contents)
- [Short description](#short-description)
- [What can you simulate?](#what-can-you-simulate)
- [Web GUI](#web-gui)
- [Quickstart](#quickstart)
- [Installation :rocket:](#installation-rocket)
- [Extra dependencies](#extra-dependencies)
- [Documentation and examples](#documentation-and-examples)
- [Extensions](#extensions)
- [Citing](#citing)
- [Development](#development)
- [Acknowledgements](#acknowledgements)
- [Contributions](#contributions)
- [Docker](#docker)
- [Precommit](#precommit)
- [Documentation builds](#documentation-builds)
## Short description
The `cmtj` name may be misleading -- the MTJ (Magnetic Tunnel Junctions) are not the only structures that may be simulated.
The library allows for macromagnetic simulation of various multilayer spintronic structures. The package uses C++ implementation of (s)LLGS (stochastic Landau-Lifschitz-Gilbert-Slonczewski) equation with various field contributions included for instance: anisotropy, interlayer exchange coupling, demagnetisation, dipole fields etc.
It is also possible to connect devices in parallel or in series to have electrically coupled arrays.
### What can you simulate?
Below is a brief list of examples (it's not exhaustive! Check the docs for more).
**Magnetic devices:**
- Magnetic Tunnel Junctions
- Voltage-Driven Magnetic Tunnel Junctions
- Spin-Torque Oscillators
- VCMA sensors and devices
- Magnetic Tunnel Junction Arrays
- SOT devices
- Current-Driven SOT
- Advanced device coupling
- Reservoirs (dipole coupling)
- Electrically coupled MTJs
- Base equations
- Landau-Lifshitz-Gilbert-Slonczewski equation
- Stochastic Landau-Lifshitz-Gilbert-Slonczewski equation
- Landau-Lifshitz-Gilbert-Bloch equation
- Domain wall motion
**Experimental methods:**
Some of the experimental methods available:
- PIMM
- Spin-Diode
- CIMS
- R(H), M(H)
## Web GUI
Check out the [streamlit hosted demo here](https://cmtj-app.streamlit.app/spectrum).
You can simulate:
* PIMM spectra and Spin-Diode spectra
* Try some optimization fitting
* Fit multi-domain or multi-level M(H) or R(H) loops in [Domain mode](https://cmtj-app.streamlit.app)
Let us know if you have any issues with the demo.
## Quickstart
#### Installation :rocket:
The recommended way is to use the `pip` package manager and virtualenv (or conda).
Installation is as easy as doing:
1. With `virtualenv` (recommended):
```bash
$(bash) python -m venv .my-venv
$(bash) source .my-venv/bin/activate
$(.my-venv) python -m pip install cmtj
```
2. Straight from `pip`:
```bash
python3 -m pip install cmtj
```
3. Straight from source:
```bash
python3 -m pip install git+https://github.com/LemurPwned/cmtj.git
```
4. Clone the repository:
```bash
git clone https://github.com/LemurPwned/cmtj.git
python3 -m pip install .
```
#### Extra dependencies
The package requires (if `utils` subpackage is used):
```
- numpy
- scipy
- matplotlib
```
## Documentation and examples
Documentation: [https://lemurpwned.github.io/cmtj](https://lemurpwned.github.io/cmtj).
There are many examples available, check out the [examples section in the docs](https://lemurpwned.github.io/cmtj/experimental-methods/introduction/)
## Extensions
There's a GUI version available! If you wish to conduct a subset of simulations, mainly for experimental modelling, please see the _PyMag_ project. It uses CMTJ as a backend for fast computation.
## Citing
We would appreciate citing either of the listed work if you decide to use the project or using the cite button on the right hand side panel of the repository:
[**cmtj: Simulation package for analysis of multilayer spintronic devices**](https://www.nature.com/articles/s41524-023-01002-x)
```bibtex
@article{mojsiejuk_cmtj_2023,
title = {cmtj: Simulation package for analysis of multilayer spintronic devices},
volume = {9},
issn = {2057-3960},
url = {https://www.nature.com/articles/s41524-023-01002-x},
doi = {10.1038/s41524-023-01002-x},
pages = {54},
number = {1},
journaltitle = {npj Comput Mater},
author = {Mojsiejuk, Jakub and Ziętek, Sławomir and Grochot, Krzysztof and Skowroński, Witold and Stobiecki, Tomasz},
date = {2023-04-06},
}
```
# Development
## Acknowledgements
Many thanks to professor Jack Sankey for his help with the development of thermal contributions, with inspiration from the [macrospinmob project](https://github.com/Spinmob/macrospinmob).
## Contributions
All contributions are welcome, please leave an issue if you've encountered any trouble with setup or running the library.
## Docker
In the `docker` directory there's a `Dockerfile` that can be used to build a docker image with the library installed.
`Dockerfile.app` is used for streamlit development.
## Precommit
There's a `.pre-commit-config.yaml` that does some basic python and cpp lints and checks. More static analysis to come in the future.
This may be run with:
```
pre-commit run -v
```
or
```
pre-commit run -a (or --files core/* cmtj/*)
```
## Documentation builds
**Note**
For stub generation add `__init__.py` to the `cmtj` directory.
There are a couple of stages to building the documentation
1. Build Doxygen documentation
```
doxygen Doxyfile
```
This is mostly for the C++ documentation. Future changes may couple C++ and Python docs.
2. Build stubs
The stubgen is `pybind11-stubgen` or `mypy stubgen` with the latter being preferred now.
Before running the stubgen, make sure to install the package with:
```
python3 -m pip install .
```
avoid using `-e` flag as it may cause issues with the stubgen.
Then to generate, for instance, `Stack` module stubs we can do:
```
stubgen -m cmtj.stack -o target-stub-dir/
```
or
```
python3 -c "import mypy.stubgen; mypy.stubgen.main(['-p', 'cmtj.stack', '-o', 'target-stub-dir/'])"
```
More info here: https://mypy.readthedocs.io/en/stable/stubgen.html.
3. Parse stubs to Markdown.
This stage is done by running: `python3 docs/docgen.py `
The deployment of the documentation is done via:
```bash
mkdocs gh-deploy
```
But first, worth a check:
```bash
mkdocs serve
```
Raw data
{
"_id": null,
"home_page": "https://github.com/LemurPwned/cmtj",
"name": "cmtj",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": "magnetics, physics, simulation, spintronics",
"author": "Jakub",
"author_email": "mojsieju@agh.edu.pl",
"download_url": null,
"platform": null,
"description": "<img style=\"float: right; max-width: 50px;\" src=\"assets/icon.svg\">\n\n# CMTJ\n\n[![PyPI](https://github.com/LemurPwned/cmtj/actions/workflows/main.yml/badge.svg?branch=master)](https://github.com/LemurPwned/cmtj/actions/workflows/main.yml)\n[![pages-build-deployment](https://github.com/LemurPwned/cmtj/actions/workflows/pages/pages-build-deployment/badge.svg?branch=gh-pages)](https://github.com/LemurPwned/cmtj/actions/workflows/pages/pages-build-deployment)\n[![Version](https://img.shields.io/pypi/v/cmtj)](https://pypi.org/project/cmtj/)\n[![License](https://img.shields.io/pypi/l/cmtj.svg)](https://github.com/LemurPwned/cmtj/blob/master/LICENSE)\n[![Streamlit](https://static.streamlit.io/badges/streamlit_badge_black_white.svg)](https://cmtj-app.streamlit.app/spectrum)\n![Downloads](https://img.shields.io/pypi/dm/cmtj.svg)\n\n## Table of contents\n\n- [CMTJ](#cmtj)\n - [Table of contents](#table-of-contents)\n - [Short description](#short-description)\n - [What can you simulate?](#what-can-you-simulate)\n - [Web GUI](#web-gui)\n - [Quickstart](#quickstart)\n - [Installation :rocket:](#installation-rocket)\n - [Extra dependencies](#extra-dependencies)\n - [Documentation and examples](#documentation-and-examples)\n - [Extensions](#extensions)\n - [Citing](#citing)\n- [Development](#development)\n - [Acknowledgements](#acknowledgements)\n - [Contributions](#contributions)\n - [Docker](#docker)\n - [Precommit](#precommit)\n - [Documentation builds](#documentation-builds)\n\n## Short description\n\nThe `cmtj` name may be misleading -- the MTJ (Magnetic Tunnel Junctions) are not the only structures that may be simulated.\nThe library allows for macromagnetic simulation of various multilayer spintronic structures. The package uses C++ implementation of (s)LLGS (stochastic Landau-Lifschitz-Gilbert-Slonczewski) equation with various field contributions included for instance: anisotropy, interlayer exchange coupling, demagnetisation, dipole fields etc.\nIt is also possible to connect devices in parallel or in series to have electrically coupled arrays.\n\n### What can you simulate?\n\nBelow is a brief list of examples (it's not exhaustive! Check the docs for more).\n\n**Magnetic devices:**\n\n- Magnetic Tunnel Junctions\n - Voltage-Driven Magnetic Tunnel Junctions\n - Spin-Torque Oscillators\n - VCMA sensors and devices\n - Magnetic Tunnel Junction Arrays\n- SOT devices\n - Current-Driven SOT\n- Advanced device coupling\n- Reservoirs (dipole coupling)\n- Electrically coupled MTJs\n- Base equations\n - Landau-Lifshitz-Gilbert-Slonczewski equation\n - Stochastic Landau-Lifshitz-Gilbert-Slonczewski equation\n - Landau-Lifshitz-Gilbert-Bloch equation\n- Domain wall motion\n\n**Experimental methods:**\n\nSome of the experimental methods available:\n\n- PIMM\n- Spin-Diode\n- CIMS\n- R(H), M(H)\n\n## Web GUI\n\nCheck out the [streamlit hosted demo here](https://cmtj-app.streamlit.app/spectrum). \nYou can simulate:\n\n* PIMM spectra and Spin-Diode spectra\n* Try some optimization fitting\n* Fit multi-domain or multi-level M(H) or R(H) loops in [Domain mode](https://cmtj-app.streamlit.app)\n\nLet us know if you have any issues with the demo.\n\n## Quickstart\n\n#### Installation :rocket:\n\nThe recommended way is to use the `pip` package manager and virtualenv (or conda).\nInstallation is as easy as doing:\n\n1. With `virtualenv` (recommended):\n\n```bash\n$(bash) python -m venv .my-venv\n$(bash) source .my-venv/bin/activate\n$(.my-venv) python -m pip install cmtj\n```\n\n2. Straight from `pip`:\n\n```bash\npython3 -m pip install cmtj\n```\n\n3. Straight from source:\n\n```bash\npython3 -m pip install git+https://github.com/LemurPwned/cmtj.git\n```\n\n4. Clone the repository:\n\n```bash\ngit clone https://github.com/LemurPwned/cmtj.git\npython3 -m pip install .\n```\n\n#### Extra dependencies\n\nThe package requires (if `utils` subpackage is used):\n\n```\n- numpy\n- scipy\n- matplotlib\n```\n\n## Documentation and examples\n\nDocumentation: [https://lemurpwned.github.io/cmtj](https://lemurpwned.github.io/cmtj).\nThere are many examples available, check out the [examples section in the docs](https://lemurpwned.github.io/cmtj/experimental-methods/introduction/)\n\n## Extensions\n\nThere's a GUI version available! If you wish to conduct a subset of simulations, mainly for experimental modelling, please see the _PyMag_ project. It uses CMTJ as a backend for fast computation.\n\n## Citing\n\nWe would appreciate citing either of the listed work if you decide to use the project or using the cite button on the right hand side panel of the repository:\n\n[**cmtj: Simulation package for analysis of multilayer spintronic devices**](https://www.nature.com/articles/s41524-023-01002-x)\n\n```bibtex\n@article{mojsiejuk_cmtj_2023,\n\ttitle = {cmtj: Simulation package for analysis of multilayer spintronic devices},\n\tvolume = {9},\n\tissn = {2057-3960},\n\turl = {https://www.nature.com/articles/s41524-023-01002-x},\n\tdoi = {10.1038/s41524-023-01002-x},\n\tpages = {54},\n\tnumber = {1},\n\tjournaltitle = {npj Comput Mater},\n\tauthor = {Mojsiejuk, Jakub and Zi\u0119tek, S\u0142awomir and Grochot, Krzysztof and Skowro\u0144ski, Witold and Stobiecki, Tomasz},\n\tdate = {2023-04-06},\n}\n```\n\n# Development\n\n## Acknowledgements\n\nMany thanks to professor Jack Sankey for his help with the development of thermal contributions, with inspiration from the [macrospinmob project](https://github.com/Spinmob/macrospinmob).\n\n## Contributions\n\nAll contributions are welcome, please leave an issue if you've encountered any trouble with setup or running the library.\n\n## Docker\n\nIn the `docker` directory there's a `Dockerfile` that can be used to build a docker image with the library installed.\n`Dockerfile.app` is used for streamlit development.\n\n## Precommit\n\nThere's a `.pre-commit-config.yaml` that does some basic python and cpp lints and checks. More static analysis to come in the future.\nThis may be run with:\n\n```\npre-commit run -v\n```\n\nor\n\n```\npre-commit run -a (or --files core/* cmtj/*)\n```\n\n## Documentation builds\n\n**Note**\nFor stub generation add `__init__.py` to the `cmtj` directory.\n\nThere are a couple of stages to building the documentation\n\n1. Build Doxygen documentation\n ```\n doxygen Doxyfile\n ```\n This is mostly for the C++ documentation. Future changes may couple C++ and Python docs.\n2. Build stubs\n The stubgen is `pybind11-stubgen` or `mypy stubgen` with the latter being preferred now.\n Before running the stubgen, make sure to install the package with:\n ```\n python3 -m pip install .\n ```\n avoid using `-e` flag as it may cause issues with the stubgen.\n Then to generate, for instance, `Stack` module stubs we can do:\n ```\n stubgen -m cmtj.stack -o target-stub-dir/\n ```\n or\n ```\n python3 -c \"import mypy.stubgen; mypy.stubgen.main(['-p', 'cmtj.stack', '-o', 'target-stub-dir/'])\"\n ```\n More info here: https://mypy.readthedocs.io/en/stable/stubgen.html.\n3. Parse stubs to Markdown.\n This stage is done by running: `python3 docs/docgen.py `\n The deployment of the documentation is done via:\n ```bash\n mkdocs gh-deploy\n ```\n But first, worth a check:\n ```bash\n mkdocs serve\n ```\n",
"bugtrack_url": null,
"license": null,
"summary": "CMTJ - C Magnetic Tunnel Junctions.",
"version": "1.6.1",
"project_urls": {
"Homepage": "https://github.com/LemurPwned/cmtj"
},
"split_keywords": [
"magnetics",
" physics",
" simulation",
" spintronics"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "5bf66dd83c777f405107257afc4518f4afcde5ffba2037987d1a20361df3c8a0",
"md5": "a44e5a35a3cb8a35bd0608760a6b26da",
"sha256": "912d256e567a326cb2ef32b1dc4f22fa26424ba1e37324c2169b65d9ec8e3221"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp310-cp310-macosx_10_9_universal2.whl",
"has_sig": false,
"md5_digest": "a44e5a35a3cb8a35bd0608760a6b26da",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": null,
"size": 700600,
"upload_time": "2024-12-10T17:00:24",
"upload_time_iso_8601": "2024-12-10T17:00:24.854106Z",
"url": "https://files.pythonhosted.org/packages/5b/f6/6dd83c777f405107257afc4518f4afcde5ffba2037987d1a20361df3c8a0/cmtj-1.6.1-cp310-cp310-macosx_10_9_universal2.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "20db0c4bddabfd9741319696b8be5fa0b7fcf6efd0bf98bb4d4496f3d3e1524b",
"md5": "2abcae547de1771a80094c98e729ea94",
"sha256": "a7aa4d4025cd6cf7ead1640ddad61dec1945378a2ea4112e0c2c2e6a95fd07ea"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "2abcae547de1771a80094c98e729ea94",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": null,
"size": 4358884,
"upload_time": "2024-12-10T17:02:38",
"upload_time_iso_8601": "2024-12-10T17:02:38.791416Z",
"url": "https://files.pythonhosted.org/packages/20/db/0c4bddabfd9741319696b8be5fa0b7fcf6efd0bf98bb4d4496f3d3e1524b/cmtj-1.6.1-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "bc94f76f0b62ea5b5574c90169fe04cbdbb2cc6040c6ca7ec486134d81b6f541",
"md5": "50dad39b201d1fd3a7892034448b1016",
"sha256": "5652b8e71630fed95513c75772b63e00be2149997ee98ef2689ce103498a99ee"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp310-cp310-win_amd64.whl",
"has_sig": false,
"md5_digest": "50dad39b201d1fd3a7892034448b1016",
"packagetype": "bdist_wheel",
"python_version": "cp310",
"requires_python": null,
"size": 291741,
"upload_time": "2024-12-10T17:00:50",
"upload_time_iso_8601": "2024-12-10T17:00:50.639782Z",
"url": "https://files.pythonhosted.org/packages/bc/94/f76f0b62ea5b5574c90169fe04cbdbb2cc6040c6ca7ec486134d81b6f541/cmtj-1.6.1-cp310-cp310-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "9679e62a398c244547e9290c91addae1c07873fa4bd035f686bf48ad1fb9834d",
"md5": "c5a8c5b30cfdadb05955b135711d5b71",
"sha256": "aca65745b9a650e6a3b1cdc7c99185d284766cbcac9e3fdbf8e366b448bf1c75"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp311-cp311-macosx_10_9_universal2.whl",
"has_sig": false,
"md5_digest": "c5a8c5b30cfdadb05955b135711d5b71",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": null,
"size": 703780,
"upload_time": "2024-12-10T17:00:10",
"upload_time_iso_8601": "2024-12-10T17:00:10.197336Z",
"url": "https://files.pythonhosted.org/packages/96/79/e62a398c244547e9290c91addae1c07873fa4bd035f686bf48ad1fb9834d/cmtj-1.6.1-cp311-cp311-macosx_10_9_universal2.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "8c538ddf8cfe5c868e6b19909320f1c3f7ecd767364621f1546d52c21516d889",
"md5": "482397d53bd6cfaa04a55924351de684",
"sha256": "2d8c33e22e43128e5361b6e82f1dea9bde6ea6cbfae1ed56646300cf28a7c9db"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "482397d53bd6cfaa04a55924351de684",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": null,
"size": 4383269,
"upload_time": "2024-12-10T17:02:41",
"upload_time_iso_8601": "2024-12-10T17:02:41.590910Z",
"url": "https://files.pythonhosted.org/packages/8c/53/8ddf8cfe5c868e6b19909320f1c3f7ecd767364621f1546d52c21516d889/cmtj-1.6.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "800de5e6e71483715ba97daa2df6d783bc887edf76efd79e8c5aaa1d0214567f",
"md5": "df08d47a07aba91ff19799fc33966aa4",
"sha256": "61bbc69e0fa0317d01cfd7644eddcd7211599a307e3163f28ed5721f026f61f0"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp311-cp311-win_amd64.whl",
"has_sig": false,
"md5_digest": "df08d47a07aba91ff19799fc33966aa4",
"packagetype": "bdist_wheel",
"python_version": "cp311",
"requires_python": null,
"size": 292698,
"upload_time": "2024-12-10T17:01:21",
"upload_time_iso_8601": "2024-12-10T17:01:21.955273Z",
"url": "https://files.pythonhosted.org/packages/80/0d/e5e6e71483715ba97daa2df6d783bc887edf76efd79e8c5aaa1d0214567f/cmtj-1.6.1-cp311-cp311-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "01126dcc753ecda5821c3f1898f69479f4737b54ad04cf567008d90124ab83c9",
"md5": "c35ba636937fd9b08a6176f665949b10",
"sha256": "e7a8942877fbb3d9e7f8804729dacaf16c09051e4ea271eb5088cb7f93052705"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp312-cp312-macosx_10_13_universal2.whl",
"has_sig": false,
"md5_digest": "c35ba636937fd9b08a6176f665949b10",
"packagetype": "bdist_wheel",
"python_version": "cp312",
"requires_python": null,
"size": 717519,
"upload_time": "2024-12-10T17:00:22",
"upload_time_iso_8601": "2024-12-10T17:00:22.435872Z",
"url": "https://files.pythonhosted.org/packages/01/12/6dcc753ecda5821c3f1898f69479f4737b54ad04cf567008d90124ab83c9/cmtj-1.6.1-cp312-cp312-macosx_10_13_universal2.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "cee6390468bf826e77eec2edaddcd71bb3e6f9e9ac02c5db447b57931cb80b04",
"md5": "30a5e891806161f5003b194d7ec554c4",
"sha256": "7f59f40b3f004087fd60cbfe2ea19eee335682f8e685106726bd07d108594cb0"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp312-cp312-win_amd64.whl",
"has_sig": false,
"md5_digest": "30a5e891806161f5003b194d7ec554c4",
"packagetype": "bdist_wheel",
"python_version": "cp312",
"requires_python": null,
"size": 294991,
"upload_time": "2024-12-10T17:01:10",
"upload_time_iso_8601": "2024-12-10T17:01:10.323086Z",
"url": "https://files.pythonhosted.org/packages/ce/e6/390468bf826e77eec2edaddcd71bb3e6f9e9ac02c5db447b57931cb80b04/cmtj-1.6.1-cp312-cp312-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "898e9de4f4433947950d198a9100d62847d8145b11346c75779d7deb73bc38d4",
"md5": "87214b08dfb8f06402ea8964de7be6ba",
"sha256": "5458cae594ebebf57343fdd538853e8f62ab08b6b94174c37794e1a06a587328"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp38-cp38-macosx_11_0_universal2.whl",
"has_sig": false,
"md5_digest": "87214b08dfb8f06402ea8964de7be6ba",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": null,
"size": 700743,
"upload_time": "2024-12-10T17:00:41",
"upload_time_iso_8601": "2024-12-10T17:00:41.782884Z",
"url": "https://files.pythonhosted.org/packages/89/8e/9de4f4433947950d198a9100d62847d8145b11346c75779d7deb73bc38d4/cmtj-1.6.1-cp38-cp38-macosx_11_0_universal2.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "2b7c8202aa02016cd9dc67ecd3eb938a5dd187f32970868d3229862117c50335",
"md5": "543216abdc25506acd530cad058f3438",
"sha256": "69274da944a9eaf93a36775dc038a191448e64205786dd7ec12babcf7ab9bc71"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "543216abdc25506acd530cad058f3438",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": null,
"size": 4372388,
"upload_time": "2024-12-10T17:02:45",
"upload_time_iso_8601": "2024-12-10T17:02:45.361462Z",
"url": "https://files.pythonhosted.org/packages/2b/7c/8202aa02016cd9dc67ecd3eb938a5dd187f32970868d3229862117c50335/cmtj-1.6.1-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "864492b619cd6ab740d1c48bb12288298360c3af47cbedb45cf06ed398d86c9c",
"md5": "13b60f1fef4097e82a1b2868049f3dfe",
"sha256": "1788c2406dc03417d412e918acc18acf9d63c660552fd755b2fbd7a5009e8072"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp38-cp38-win_amd64.whl",
"has_sig": false,
"md5_digest": "13b60f1fef4097e82a1b2868049f3dfe",
"packagetype": "bdist_wheel",
"python_version": "cp38",
"requires_python": null,
"size": 294845,
"upload_time": "2024-12-10T17:01:07",
"upload_time_iso_8601": "2024-12-10T17:01:07.707984Z",
"url": "https://files.pythonhosted.org/packages/86/44/92b619cd6ab740d1c48bb12288298360c3af47cbedb45cf06ed398d86c9c/cmtj-1.6.1-cp38-cp38-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "a7991ac08deebb5c2edde783e81fd013ec6cc3bf68e80df756787c48c1be1500",
"md5": "8f3dbe85bf738a5664e1419c89911464",
"sha256": "69554d8456b03e443816a6da72fa454e18e7a27a8ea91d40df58a10d22646853"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp39-cp39-macosx_10_9_universal2.whl",
"has_sig": false,
"md5_digest": "8f3dbe85bf738a5664e1419c89911464",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": null,
"size": 700909,
"upload_time": "2024-12-10T17:00:35",
"upload_time_iso_8601": "2024-12-10T17:00:35.476531Z",
"url": "https://files.pythonhosted.org/packages/a7/99/1ac08deebb5c2edde783e81fd013ec6cc3bf68e80df756787c48c1be1500/cmtj-1.6.1-cp39-cp39-macosx_10_9_universal2.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "78f76eee4ff234fb69162ed4c3817cade7b96c3a973dfe1536467eb8a2a0cbe6",
"md5": "f294e7cdc3a106d69118e981ae94e956",
"sha256": "a406a506652b0382f2a4d25bcbc0c6b18b9539038bbbcf8c068d89cd35b5460c"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "f294e7cdc3a106d69118e981ae94e956",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": null,
"size": 4356067,
"upload_time": "2024-12-10T17:02:47",
"upload_time_iso_8601": "2024-12-10T17:02:47.259689Z",
"url": "https://files.pythonhosted.org/packages/78/f7/6eee4ff234fb69162ed4c3817cade7b96c3a973dfe1536467eb8a2a0cbe6/cmtj-1.6.1-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "8248e2c8df286b39df7f1bd77b224374a4f16f9da64925020b4df8a11f5f84e5",
"md5": "48e990895193eea0d10ba36272acce41",
"sha256": "5d533cfc2297421065a7d4f2a66fe1b8a2c63d2c4f20795a7ace2b18943f1bc6"
},
"downloads": -1,
"filename": "cmtj-1.6.1-cp39-cp39-win_amd64.whl",
"has_sig": false,
"md5_digest": "48e990895193eea0d10ba36272acce41",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": null,
"size": 285529,
"upload_time": "2024-12-10T17:00:33",
"upload_time_iso_8601": "2024-12-10T17:00:33.428360Z",
"url": "https://files.pythonhosted.org/packages/82/48/e2c8df286b39df7f1bd77b224374a4f16f9da64925020b4df8a11f5f84e5/cmtj-1.6.1-cp39-cp39-win_amd64.whl",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-10 17:00:24",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "LemurPwned",
"github_project": "cmtj",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "cmtj"
}