cmtj 1.5.4

Creator: bradpython12

Last updated:

Add to Cart

Description:

cmtj 1.5.4

CMTJ






Table of contents

CMTJ

Table of contents
Short description
Web GUI
Quickstart

Installation :rocket:
Extra dependencies


Documentation and examples
Extensions
Citing


Development

Acknowledgements
Contributions
Docker
Precommit
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.
Web GUI
Check out the streamlit hosted demo here. You can simulate PIMM spectra and Spin-Diode spectra there. 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:

With virtualenv (recommended):

$(bash) python -m venv .my-venv
$(bash) source .my-venv/bin/activate
$(.my-venv) python -m pip install cmtj


Straight from pip:

python3 -m pip install cmtj


Straight from source:

python3 -m pip install git+https://github.com/LemurPwned/cmtj.git


Clone the repository:

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.
There are many examples available, check out the examples section in the docs
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
@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.
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
There are couple of stages to building the documentation

Build Doxygen documentation
doxygen Doxyfile

This is mostly for the C++ documentation. Furture changes may couple C++ and Python docs.
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.
Parse stubs to Markdown.
This stage is done by running:
python3 docs/docgen.py
The deployment of the documentation is done via:
mkdocs gh-deploy

But first, worth a check:
mkdocs serve

License

For personal and professional use. You cannot resell or redistribute these repositories in their original state.

Customer Reviews

There are no reviews.