We are writing a paper for Journal of Open Source Software (JOSS)! Read the manuscript here: https://drive.proton.me/urls/T92N7SMT5M#nBvZvODDgZCc
pySLM2
is a Python package designed for using spatial light modulators (SLMs) in holographic beam shaping. It includes modules for hologram generation, simulation, and hardware control, making it a comprehensive toolkit for high-quality optical control.
The goal of pySLM2 is to provide a tool box for for engineering high-quality optical controls, which are essential for various scientific and engineering applications. These applications include atom trapping, addressing individual quantum objects, preparing exotic quantum states, and multi-beam laser machining. pySLM2
was originally developed for and is actively used in the trapped ion quantum information processing research at the Quantum Information with Trapped Ions Lab at the University of Waterloo.
- API Docs: https://pyslm2.pages.dev/
Instructions to build documentation locally can be found in docs/README.md
.
pySLM2 supports Python 3.9+.
The dependencies of pySLM2
in includes: numpy
, scipy
, matplotlib
, and tensorflow
.
If you prefer the development version from GitHub, download it here, cd
to the pySLM2 directory, and use:
pip install .
Or, if you wish to edit the pySLM2 source code without re-installing each time
pip install -e .
pySLM2
primarily relies on tensorflow
for most of its numerical computations. For machines with compatible hardware, tensorflow
can seamlessly utilize GPU acceleration to enhance performance, provided it is installed correctly.
The exact package dependencies vary depending on each system configuration and the GPU card. For details about machine compatibility and correct version of tensorflow, please refer to the Tensorflow's website, which provides installation guide for different operating systems. Another authors' recommended tensorflow
installation guide can also be found in this website which provides thorough information about package dependecies such as cuda
and cudnn
versions.
As a reference, in our setup with Windows 10 Build 17763 and an NVIDIA Quadro M4000 GPU, we executed the following commands to install tensorflow
-related packages in a Conda environment with python=3.7
.
conda install -c conda-forge cudnn==7.6.5
conda install -c conda-forge cudatoolkit==10.1.243
pip install tensorflow==2.1
pip install tensorflow-gpu==2.1
Several runtime benchmarking scripts for iterative hologram generations algorithms are included in a separate folder pySLM2/runtime_benchmark
. Instructions for running those tests can be found in pySLM2/runtime_benchmark/README.md
.
Our machine has Windows 10 Build 17763 with Intel Core i9-9900K CPU and an NVidia Quadro M4000 GPU. Key package dependencies are:
python
: 3.7.1tensorflow
: 2.1.0tensorflow-gpu
: 2.1.0cudnn
: 7.6.5cudatookkit
: 10.1.243
From our testing, we observed:
Case 1 (gs) | Case 2 (mraf) | Case 3 (ifta) | |
---|---|---|---|
CPU |
|
|
|
GPU |
|
|
|
These findings show that the iterative algorithms can be greatly accelerated by GPU usage.
pySLM2.util
includes provides an universal interface for interacting with different SLM controllers from different vendors.
pySLM2.util
itself doesn't implement the communication protocol. Instead, it relies on different libraries and wraps them with a universal interface.
The DMDs from Vialux are communicated with the ALP library and a python binding, ALP4lib.
- To install the ALP library, visit the vendors website: https://vialux.de/en/download.html
- The python binding, ALP4lib, can be installed from PyPi:
pip install ALP4lib
The DMD from Visitech are communicates with UDP, and therefore no driver is needed to be installed. pySLM.util
relies on the Luxbeam library which can be installed from PyPi:
pip install Luxbeam
For LCoS-SLMs, most models can be directly controlled via standard monitor connections. To display holograms, one might consider using slmPy. Since pySLM2 calculates hologram values in radians, one will need a conversion table to determine the corresponding grayscale values for output. This conversion typically varies based on the light wavelength and the specific model of the LCoS-SLM.
Since not all the graphic cards are optimized for double-precision computation, the default precision of pySLM2 is set to single-precision. If you wish to use double-precision, you can configure the backend right after you import the package :
pySLM2.BACKEND.dtype = pySLM2.BACKEND.TENSOR_64BITS
In practice, the single-precision is sufficient for most of the applications. However, if you are suspecting the precision is not enough, you can change the precision to double-precision and see if the results are different.
If you used pySLM2 in your research, we'd like to hear from you!
-
Shih, Chung-You, et al. "Reprogrammable and high-precision holographic optical addressing of trapped ions for scalable quantum control." npj Quantum Information 7.1 (2021): 57. https://doi.org/10.1038/s41534-021-00396-0
-
Motlakunta, S., Kotibhaskar, N., Shih, CY. et al. Preserving a qubit during state-destroying operations on an adjacent qubit at a few micrometers distance. Nat Commun 15, 6575 (2024). https://doi.org/10.1038/s41467-024-50864-2