Skip to main content

Calibration and mapping between stage and camera coordinates in a microscope

Project description

Camera Stage Mapping calibration

This Python module allows you to calibrate a microscope's stage against the camera. By moving the sample a known number of steps, and tracking how far the image translates, it is possible to recover the number of steps per pixel. This code goes a step further, and recovers a 2x2 affine transformation matrix, so it will cope with rotation, flipping, and non-uniform scaling of the X and Y axes. The calibration routines are designed to be relatively robust and minimally parameterised, so they start by determining a sensible step size automatically.

As part of the calibration, you can use either FFT-based or directly calculated cross correlation to track motion of the sample. This code is probably useful on its own, and is found in the fft_image_tracking and correlation_image_tracking submodules. The underlying mechanism of tracking stage and camera coordinates simultaneously is handled by the CameraStageTracker class, in camera_stage_tracker. The main calibration function is camera_stage_calibration_1d.calibrate_backlash_1d. For 2D calibration, I recommend running this once for X and once for Y, then using camera_stage_calibration_1d.image_to_stage_displacement_from_1d to combine the two calibrations. This is more robust than the 2D grid calibration method.

Hardware interface

Rather than tie these functions to a specific class interface, as found in many lab control frameworks, the calibration routines simply require functions to be passed in as arguments. This is done for maximum flexibility, and to impose the fewest necessary constraints on the hardware we are controlling. In the future, we may define a class interface to use, and would welcome input on how to do this without forcing a particular taxonomy of laboratory instruments upon everyone using the library.

Installing

pip install camera-stage-mapping

This package is published on PyPI and can be installed using pip. It's managed using poetry and can be installed by cloning the repository and running poetry install. For details of how to set up a development environment, please see CONTRIBUTING.

Documentation

The functions all have fairly extensive docstrings and the module is documented on readthedocs.

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

camera_stage_mapping-0.1.10.tar.gz (36.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

camera_stage_mapping-0.1.10-py3-none-any.whl (40.4 kB view details)

Uploaded Python 3

File details

Details for the file camera_stage_mapping-0.1.10.tar.gz.

File metadata

  • Download URL: camera_stage_mapping-0.1.10.tar.gz
  • Upload date:
  • Size: 36.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.12

File hashes

Hashes for camera_stage_mapping-0.1.10.tar.gz
Algorithm Hash digest
SHA256 5f58c7a21993ba187dcc7e5ba81709f237a34f020f2428d575729cdea8155ef9
MD5 f53617cd74e029922e220dba3021e0bc
BLAKE2b-256 685dba4e7dc34589ecfb49a292abc098a8be71a28a428e78b1355b86f66ddb2e

See more details on using hashes here.

File details

Details for the file camera_stage_mapping-0.1.10-py3-none-any.whl.

File metadata

File hashes

Hashes for camera_stage_mapping-0.1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 e5eae6146dcce1117fa40b617f4bf1122a9091cabb7750ae0ee7b6ebb7c79d2f
MD5 16f2745707c0515d817918f111d8697f
BLAKE2b-256 8e19cb2cb10629ceb2826dbbeee2057a10bfa0e0425263db3acdfc9ef3f7ab1d

See more details on using hashes here.

Supported by

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