Skip to main content

OMIO: Open Microscopy Image I/O

Project description

OMIO – Open Microscopy Image I/O

GitHub Release PyPI version GPLv3 License Tests GitHub last commit codecov GitHub Issues Open GitHub Issues Closed GitHub Issues or Pull Requests Documentation Status GitHub code size in bytes PyPI - Downloads

OMIO (Open Microscopy Image I/O) is a policy-driven Python library for reading, organizing, merging, visualizing, and exporting multidimensional microscopy image data under explicit OME-compliant axis and metadata semantics.

OMIO is designed as an infrastructure layer between heterogeneous microscopy file formats and downstream analysis or visualization workflows. It provides a unified I/O interface that enforces consistent axis ordering, metadata normalization, and memory-aware data handling across NumPy, Zarr, Dask, napari, and OME-TIFF.

NOTE 1: OMIO is currently under active development. The API and feature set may change in future releases.

NOTE 2: A documentation website is being prepared and will be made available soon.

What is OMIO good for your microscopy data?

Modern microscopy workflows face a recurring and largely unsolved problem: While image acquisition formats are diverse, downstream analysis and visualization pipelines implicitly assume consistent data semantics.

In practice, this leads to:

  • ambiguous or undocumented axis conventions,
  • silent shape mismatches across files,
  • inconsistent or partially missing physical metadata,
  • ad-hoc merge scripts that fail for large data,
  • format-specific reader logic leaking into analysis code,
  • and brittle visualization workflows for large volumetric or time-series data.

OME-TIFF and OME-XML define a powerful metadata standard, but most real-world microscopy data do not arrive in a clean, OME-conform form. Instead, users are left to bridge the gap manually, often repeatedly and inconsistently.

OMIO addresses this gap by acting as a semantic I/O layer rather than a format converter.

It provides:

  • explicit and enforced axis semantics,
  • structured metadata normalization,
  • controlled merge and padding policies,
  • memory-efficient handling of large datasets,
  • and a consistent interface for both batch conversion and interactive visualization.

Installation

OMIO can be installed via pip from the Python Package Index (PyPI):

conda create -n omio-env python=3.12 -y
conda activate omio-env
pip install omio-microscopy

Design principles

OMIO is built around the following principles:

Explicit axis semantics

All image data are handled internally using explicit axis strings (default: TZCYX).
Axis order is never implicit and never guessed silently.

OME-aware, but not OME-exclusive

OME semantics are used as the internal reference model, but OMIO is not restricted to OME-TIFF input or output.
OME-TIFF is treated as one well-defined sink among several possible representations.

Policy-driven behavior

Operations such as merging, padding, and metadata reconciliation are governed by explicit, documented policies rather than hidden heuristics.

Memory-aware by construction

Large datasets can be processed via Zarr and Dask without loading entire volumes into RAM.
Chunk-aligned copying and cache-based workflows are first-class concepts and allow both memory-mapped and out-of-core processing as well as memory-efficient visualization in napari.

Separation of concerns

Reading, merging, visualization, and writing are distinct stages that can be composed but are not entangled.

Core features

Unified image reading

OMIO provides a single entry point for reading microscopy image data. At the moment, supported formats include:

  • TIFF / OME-TIFF
  • LSM
  • CZI
  • Thorlabs RAW

All readers return:

  • an image object (NumPy array or Zarr array),
  • a normalized metadata dictionary,
  • and an explicit axis specification.

Metadata normalization and enforcement

OMIO normalizes metadata into a consistent dictionary that includes:

  • axis string (axes)
  • full 5D shape (TZCYX)
  • physical pixel sizes (PhysicalSizeX/Y/Z)
  • temporal resolution (TimeIncrement)
  • units
  • structured provenance stored via OME MapAnnotations

Non-OME metadata are preserved and stored explicitly inside annotations rather than discarded.

Controlled merging along semantic axes

OMIO supports concatenation and merging along semantic axes:

  • Time (T)
  • Depth (Z)
  • Channel (C)

Merge behavior is configurable:

  • strict compatibility checks, or
  • zero-padding of non-merge axes to maximal extents.

All merges propagate provenance information into metadata annotations.

Image compression

OMIO supports reading and writing compressed image data. When writing OME-TIFF files, users can choose a zlib compression level between 0 (no compression) and 9 (maximum compression). I.e, OMIO can be used to shrink large uncompressed TIFF files into compressed OME-TIFF files, which facilitates significant disk space savings, faster I/O performance, and better transfer speeds.

