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

Loading from higher resolution geoimages / extracting larger-scale textures is slower #15

Closed
kb173 opened this issue Mar 25, 2020 · 5 comments
Assignees
Labels
bug Something isn't working

Comments

@kb173
Copy link
Member

kb173 commented Mar 25, 2020

With nearest neighbor sampling, the scale of the desired image / the resolution (pixels / meter) of the raw geodata should have close to no effect on performance because only single points are sampled either way. Only the resolution of the output texture should have an effect.

For some reason though, the resolution / scale does have a pretty significant impact that is especially noticeable with very high-resolution images and large-scale (overview) extraction. It seems to stem from the warp operation. We should investigate whether additional samples or a different algorithm is used somewhere there. Perhaps #4 could come into play here too!

@kb173 kb173 added the bug Something isn't working label Mar 25, 2020
@kb173 kb173 self-assigned this Mar 25, 2020
@kb173
Copy link
Member Author

kb173 commented Mar 26, 2020

Seems like I misread the logs there: It doesn't only happen in the warp operation, but also before it. The time this takes could be related to reading the metadata of the dataset or something else that happens when first opening it. We could cache it, it's not a problem if it only happens the first time.
Maybe not though, since a larger size in meters of the request also increases this waiting time... Gotta figure out more exactly where it gets stuck.

Weird - the warp operation is only slow with a larger output pixel size (which is expected), but the amount it gets slower seems to be different depending on the raw data. It's also not consistently slow but it gets stuck - seemingly after each quarter of warping. Funnily, an image size of 3x3 gets slow after each third of warping, whereas a 2x2 image warps instantly even when requesting 5x5km.

I might want to test this with a different hard drive, that could be the reason too... or maybe it depends on how well the file system handles large files like that? (The TIF I'm testing with is over 100GB large)

@kb173
Copy link
Member Author

kb173 commented Mar 26, 2020

No, GDALOpen is not the problem - It seems like it gets stuck before the warp, but apparently it's just stuck at 0% of the warp.

I guess this makes it somewhat easier since the warp is the only problem.

@kb173
Copy link
Member Author

kb173 commented Mar 26, 2020

ChunkAndWarpMulti is much faster than ChunkAndWarpImage. Makes sense that it's somewhat faster, but it doesn't exhibit the stuck behavior at all at scales where ChunkAndWarpImage does. However, it does also start getting stuck at similar points (quarters of progress) starting at a certain scale/resolution.

In order to handle images too large to hold in RAM, the warper needs to segment large images. This is the responsibility of the GDALWarpOperation class.

This could be the reason... but why is it loading everything into RAM, not just the required parts?

@kb173
Copy link
Member Author

kb173 commented Mar 26, 2020

Ok, to some extent it's definitely a hard drive thing because loading it the first time takes long, and each time the same raster is requested afterwards is much faster.

I tried fixing #4 and this solves this issue because we can get rid of the whole warping stuff. It needs to be cleaned up though because something is not quite right with the coordinate transformation.

@kb173
Copy link
Member Author

kb173 commented Mar 26, 2020

#4 does indeed fix this! bb065db is a proof of concept where this issue is gone, but not everything is reimplemented without GDALWarp yet. Further discussion will be in #4.

@kb173 kb173 closed this as completed Mar 26, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

1 participant