> [!IMPORTANT]
> This is the lite version of py4DSTEM with fewer dependencies. While this means that the package will load faster and be pyodide compatible, it lacks some of the functionality such as GPU-acceleration, whole-pattern fitting, etc. If you're looking for the main py4DSTEM repo, you can find it [here](https://github.com/py4dstem/py4DSTEM).
![py4DSTEM logo](https://raw.githubusercontent.com/py4dstem/py4DSTEM/dev/images/py4DSTEM_logo.png)
**py4DSTEM** is an open source set of python tools for processing and analysis of four-dimensional scanning transmission electron microscopy (4D-STEM) data.
Additional information:
- [Installation instructions](#install)
- [The py4DSTEM documentation pages](https://py4dstem.readthedocs.io/en/latest/index.html).
- [Tutorials and example code](https://github.com/py4dstem/py4DSTEM_tutorials)
- [Want to get involved?](#Contributing)
- [Our open access py4DSTEM publication in Microscopy and Microanalysis](https://doi.org/10.1017/S1431927621000477) describing this project and demonstrating a variety of applications.
- [Our open access 4D-STEM review in Microscopy and Microanalysis](https://doi.org/10.1017/S1431927619000497) describing this project and demonstrating a variety of applications.
# What is 4D-STEM?
In a traditional STEM experiment, a beam of high energy electrons is focused to a very fine probe - on the order of, or even smaller than, the spacing between atoms - and rastered across the surface of the sample. A conventional two-dimensional STEM image is formed by populating the value of each pixel with the electron flux through a detector at the corresponding beam position. In 4D-STEM, a pixelated detector is used instead, where a 2D image of the diffracted probe is recorded at every rastered probe position. A 4D-STEM scan thus results in a 4D data array.
4D-STEM data is information rich.
A datacube can be collapsed in real space to yield information comparable to nanobeam electron diffraction experiment, or in diffraction space to yield a variety of virtual images, corresponding to both traditional STEM imaging modes as well as more exotic virtual imaging modalities.
The structure, symmetries, and spacings of Bragg disks can be used to extract spatially resolved maps of crystallinity, grain orientations, and lattice strain.
Redundant information in overlapping Bragg disks can be leveraged to calculate the sample potential.
Structure in the diffracted halos of amorphous systems can be used to describe the short and medium range order.
**py4DSTEM** supports many different modes of 4DSTEM analysis.
The tutorials, sample code, module, and function documentation all provide more detailed discussion on some of the analytical methods possible with this code.
<a id='install'></a>
# py4DSTEM Installation
[![PyPI version](https://badge.fury.io/py/py4dstem.svg)](https://badge.fury.io/py/py4dstem)
[![Anaconda-Server Badge](https://anaconda.org/conda-forge/py4dstem/badges/version.svg)](https://anaconda.org/conda-forge/py4dstem)
[![Anaconda-Server Badge](https://anaconda.org/conda-forge/py4dstem/badges/latest_release_date.svg)](https://anaconda.org/conda-forge/py4dstem)
[![Anaconda-Server Badge](https://anaconda.org/conda-forge/py4dstem/badges/platforms.svg)](https://anaconda.org/conda-forge/py4dstem)
[![Anaconda-Server Badge](https://anaconda.org/conda-forge/py4dstem/badges/downloads.svg)](https://anaconda.org/conda-forge/py4dstem)
The recommended installation for **py4DSTEM** uses the Anaconda python distribution.
First, download and install Anaconda: www.anaconda.com/download.
If you prefer a more lightweight conda client, you can instead install Miniconda: https://docs.conda.io/en/latest/miniconda.html.
Then open a conda terminal and run one of the following sets of commands to ensure everything is up-to-date and create a new environment for your py4DSTEM installation:
```
conda update conda
conda create -n py4dstem
conda activate py4dstem
conda install -c conda-forge py4dstem pymatgen jupyterlab
```
In order, these commands
- ensure your installation of anaconda is up-to-date
- make a virtual environment (see below)
- enter the environment
- install py4DSTEM, as well as pymatgen (used for crystal structure calculations) and JupyterLab (an interface for running Python notebooks like those in the [py4DSTEM tutorials repository](https://github.com/py4dstem/py4DSTEM_tutorials))
We've had some recent reports install of `conda` getting stuck trying to solve the environment using the above installation. If you run into this problem, you can install py4DSTEM using `pip` instead of `conda` by running:
```
conda update conda
conda create -n py4dstem python=3.10
conda activate py4dstem
pip install py4dstem pymatgen
```
Both `conda` and `pip` are programs which manage package installations, i.e. make sure different codes you're installing which depend on one another are using mutually compatible versions. Each has advantages and disadvantages; `pip` is a little more bare-bones, and we've seen this install work when `conda` doesn't. If you also want to use Jupyterlab you can then use either `pip install jupyterlab` or `conda install jupyterlab`.
If you would prefer to install only the base modules of **py4DSTEM**, and skip pymategen and Jupterlab, you can instead run:
```
conda install -c conda-forge py4dstem
```
Finally, regardless of which of the above approaches you used, in Windows you should then also run:
```
conda install pywin32
```
which enables Python to talk to the Windows API.
Please note that virtual environments are used in the instructions above in order to make sure packages that have different dependencies don't conflict with one another.
Because these directions install py4DSTEM to its own virtual environment, each time you want to use py4DSTEM you'll need to activate this environment.
You can do this in the command line by running `conda activate py4dstem`, or, if you're using the Anaconda Navigator, by clicking on the Environments tab and then clicking on `py4dstem`.
Last - as of the version 0.14.4 update, we've had a few reports of problems upgrading to the newest version. We're not sure what's causing the issue yet, but have found the new version can be installed successfully in these cases using a fresh Anaconda installation.
<a id='legacyinstall'></a>
## Legacy installations (version <0.14)
The latest version of py4DSTEM (v0.14) makes changes to the classes and functions which may not be compatible with code written for prior versions.
We are working to ensure better backwards-compatibility in the future.
For now, if you have code from earlier versions, you can either (1) install the legacy version of your choice, or (2) update legacy code to use the version 0.14 methods.
To update your code to the new syntax, check out the examples in the [py4DSTEM tutorials repository](https://github.com/py4dstem/py4DSTEM_tutorials) and the docstrings for the classes and functions you're using.
To install the legacy version of py4DSTEM of your choice, you can call
```
pip install py4dstem==0.XX.XX
```
substituting the desired version for `XX.XX`. For instance, you can install the last version 13 release with
```
pip install py4dstem==0.13.17
```
or the last version 12 release with
```
pip install py4dstem==0.12.24
```
## Advanced installations - GPU acceleration and ML functionality
To install the py4dstem with AI/ML functionality, follow the steps below.
If you're using a machine with an Nvidia GPU and CUDA capability, run:
```
conda update conda
conda create -n py4dstem-aiml
conda activate py4dstem-aiml
conda install -c conda-forge cudatoolkit=11.0 cudnn=8.1 cupy
pip install "py4dstem[aiml-cuda]"
```
If your machine does not have a CUDA capable device, run
```
conda update conda
conda create -n py4dstem
conda activate py4dstem
conda install pip
pip install "py4dstem[aiml]"
```
# The py4DSTEM GUI
The py4DSTEM GUI data browser has been moved to a separate repository.
You can [find that repository here](https://github.com/py4dstem/py4D-browser).
You can install the GUI from the command line with:
```
pip install py4D-browser
```
The py4D-browser can then be launched from the command line by calling:
```
py4DGUI
```
# Running the code
The anaconda navigator can be used to launch various Python interfaces, including Jupyter Notebooks, JupyterLab, PyCharm, and others.
Once you're inside the conda environment where you installed py4DSTEM and you've launched an interface to the Python interpreter, you can import **py4DSTEM** to access all its modules and functions using `import py4DSTEM`.
## Example code and tutorials
At this point you'll need code, and data!
Sample code demonstrating a variety of workflows can be found in [the py4DSTEM tutorials repository](https://github.com/py4dstem/py4DSTEM_tutorials) in the `/notebooks` directory.
These sample files are provided as Jupyter notebooks.
Links to the data used in each notebook are provided in the intro cell of each notebook.
# More information
<a id='Contributing'></a>
## Contributing Guide
We are grateful for your interest in contributing to py4DSTEM. There are many ways to contribute to py4DSTEM, including Reporting bugs, Submitting feature requests, Improving documentation and Developing new code
For more information checkout our [Contributors Guide](CONTRIBUTORS.md)
## Documentation
Our documentation pages are [available here](https://py4dstem.readthedocs.io/en/latest/index.html).
## Scientific papers which use **py4DSTEM**
See a list [here](docs/papers.md).
# Acknowledgements
If you use py4DSTEM for a scientific study, please cite [our open access py4DSTEM publication in Microscopy and Microanalysis](https://doi.org/10.1017/S1431927621000477). You are also free to use the py4DSTEM [logo in PDF format](https://raw.githubusercontent.com/py4dstem/py4DSTEM/dev/images/py4DSTEM_logo_54.pdf) or [logo in PNG format](https://raw.githubusercontent.com/py4dstem/py4DSTEM/dev/images/py4DSTEM_logo_54_export.png) for presentations or posters.
[![TRI logo](https://raw.githubusercontent.com/py4dstem/py4DSTEM/dev/images/toyota_research_institute.png)](https://www.tri.global/)
The developers gratefully acknowledge the financial support of the Toyota Research Institute for the research and development time which made this project possible.
[![DOE logo](https://raw.githubusercontent.com/py4dstem/py4DSTEM/dev/images/DOE_logo.png)](https://www.energy.gov/science/bes/basic-energy-sciences/)
Additional funding has been provided by the US Department of Energy, Office of Science, Basic Energy Sciences.
# License
GNU GPLv3
**py4DSTEM** is open source software distributed under a GPLv3 license.
It is free to use, alter, or build on, provided that any work derived from **py4DSTEM** is also kept free and open under a GPLv3 license.
Raw data
{
"_id": null,
"home_page": "https://github.com/py4dstem/py4DSTEM-lite/",
"name": "py4DSTEM-lite",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.10",
"maintainer_email": null,
"keywords": "STEM, 4DSTEM, lite",
"author": "Benjamin H. Savitzky",
"author_email": "ben.savitzky@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/b0/44/166a68a2253d6d31c92c77556e590d49921c5a8e1596b9eafd9c7e1184ff/py4dstem_lite-0.14.16.tar.gz",
"platform": null,
"description": "> [!IMPORTANT]\n> This is the lite version of py4DSTEM with fewer dependencies. While this means that the package will load faster and be pyodide compatible, it lacks some of the functionality such as GPU-acceleration, whole-pattern fitting, etc. If you're looking for the main py4DSTEM repo, you can find it [here](https://github.com/py4dstem/py4DSTEM).\n\n![py4DSTEM logo](https://raw.githubusercontent.com/py4dstem/py4DSTEM/dev/images/py4DSTEM_logo.png)\n\n**py4DSTEM** is an open source set of python tools for processing and analysis of four-dimensional scanning transmission electron microscopy (4D-STEM) data.\nAdditional information:\n\n- [Installation instructions](#install)\n- [The py4DSTEM documentation pages](https://py4dstem.readthedocs.io/en/latest/index.html).\n- [Tutorials and example code](https://github.com/py4dstem/py4DSTEM_tutorials)\n- [Want to get involved?](#Contributing)\n- [Our open access py4DSTEM publication in Microscopy and Microanalysis](https://doi.org/10.1017/S1431927621000477) describing this project and demonstrating a variety of applications.\n- [Our open access 4D-STEM review in Microscopy and Microanalysis](https://doi.org/10.1017/S1431927619000497) describing this project and demonstrating a variety of applications.\n\n\n\n# What is 4D-STEM?\n\nIn a traditional STEM experiment, a beam of high energy electrons is focused to a very fine probe - on the order of, or even smaller than, the spacing between atoms - and rastered across the surface of the sample. A conventional two-dimensional STEM image is formed by populating the value of each pixel with the electron flux through a detector at the corresponding beam position. In 4D-STEM, a pixelated detector is used instead, where a 2D image of the diffracted probe is recorded at every rastered probe position. A 4D-STEM scan thus results in a 4D data array.\n\n\n4D-STEM data is information rich.\nA datacube can be collapsed in real space to yield information comparable to nanobeam electron diffraction experiment, or in diffraction space to yield a variety of virtual images, corresponding to both traditional STEM imaging modes as well as more exotic virtual imaging modalities.\nThe structure, symmetries, and spacings of Bragg disks can be used to extract spatially resolved maps of crystallinity, grain orientations, and lattice strain.\nRedundant information in overlapping Bragg disks can be leveraged to calculate the sample potential.\nStructure in the diffracted halos of amorphous systems can be used to describe the short and medium range order.\n\n**py4DSTEM** supports many different modes of 4DSTEM analysis.\nThe tutorials, sample code, module, and function documentation all provide more detailed discussion on some of the analytical methods possible with this code.\n\n\n\n<a id='install'></a>\n# py4DSTEM Installation\n\n[![PyPI version](https://badge.fury.io/py/py4dstem.svg)](https://badge.fury.io/py/py4dstem)\n[![Anaconda-Server Badge](https://anaconda.org/conda-forge/py4dstem/badges/version.svg)](https://anaconda.org/conda-forge/py4dstem)\n[![Anaconda-Server Badge](https://anaconda.org/conda-forge/py4dstem/badges/latest_release_date.svg)](https://anaconda.org/conda-forge/py4dstem)\n[![Anaconda-Server Badge](https://anaconda.org/conda-forge/py4dstem/badges/platforms.svg)](https://anaconda.org/conda-forge/py4dstem)\n[![Anaconda-Server Badge](https://anaconda.org/conda-forge/py4dstem/badges/downloads.svg)](https://anaconda.org/conda-forge/py4dstem)\n\nThe recommended installation for **py4DSTEM** uses the Anaconda python distribution.\nFirst, download and install Anaconda: www.anaconda.com/download. \nIf you prefer a more lightweight conda client, you can instead install Miniconda: https://docs.conda.io/en/latest/miniconda.html.\nThen open a conda terminal and run one of the following sets of commands to ensure everything is up-to-date and create a new environment for your py4DSTEM installation:\n\n```\nconda update conda\nconda create -n py4dstem\nconda activate py4dstem\nconda install -c conda-forge py4dstem pymatgen jupyterlab\n```\n\nIn order, these commands\n- ensure your installation of anaconda is up-to-date\n- make a virtual environment (see below)\n- enter the environment\n- install py4DSTEM, as well as pymatgen (used for crystal structure calculations) and JupyterLab (an interface for running Python notebooks like those in the [py4DSTEM tutorials repository](https://github.com/py4dstem/py4DSTEM_tutorials))\n\n\nWe've had some recent reports install of `conda` getting stuck trying to solve the environment using the above installation. If you run into this problem, you can install py4DSTEM using `pip` instead of `conda` by running:\n\n```\nconda update conda\nconda create -n py4dstem python=3.10 \nconda activate py4dstem\npip install py4dstem pymatgen \n```\n\nBoth `conda` and `pip` are programs which manage package installations, i.e. make sure different codes you're installing which depend on one another are using mutually compatible versions. Each has advantages and disadvantages; `pip` is a little more bare-bones, and we've seen this install work when `conda` doesn't. If you also want to use Jupyterlab you can then use either `pip install jupyterlab` or `conda install jupyterlab`.\n\nIf you would prefer to install only the base modules of **py4DSTEM**, and skip pymategen and Jupterlab, you can instead run:\n\n```\nconda install -c conda-forge py4dstem\n```\n\nFinally, regardless of which of the above approaches you used, in Windows you should then also run:\n\n```\nconda install pywin32\n```\n\nwhich enables Python to talk to the Windows API.\n\nPlease note that virtual environments are used in the instructions above in order to make sure packages that have different dependencies don't conflict with one another.\nBecause these directions install py4DSTEM to its own virtual environment, each time you want to use py4DSTEM you'll need to activate this environment.\nYou can do this in the command line by running `conda activate py4dstem`, or, if you're using the Anaconda Navigator, by clicking on the Environments tab and then clicking on `py4dstem`.\n\nLast - as of the version 0.14.4 update, we've had a few reports of problems upgrading to the newest version. We're not sure what's causing the issue yet, but have found the new version can be installed successfully in these cases using a fresh Anaconda installation.\n\n\n<a id='legacyinstall'></a>\n## Legacy installations (version <0.14)\n\nThe latest version of py4DSTEM (v0.14) makes changes to the classes and functions which may not be compatible with code written for prior versions.\nWe are working to ensure better backwards-compatibility in the future.\nFor now, if you have code from earlier versions, you can either (1) install the legacy version of your choice, or (2) update legacy code to use the version 0.14 methods.\nTo update your code to the new syntax, check out the examples in the [py4DSTEM tutorials repository](https://github.com/py4dstem/py4DSTEM_tutorials) and the docstrings for the classes and functions you're using.\nTo install the legacy version of py4DSTEM of your choice, you can call\n\n```\npip install py4dstem==0.XX.XX\n```\n\nsubstituting the desired version for `XX.XX`. For instance, you can install the last version 13 release with\n\n```\npip install py4dstem==0.13.17\n```\n\nor the last version 12 release with\n\n```\npip install py4dstem==0.12.24\n```\n\n\n\n\n## Advanced installations - GPU acceleration and ML functionality\n\nTo install the py4dstem with AI/ML functionality, follow the steps below.\nIf you're using a machine with an Nvidia GPU and CUDA capability, run:\n\n```\nconda update conda\nconda create -n py4dstem-aiml\nconda activate py4dstem-aiml\nconda install -c conda-forge cudatoolkit=11.0 cudnn=8.1 cupy \npip install \"py4dstem[aiml-cuda]\"\n```\n\nIf your machine does not have a CUDA capable device, run\n```\nconda update conda\nconda create -n py4dstem\nconda activate py4dstem\nconda install pip\npip install \"py4dstem[aiml]\"\n```\n\n\n\n# The py4DSTEM GUI\n\nThe py4DSTEM GUI data browser has been moved to a separate repository.\nYou can [find that repository here](https://github.com/py4dstem/py4D-browser).\nYou can install the GUI from the command line with:\n\n```\npip install py4D-browser\n```\n\nThe py4D-browser can then be launched from the command line by calling:\n\n```\npy4DGUI\n```\n\n\n\n\n# Running the code\n\nThe anaconda navigator can be used to launch various Python interfaces, including Jupyter Notebooks, JupyterLab, PyCharm, and others.\n\nOnce you're inside the conda environment where you installed py4DSTEM and you've launched an interface to the Python interpreter, you can import **py4DSTEM** to access all its modules and functions using `import py4DSTEM`.\n\n\n## Example code and tutorials\n\nAt this point you'll need code, and data!\nSample code demonstrating a variety of workflows can be found in [the py4DSTEM tutorials repository](https://github.com/py4dstem/py4DSTEM_tutorials) in the `/notebooks` directory.\nThese sample files are provided as Jupyter notebooks.\nLinks to the data used in each notebook are provided in the intro cell of each notebook.\n\n\n\n\n# More information\n<a id='Contributing'></a>\n\n## Contributing Guide \nWe are grateful for your interest in contributing to py4DSTEM. There are many ways to contribute to py4DSTEM, including Reporting bugs, Submitting feature requests, Improving documentation and Developing new code\n\nFor more information checkout our [Contributors Guide](CONTRIBUTORS.md)\n\n\n## Documentation\n\nOur documentation pages are [available here](https://py4dstem.readthedocs.io/en/latest/index.html).\n\n\n\n## Scientific papers which use **py4DSTEM**\n\nSee a list [here](docs/papers.md).\n\n\n\n\n# Acknowledgements\n\nIf you use py4DSTEM for a scientific study, please cite [our open access py4DSTEM publication in Microscopy and Microanalysis](https://doi.org/10.1017/S1431927621000477). You are also free to use the py4DSTEM [logo in PDF format](https://raw.githubusercontent.com/py4dstem/py4DSTEM/dev/images/py4DSTEM_logo_54.pdf) or [logo in PNG format](https://raw.githubusercontent.com/py4dstem/py4DSTEM/dev/images/py4DSTEM_logo_54_export.png) for presentations or posters.\n\n\n[![TRI logo](https://raw.githubusercontent.com/py4dstem/py4DSTEM/dev/images/toyota_research_institute.png)](https://www.tri.global/)\n\n\nThe developers gratefully acknowledge the financial support of the Toyota Research Institute for the research and development time which made this project possible.\n\n[![DOE logo](https://raw.githubusercontent.com/py4dstem/py4DSTEM/dev/images/DOE_logo.png)](https://www.energy.gov/science/bes/basic-energy-sciences/)\n\nAdditional funding has been provided by the US Department of Energy, Office of Science, Basic Energy Sciences.\n\n\n\n# License\n\nGNU GPLv3\n\n**py4DSTEM** is open source software distributed under a GPLv3 license.\nIt is free to use, alter, or build on, provided that any work derived from **py4DSTEM** is also kept free and open under a GPLv3 license.\n\n",
"bugtrack_url": null,
"license": "GNU GPLv3",
"summary": "A lite version of the open source python package, py4DSTEM.",
"version": "0.14.16",
"project_urls": {
"Homepage": "https://github.com/py4dstem/py4DSTEM-lite/"
},
"split_keywords": [
"stem",
" 4dstem",
" lite"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "cd7572d451e5fff204fbd342552437c8f6f8912cfe5211b9ee213d065ecf247a",
"md5": "684c2bcdfcf9f94e46adca3822819e26",
"sha256": "234d356d6f68270228452f5a40744579ed6835c109e4631dc48e1c8cb676778c"
},
"downloads": -1,
"filename": "py4DSTEM_lite-0.14.16-py3-none-any.whl",
"has_sig": false,
"md5_digest": "684c2bcdfcf9f94e46adca3822819e26",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.10",
"size": 693639,
"upload_time": "2024-07-28T03:04:20",
"upload_time_iso_8601": "2024-07-28T03:04:20.321479Z",
"url": "https://files.pythonhosted.org/packages/cd/75/72d451e5fff204fbd342552437c8f6f8912cfe5211b9ee213d065ecf247a/py4DSTEM_lite-0.14.16-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "b044166a68a2253d6d31c92c77556e590d49921c5a8e1596b9eafd9c7e1184ff",
"md5": "f4b160ffa863db150b3220883b1229a9",
"sha256": "fa5b7a2cf5b3196d4fd0c6a24de980d04e4df765b76d0a89c03e308ee1308b76"
},
"downloads": -1,
"filename": "py4dstem_lite-0.14.16.tar.gz",
"has_sig": false,
"md5_digest": "f4b160ffa863db150b3220883b1229a9",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.10",
"size": 608828,
"upload_time": "2024-07-28T03:04:22",
"upload_time_iso_8601": "2024-07-28T03:04:22.779991Z",
"url": "https://files.pythonhosted.org/packages/b0/44/166a68a2253d6d31c92c77556e590d49921c5a8e1596b9eafd9c7e1184ff/py4dstem_lite-0.14.16.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-07-28 03:04:22",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "py4dstem",
"github_project": "py4DSTEM-lite",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "py4dstem-lite"
}