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

Question: Visualizing high resolution image is slow #300

Open
mdhe1248 opened this issue Dec 12, 2023 · 3 comments
Open

Question: Visualizing high resolution image is slow #300

mdhe1248 opened this issue Dec 12, 2023 · 3 comments

Comments

@mdhe1248
Copy link

When visualizing a high resolution image, ImageView seems quite slow (slower than ImageJ). To speed up, is it possible to limit the image resolution to that of monitor; but visualize the original resolution when a region is zoomed in? I guess when the image resolution is larger than that of monitor, it may not necessary to load all the pixels.

@jwahlstrand
Copy link
Collaborator

I'd assume the slowness has to do with ImageView using Cairo to draw an image into a memory buffer, which is then shown by GTK. There's little to no GPU involvement, as far as I understand it. There are probably ways to eke out more performance within the current approach (perhaps by doing what you say), but it would probably be more efficient to use GL or the equivalent to do the rescaling and drawing. That would require someone rewriting the Canvas code in GtkObservables to use GL rather than Cairo.

@mkitti
Copy link
Member

mkitti commented May 2, 2024

With ImageJ is an image pyramid being used (such as with BigDataViewer) ?

@jwahlstrand
Copy link
Collaborator

Over the summer I did some profiling of ImageView's rendering of big images and found that for the "earth" test image, almost 90% of the time in the canvas "draw" function was spent calling restrict, which downsamples the image. Doing the same downsampling over and over as the user zooms and pans is wasteful, and caching the output indeed improves performance of redraws (#313). However, it turns out that a real implementation of an image pyramid is in the works (JuliaImages/ImageBase.jl#39). Rather than hacking something together in this package, it makes sense to wait and use whatever comes out of that effort.

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

No branches or pull requests

3 participants