This package is a python interface for laboratory adaptive optics systems, with a focus on the calibration of deformable mirrors (DMs) and the acquisition of wavefront data using interferometers.
Project description
OptiCalib : adaptive OPTics package for deformable mirrors CALibration
Adaptive Optics Group, INAF - Osservatorio Astrofisico di Arcetri
OptiCalib is a python package which first goal is to make easy deformable mirror's calibration in the laboratory (and not only).
It was born as a general extrapolation of the software built for the control and calibration of the ELT @ M4 adaptive mirror and it's calibration tower, OTT (Optical Test Tower).
Description
The OPTICALIB package serves two main purposes:
-
Making connection to the hardware (interferometers, DMs, ...) easy;
-
Providing routines for Deformable Mirrors calibrations.
The latests, stable, version can be installed from pypi:
pip install opticalib
The in-development version can be installed directly from this repository:
pip install git+"https://github.com/pietroferraiuolo/labott.git"
but do expect some bugs!
Upon installation, the software will create an entry point script called calpy, which is usefull to set up a specific experiment's environment. Let's say we have an optical bench composed of an interferometer 4D PhaseCam6110 and an Alpao Deformable mirror, say DM820. We can create the experiment's environment just like:
calpy -f ~/alpao_experiment --create
This will create, in the ~/alpao_experiment folder, the package's data folder tree, together with a configuration file in the SysConfig folder. The configuration file, documented here, is where all devices must be specified.
Once done with the configuration, we can then start using out instruments:
calpy -f ~/alpao_experiment
# The `calpy` function will automatically import opticalib (with `opt` as alias), as well as the `opticalib.dmutils` as dmutils
interf = opt.PhaseCam(6110) # set in the configuration file
dm = opt.AlpaoDm(820) # set in the configuration file
# Having the bench set up and the configuration file set, we can acquire an Influence Function by just doing
tn = dmutils.iff_module.iffDataAcquisition(dm, interf) # Optional paramenters are `modesList, modesAmplitude, template`, which if not specified are read from the configuration file
Documentation
For the API references, check here (work in progress...), while for the configuration file documentation check here
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file opticalib-1.1.0.tar.gz.
File metadata
- Download URL: opticalib-1.1.0.tar.gz
- Upload date:
- Size: 338.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bdfdb8e2da76347883a7b8f084b71e47bed009556c35f52aaa82e564e0fe12ae
|
|
| MD5 |
5f5c3f8b35dee2492c888dd40665a788
|
|
| BLAKE2b-256 |
1a866e320f19f6f82d749e2cea273c5c09c4160881c66b172cf07f0517f0e0ff
|
File details
Details for the file opticalib-1.1.0-py3-none-any.whl.
File metadata
- Download URL: opticalib-1.1.0-py3-none-any.whl
- Upload date:
- Size: 361.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
370efad1742af3f3f525401bb6c93e62f7d6b9d754e9d4068882689d5d64b847
|
|
| MD5 |
8f6b1ef78f4364b603a346646c8cdb74
|
|
| BLAKE2b-256 |
4684e6b3abe4ef38a2512f74deaf1bd3ca3b96ae69e717922f78c460147ba621
|