Folder-based and BIDS-like workflows

OMIO supports structured folder traversal for large projects, including:

  • reading all files in a folder,
  • merging multiple files within a folder,
  • merging structured "folder stacks" (e.g. repeated acquisitions),
  • batch processing of BIDS-like directory hierarchies.

These workflows are designed to reflect how microscopy data are actually organized, not how idealized examples look.

OME-TIFF export

OMIO can write OME-TIFF files with:

  • correct axis order,
  • correct physical and temporal metadata,
  • optional BigTIFF handling for large datasets,
  • embedded MapAnnotations for provenance and custom metadata.

Filename handling is collision-safe and metadata-aware.

Napari integration

OMIO provides direct integration with napari, supporting:

  • NumPy-based visualization for small data,
  • Zarr-backed visualization for large data,
  • optional Dask-based slicing and caching,
  • correct spatial scaling and channel handling.

Axis squeezing and cache generation are performed explicitly and transparently.

Expected project structure (BIDS-like)

OMIO supports batch processing of projects organized in a BIDS-like manner.
An abstract example is shown below:

project_name/
├─ sub-01/
│  ├─ exp_TP001/
│    ├─ image.tif
│  │
│  ├─ exp_TP002/
│    ├─ TAG_01/
│      ├─ image1.czi
│    ├─ TAG_02/
│      ├─ image2.czi
│  │
│  ├─ exp_TP003/
│    ├─ image1.tif
│    ├─ image2.tif
│
├─ sub-02/
│  ├─ exp_TP001/
│    ├─ image.tif

OMIO detects subjects, experiments, and optional tag folders via user-defined matching rules and applies consistent read and merge policies across the project.

Typical usage patterns

Read a single file

img, metadata = omio.imread("image.czi")

Read all images in a folder

images, metadatas = omio.imread("experiment_folder", return_list=True)

Merge multiple files along time

merged_img, merged_md = omio.imread(
    "experiment_folder",
    merge_multiple_files_in_folder=True,
    merge_along_axis="T")

Convert to OME-TIFF

omio.convert_to_ometiff("experiment_folder")

Batch conversion over a BIDS-like project

omio.convert_bids_batch_to_ometiff(
    fname="project_root",
    sub="sub-",
    exp="TP",
    tagfolder="TAG_",
    merge_tagfolders=True)

Scope and non-goals

OMIO intentionally does not:

  • perform image processing or analysis,
  • infer or guess missing metadata silently,
  • replace domain-specific analysis pipelines.

Its purpose is to provide a reliable, explicit, and reproducible I/O layer on which such pipelines can be built.

License

OMIO is released under the GNU General Public License v3.0 (GPLv3). Please refer to the LICENSE file for details.

Citation

If you use OMIO in scientific work, please cite it appropriately. (CITATION.cff will be provided.)

Acknowledgments

OMIO was developed to support real-world microscopy workflows where data heterogeneity, scale, and metadata inconsistencies are the norm rather than the exception.

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

omio_microscopy-0.1.2.tar.gz (622.0 kB view details)

Uploaded Source

Built Distribution

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

omio_microscopy-0.1.2-py3-none-any.whl (91.3 kB view details)

Uploaded Python 3

File details

Details for the file omio_microscopy-0.1.2.tar.gz.

File metadata

  • Download URL: omio_microscopy-0.1.2.tar.gz
  • Upload date:
  • Size: 622.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.32.5

File hashes

Hashes for omio_microscopy-0.1.2.tar.gz
Algorithm Hash digest
SHA256 7c58043a501725c6605f898592cbb8b8a549c155fd1aea9e03936c5cbb6d89c7
MD5 d26ea38f484993ac40fc748937d550eb
BLAKE2b-256 b8fc3ea16e7cd5d67891e70fe5a1c13f9f496d0f228e4e7c204c37c6ad3550cd

See more details on using hashes here.

File details

Details for the file omio_microscopy-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for omio_microscopy-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 5b80db93aa73f1dbfb5d289448d26c54b1c9f143fb40ed7f809eb07afca03911
MD5 909ebc8b897900e6ac30684443beb795
BLAKE2b-256 f9dff109b26509230c1c35f28f89417581f2b9f9acb325d762d57db1c19841d9

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