Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

RFC-6: Multiscale #285

Open
wants to merge 6 commits into
base: main
Choose a base branch
from
Open

RFC-6: Multiscale #285

wants to merge 6 commits into from

Conversation

normanrz
Copy link
Contributor

@normanrz normanrz commented Dec 12, 2024

This RFC proposes to change the multiscales array into a single multiscale object.

co-authored by @dstansby

Copy link
Contributor

github-actions bot commented Dec 12, 2024

Automated Review URLs

@normanrz
Copy link
Contributor Author

If you would like to endorse this RFC, please leave a 👍 reaction or comment.

@will-moore
Copy link
Member

👍 Endorse

@ziw-liu
Copy link

ziw-liu commented Dec 14, 2024

One (hypothetical) use case for an array of multiscales is to store measurements of the same sample-space grid (same scale as in coordinate transforms) that are in different data types. For example, for widefield fluorescence microscopy, the raw camera frames are in unsigned integers, and the deconvolved images are in floating point numbers. In practice many people (including me) just store them in separate Zarr stores, which has it's own problems. What would be the recommended solution for this?

@dstansby
Copy link
Contributor

In practice many people (including me) just store them in separate Zarr stores, which has it's own problems. What would be the recommended solution for this?

I think our recommendation would be to store them in separate OME-zarr datasets. Could you share some more details about what problems you have with storing them like this?

@ziw-liu
Copy link

ziw-liu commented Dec 15, 2024

I think our recommendation would be to store them in separate OME-zarr datasets. Could you share some more details about what problems you have with storing them like this?

Mostly the hassle of having multiple URLs for the same dataset. For example to visualize them in a viewer, the user needs to open each store individually; to run some simple processing (e.g. make a crop), the user needs to run the same pipeline multiple times. Each user would also need to come up with their own practices to keep track of all the associated stores, as opposed to being able to follow a standardized storage hierarchy.

@normanrz
Copy link
Contributor Author

I agree that passing around multiple URLs is a hassle. However, I don't think multiple multiscales were intended for that and almost no visualization tools support them properly.

Your use case is very similar to grouping segmentations or predictions together with the image. It also is similar to grouping images from other modalities through coordinate transformations. Together with a few other people, I am writing another RFC that aims to introduce collections for OME-Zarr that would enable these use cases. The draft is still very early but you can have a look here: https://hackmd.io/rQPfIMw0Q9SqP9WWspCiLQ# I would love to hear your feedback there.

@joshmoore
Copy link
Member

I think our recommendation would be to store them in separate OME-zarr datasets.

Do you mean in a separate multiscale, @dstansby? Or does datasets here == array? Or a separate Zarr fileset?

@dstansby
Copy link
Contributor

(after looking at the spec for the right terms) I think I meant storing them as separate OME-Zarr images

@ziw-liu
Copy link

ziw-liu commented Dec 17, 2024

The draft is still very early but you can have a look here

I get 403 forbidden for the link. I'll definitely read once it's an RFC though!

@normanrz
Copy link
Contributor Author

That link currently requires a hackmd account to access.

@normanrz
Copy link
Contributor Author

(after looking at the spec for the right terms) I think I meant storing them as separate OME-Zarr images

I think our recommendation would be to store them in separate OME-zarr datasets.

Do you mean in a separate multiscale, @dstansby? Or does datasets here == array? Or a separate Zarr fileset?

I think you mean the same thing: a separate Zarr group with multiscale metadata.

@perlman
Copy link

perlman commented Dec 18, 2024

👍 (endorse)
Happy to see this written down, including the concise json example.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants