A BioIO reader plugin for reading nd2 (Nikon microscope) files using nd2
See the full documentation on our GitHub pages site - the generic use and installation instructions there will work for this package.
Information about the base reader this package relies on can be found in the bioio-base repository here
Stable Release: pip install bioio-nd2
Development Head: pip install git+https://github.com/bioio-devs/bioio-nd2.git
Install bioio-nd2 alongside bioio:
pip install bioio bioio-nd2
This example shows a simple use case for just accessing the pixel data of the image
by explicitly passing this Reader into the BioImage. Passing the Reader into
the BioImage instance is optional as bioio will automatically detect installed
plug-ins and auto-select the most recently installed plug-in that supports the file
passed in.
from bioio import BioImage
import bioio_nd2
img = BioImage("my_file.nd2", reader=bioio_nd2.Reader)
img.databioio-nd2 includes support for mapping ND2 XY stage positions to
multi-well plate positions (e.g. A1, B3, H12). This is primarily
intended for experiments acquired using Nikon’s XYPosLoop functionality
on multi-well plates.
⚠️ If the ND2 file does not contain XY position metadata (XYPosLoop), no well mapping is performed androw/columnwill beNone.
The ND2 reader assumes a standard 96-well plate geometry (See Plates for specification) and assigns each scene to the nearest well center. Users may define their own plate geometry and pass it to the reader to override these defaults.
from bioio import BioImage
import bioio_nd2
img = BioImage("my_file.nd2", reader=bioio_nd2.Reader)
img.set_scene(0)
img.reader.row # e.g. "B"
img.reader.column # e.g. "3"Users may define their own plate geometry and pass it to the reader.
from bioio import BioImage
import bioio_nd2
from bioio_nd2.plates import Plate, WellAssignmentMode
custom_plate = Plate(
name="custom_96",
rows=list("ABCDEFGH")[::-1],
cols=[str(i) for i in range(1, 13)],
plate_width_mm=126.6,
plate_height_mm=85.7,
a1_offset_mm=(14.3, 11.36),
well_spacing_um=9000.0,
well_radius_um=6210.0 / 2,
assignment_mode=WellAssignmentMode.CLOSEST,
)
img = BioImage(
"my_file.nd2",
reader=bioio_nd2.Reader,
plate=custom_plate,
)The plate definition includes a well assignment mode that controls how strictly stage positions must correspond to a physical well.
Available modes:
| Mode | Behavior |
|---|---|
CLOSEST |
Always assign the nearest well (most permissive) |
WITHIN_WELL |
Assign only if position falls within the well radius |
HALF_SPACING |
Assign only if within half the inter-well spacing |
In strict modes, scenes that fall outside the allowed region will have
row / column set to None.
Click here to view all open issues in bioio-devs organization at once or check this repository's issue tab.
See CONTRIBUTING.md for information related to developing the code.