Skip to main content

OMIO: Open Microscopy Image I/O

Project description

OMIO: A Python library for unified I/O of multidimensional microscopy images

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 PyPI Total Downloads Zenodo Archive

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

OMIO's core functions are:

  • imread(): read images from files or folders,
  • imconvert(): convert images to OME-TIFF,
  • bids_batch_convert(): batch-convert BIDS-like projects,
  • open_in_napari(): visualize images in napari,
  • create_empty_metadata(): create empty metadata templates,
  • create_empty_image(): create empty image arrays, and
  • update_metadata_from_image(): update metadata based on image properties.

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.imconvert("experiment_folder")

Batch conversion over a BIDS-like project

omio.bids_batch_convert(
    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.

Requests for new file formats and reader extensions

OMIO is designed to grow and evolve based on user needs and real-world microscopy data. By intention, we will add support for additional file formats or format variants over time, bases on user requests and contributions.

Requests for new readers or reader extensions are therefore very welcome and should be submitted via the GitHub issue tracker. To be actionable, such requests must include access to a representative example file, as OMIO intentionally avoids speculative or heuristic-based format inference.

Detailed guidelines for requesting new format support, including what information to provide and how example files can be shared, are described in *CONTRIBUTING.md.

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 as:

Fabrizio Musacchio. (2025). OMIO: A Python library for unified I/O of multidimensional microscopy images. Zenodo. https://doi.org/10.5281/zenodo.18030883

On Zenodo, you can select other citation formats as needed as well as a DOI for dedicated OMIO software versions.

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.4.tar.gz (623.5 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.4-py3-none-any.whl (91.8 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for omio_microscopy-0.1.4.tar.gz
Algorithm Hash digest
SHA256 cc124efa43cfbd9670300ed93312d32ffaacbaef66e85466eabd9a7297324d93
MD5 84dec7a9139c738a2b4cb626f4d5723e
BLAKE2b-256 bd34c222c8d9b8bc63d7e6d9e615fdb62b443136adca285e36bde4a5be6f9ba9

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for omio_microscopy-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 15f4342b984ace66f6f781507c55e349ec93216554d4f483098451dd38ee4af3
MD5 1b7e0db5e3344e2fb4691824384d05c7
BLAKE2b-256 7ab183a3198d5b2e0ca99d8530db23bb712606119ac5c65f9a57138378224c19

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