A project to read microscopy files.
Project description
NImA-io
This is a helper library designed for reading microscopy data supported by Bioformats using Python. The package also includes a command-line interface for assessing differences between images.
Features / Description
Despite the comprehensive python-bioformats package, Bioformats reading in Python is not flawless. To assess correct reading and performance, I gathered a set of test input files from real working data and established various approaches for reading them:
- Utilizing the external "showinf" and parsing the generated XML metadata.
- Employing out-of-the-box python-bioformats.
- Leveraging bioformats through the Java API.
- Combining python-bioformats with Java for metadata (Download link: bio-formats 5.9.2).
At present, Solution No. 4 appears to be the most effective.
It's important to note that FEI files are not 100% OME compliant, and understanding OME metadata can be challenging. For instance, metadata.getXXX is sometimes equivalent to metadata.getRoot().getImage(i).getPixels().getPlane(index).
The use of parametrized tests enhances clarity and consistency. The approach of returning a wrapper to a Bioformats reader enables memory-mapped (a la memmap) operations.
Notebooks are included in the documentation tutorials to aid development and illustrate usage. Although there was an initial exploration of the TileStitch Java class, the decision was made to implement TileStitcher in Python.
Future improvements can be implemented in the code, particularly for the multichannel OME standard example, which currently lacks obj or resolutionX metadata. Additionally, support for various instrument, experiment, or plate metadata can be considered in future updates.
Installation
System requirements:
- maven
From PyPI
Using pip:
pip install nima_io
Recommended: Using pipx
For isolated installation (recommended):
pipx install nima_io
Shell Completion
Bash
_IMGDIFF_COMPLETE=bash_source imgdiff > ~/.local/bin/imgdiff-complete.bash
source ~/.local/bin/imgdiff-complete.bash
# Add to your ~/.bashrc to make it permanent:
echo 'source ~/.local/bin/ingdiff-complete.bash' >> ~/.bashrc
Fish:
_IMGDIFF_COMPLETE=fish_source imgdiff | source
# Add to fish config to make it permanent:
_IMGDIFF_COMPLETE=fish_source imgdiff > ~/.config/fish/completions/imgdiff.fish
Usage
Docs: https://{{ cookiecutter.project_slug }}.readthedocs.io/
CLI
imgdiff --help
Python
from nima_io import read
Development
Requires Python uv.
With uv:
# one-time
pre-commit install
# dev tools and deps
uv sync --group dev
# lint/test
uv run ruff check . (or: make lint)
uv run pytest -q (or: make test)
Update and initialize submodules
git submodule update --init --recursive
Navigate to the tests/data/ directory:
cd tests/data/
git co master
Configure Git Annex for SSH caching:
git config annex.sshcaching true
Pull the necessary files using Git Annex:
git annex pull
These commands set up the development environment and fetch the required data for testing.
Modify tests/data.filenames.txt and tests/data.filenames.md5 as needed and run:
cd tests
./data.filenames.sh
We use Renovate to keep dependencies current.
Dependency updates (Renovate)
Enable Renovate:
- Install the GitHub App: https://github.com/apps/renovate (Settings → Integrations → GitHub Apps → Configure → select this repo/org).
- This repo includes a
renovate.jsonpolicy. Renovate will open a “Dependency Dashboard” issue and PRs accordingly.
Notes:
- Commit style:
build(deps): bump <dep> from <old> to <new> - Pre-commit hooks are grouped and labeled; Python version bumps in
pyproject.tomlare disabled by policy.
Migrating from Dependabot:
- You may keep “Dependabot alerts” ON for vulnerability visibility, but disable Dependabot security PRs.
Template updates (Cruft)
This project is linked to its Cookiecutter template with Cruft.
- Check for updates:
cruft check - Apply updates:
cruft update -y(resolve conflicts, then commit)
CI runs a weekly job to open a PR when template updates are available.
First-time setup if you didn’t generate with Cruft:
pipx install cruft # or: pip install --user cruft
cruft link --checkout main https://github.com/darosio/cookiecutter-python.git
Notes:
- The CI workflow skips if
.cruft.jsonis absent. - If you maintain a stable template branch (e.g.,
v1), link with--checkout v1. You can also update within that line usingcruft update -y --checkout v1.
License
We use a shared copyright model that enables all contributors to maintain the copyright on their contributions.
All code is licensed under the terms of the revised BSD license.
Contributing
If you are interested in contributing to the project, please read our contributing and development environment guides, which outline the guidelines and conventions that we follow for contributing code, documentation, and other resources.
Project details
Release history Release notifications | RSS feed
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 nima_io-0.4.2.tar.gz.
File metadata
- Download URL: nima_io-0.4.2.tar.gz
- Upload date:
- Size: 334.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ad712ef689fa8173427cc44a1510cf72f608ac757c8285b3a0ee21cf1e3094fb
|
|
| MD5 |
f72b11e09dc69e557d93fece580431e3
|
|
| BLAKE2b-256 |
05e554849e1c37be6c205478edcec396c6615dd05ede18e32af758a042fd44f5
|
File details
Details for the file nima_io-0.4.2-py3-none-any.whl.
File metadata
- Download URL: nima_io-0.4.2-py3-none-any.whl
- Upload date:
- Size: 12.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a291c4ea16f1ed04281d3aaa20027ddc4a8674e258b3f86726f374f35f0c9b3e
|
|
| MD5 |
a094aae82172dfcf6a5acc254e562309
|
|
| BLAKE2b-256 |
686aeb015325498142ad36e652eae7d6df00d0de105be0ef867d7685c7090843
|