Plugin for exporting images in zarr format.
Project description
OMERO CLI Zarr plugin
This OMERO command-line plugin allows you to import and export Images and ROIs from OME-Zarr format into OMERO and vice versa.
Import
NB: This feature currently works only with OME-Zarr files hosted on public object stores OR a local filesystem accessible to the OMERO server.
The import process is similar to an “in-place” import; It does not move the data into OMERO. Instead the data is accessed via the omero-zarr-pixel-buffer, which must be installed on the OMERO server.
Images are created in OMERO and the link to the OME-Zarr data is stored in the ExternalInfo of the Image. Images are created in one of two ways:
If the OME-Zarr data is in the bioformats2raw layout, which includes an OME/METADATA.ome.xml file, then this file is copied to the the server and imported to create a Fileset and one or more Images. This preserves all of the OME metadata in the xml file.
Otherwise, Images are created via the OMERO API, using the metadata in the OME-Zarr files.
Export
This feature supports export of any regular Images and Plates from OMERO into the OME-Zarr format, according to the spec at https://ngff.openmicroscopy.org/0.4/index.html as well as Masks and Polygons on the Images.
Images are exported as nD arrays of shape, up to (t, c, z, y, x). Plates are a hierarchy of plate/row/column/field(image). Masks in OMERO are 2D bitmasks which can exist on multiple planes of an Image. Polygons are 2D shapes defined by a set of vertices. In both cases, they are exported as OME-Zarr labels, with Polygons being converted to bitmasks during export.
Export is supported using 2 alternative methods:
By default the OMERO API is used to load planes as numpy arrays and the zarr file is created from this data.
Alternatively, if you can read directly from the OMERO binary repository and have installed https://github.com/glencoesoftware/bioformats2raw then you can use this to create zarr files.
Usage
Import OME-Zarr files
To import a public OME-Zarr data into OMERO, use the import command:
$ omero zarr import https://example.com/path/to/file.ome.zarr # Use --target DATASET_ID to import into a Dataset $ omero zarr import https://example.com/path/to/file.ome.zarr --target 1234 # Or import local data which must be accessible to the OMERO server $ omero zarr import /path/to/file.ome.zarr
Export Images and Plates
To export Images or Plates via the OMERO API:
# Image will be saved in current directory as 1.ome.zarr $ omero zarr export Image:1 # Plate will be saved in current directory as 2.ome.zarr $ omero zarr export Plate:2 # Specify the OME-Zarr format, e.g. 0.4. Default is 0.5 $ omero zarr --format 0.4 export Image:1 # Use the Image or Plate 'name' to save e.g. my_image.ome.zarr $ omero zarr --name_by name export Image:1 # Specify an output directory $ omero zarr --output /home/user/zarr_files export Image:1 # By default, a tile (chunk) size of 1024 is used. Specify values with $ omero zarr export Image:1 --tile_width 256 --tile_height 256
NB: If the connection to OMERO is lost and the Image or Plate is partially exported, re-running the command will attempt to complete the export.
To export images via bioformats2raw we use the `--bf` flag:
export MANAGED_REPO=/var/omero/data/ManagedRepository export BF2RAW=/opt/tools/bioformats2raw-0.2.0-SNAPSHOT $ omero zarr --output /home/user/zarr_files export 1 --bf Image exported to /home/user/zarr_files/2chZT.lsm
Export Masks and Polygons
To export Masks or Polygons for an Image or Plate, use the masks or polygons command:
# Saved under 1.ome.zarr/labels/0 # 1.ome.zarr/ should already exist... $ omero zarr masks Image:1 # ...or specify path with --source-image $ omero zarr masks Image:1 --source-image my_image.ome.zarr # Labels saved under each image. e.g 2.ome.zarr/A/1/0/labels/0 # 2.ome.zarr should already be exported or specify path with --source-image $ omero zarr masks Plate:2 # Saved under zarr_files/1.ome.zarr/labels/0 $ omero zarr --output /home/user/zarr_files masks Image:1 # Specify the label-name. (default is '0') # e.g. Export to 1.ome.zarr/labels/A $ omero zarr masks Image:1 --label-name=A # Allow overlapping masks or polygons (overlap will be maximum value of the dtype) $ omero zarr polygons Image:1 --overlaps=dtype_max
The default behaviour is to export all masks or polygons on the Image to a single nD “labeled” zarr array, with a different value for each Shape. An exception will be thrown if any of the masks overlap, unless the –overlaps option is used as above.
An alternative to handle overlapping masks is to split masks into non-overlapping zarr groups using a “label-map” which is a csv file that specifies the name of the zarr group for each ROI on the Image. Columns are ID, NAME, ROI_ID.
For example, to create a group from the textValue of each Shape, you can use this command:
omero hql --style=plain "select distinct s.textValue, s.roi.id from Shape s where s.roi.image.id = 5514375" --limit=-1 | tee 5514375.rois
This creates a file 5514375.rois like this:
0,Cell,1369132 1,Cell,1369134 2,Cell,1369136 ... 40,Chromosomes,1369131 41,Chromosomes,1369133 42,Chromosomes,1369135 ...
This will create zarr groups of Cell and Chromosomes under 5514375.zarr/labels/:
$ omero zarr masks Image:5514375 --label-map=5514375.rois
License
This project, similar to many Open Microscopy Environment (OME) projects, is licensed under the terms of the GNU General Public License (GPL) v2 or later.
Copyright
2020-2023, The Open Microscopy Environment
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 omero_cli_zarr-0.8.0.tar.gz.
File metadata
- Download URL: omero_cli_zarr-0.8.0.tar.gz
- Upload date:
- Size: 38.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ba738f3efd8c71cf5e3f9d8a631edf9763e03ba1f171ff51b1362963fb128bfd
|
|
| MD5 |
5420fb10b13aa74c1ca8692817a8818e
|
|
| BLAKE2b-256 |
03e649f40f6ae9747dde2e10d8e7b487298e943b7cc37e3b0c688763abe7fbf3
|
File details
Details for the file omero_cli_zarr-0.8.0-py3-none-any.whl.
File metadata
- Download URL: omero_cli_zarr-0.8.0-py3-none-any.whl
- Upload date:
- Size: 38.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
10a9426a03547a10b11dacaba4de4ac90da60ba3cbe35010aafd31740f217c03
|
|
| MD5 |
8d13edbcb9a6236fb0a93f9d4df2e0a5
|
|
| BLAKE2b-256 |
e3b68e62582ab878d626174ac6028a770917bb23deff515856e957bde7ebc16c
|