Skip to main content

An app for controlling SLMs

Project description

SLM controller

SLM controller is a python based GUI software for controlling the phase pattern of an SLM (Spatial Light Modulator).

The software takes care of rendering the hologram on top of any graphical interface of the operative system used. For now it has been tested on windows 10/11, ubuntu 22.04(previous release version) and MacOS.

The software offers various types of static holograms that are normally used in the field of optical tweezers.

From the main window it is possible to add new optical elements and toggle the rendering of the hologram.

Main window

Before doing that however the user should set-up the parameters of his SLM and system. In the settings windows it is possible to set the following parameters :

  • SLM ID : This is an identifier for that particular SLM. In future I plan to provide support for multiple SLMs. Under it the user can select on which monitor the SLM pattern should be rendered. 0 = main monitor. Here the typical selection should be 1 (first external monitor, SLM)

  • Laser parameters : The wavelength of the laser used, this is used for calculating the correct lens pattern.

  • SLM resolution : This is the resolution (number of pixels) of the SLM. Beware that it can be different than the screen resolution seen by the operative system. Many SLMs use standard resolution values (eg. Full-HD) even if their effective number of pixels is different than (1920x1080).

  • SLM pixel pitch : The pixel size of the SLM

  • SLM phase correction : This is the correction value for a 2π phase modulation. The value is nomally provided by the manufacturing company. Typically 2π --> 255 but at different wavelengths this value can vary

  • Pattern window size : This should be the screen resolution used for the SLM (eg. Full-HD) not the number of pixels of the SLM (although the two might match). The unused (SLM resolution - window size) pixels will be rendered as black.

  • Network : IP and port used for remote control of the optimisation algorithm. The algorithm is based on the following work. Remote control is handled using Flask. The interface misuses the RESTful approach in order to simplify the code and improve usability (e.g. set methods are based on HTTP GET). The following endpoints are available:

    • /optimiser/start : starts the algorithm (if already running, triggers a next step)
    • /optimiser/nextStep : triggers the next step of the algorithm (once scaned till the end of the phase pattern, this will return phase = null)
    • /optimiser/refzone : returns the current reference zone
    • /optimiser/refzone/ : sets the reference zone to
    • /optimiser/probzone : returns the current probe zone
    • /optimiser/probzone/ : sets the probe zone to
    • /optimiser/phase : returns the current phase
    • /optimiser/phase/ : sets the phase to
    • /optimiser/phaseStep/ : sets the phase step to
    • /optimiser/IDsList : returns the list of IDs of the active optical elements
    • /optimiser/phasePattern : returns the optimiser phase pattern (as image)
    • /optimiser/phasePatternData : returns the optimiser phase pattern (as list)
  • Other endpoints are available globally

    • /phasePattern : returns the phase pattern (as image) currently being rendered on the SLM

Program settings

## Optical elements It is possible to add various optical elements through the software. Each optical element will have a control tab where it can be activated/deactivated. The final full phase pattern rendered on the SLM will be the sum of all the active optical elements at the moment the user press "Show hologram/Update"

At the center of the optical element tab it is possible to see a small preview of the pattern associated to that element.

Some optical elements have a "live update" feature. The live update permits to change the parameters of the optical element and automatically re-render the whole SLM pattern each time a value is changed. Beware that this works fine on good PCs but can require quite some time on old PCs or when many optical elements are active at once.

Fresnel lens pattern

It is possible to add a virtual lens on the SLM by generating a fresnel lens pattern (fresnel zone plate). This can be done by adding a new "lens" optical element.

Fresnel lens tab

In the tab it is possible to control the focus of the lens and activate/deactivate it.

Grating

This adds a virtual diffractive grating. It is possible to control the lines/mm of the grating and its orientation. The number of lines per pixel will depend on the size of each SLM pixel.

Grating tab

Flatness correction

This controls the flatness correction pattern typically used to correct for flatness imperfections of the SLM. The SLM manufacturing company normally provides a file for each wavelength supported by the SLM. This can be added to the total pattern by selecting the proper flatness correction for the used wavelength. The flatness correction is normally an image and its size should match the SLM size.

Flatness correction tab

Displayed pattern

This is a grayscale image [0,255] of the sum of all optical elements that have been activated. The rendered pattern is calculated as following:

Wrapped pattern = mod(Corrected pattern,256)

Displayed pattern = Wrapped pattern * SLM phase correction /255

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

SLMcontroller-1.0.20.tar.gz (87.9 kB view hashes)

Uploaded Source

Built Distribution

SLMcontroller-1.0.20-py3-none-any.whl (77.3 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page