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

Terrain tiles / hillshading #19

Open
hyperknot opened this issue Sep 25, 2024 · 17 comments
Open

Terrain tiles / hillshading #19

hyperknot opened this issue Sep 25, 2024 · 17 comments

Comments

@hyperknot
Copy link
Owner

hyperknot commented Sep 25, 2024

This is a longer term research issue about terrain tiles. Since I've never worked with terrain tiles, and also don't know which open data sources are available, please contribute your knowledge if you have experience in working with them.

Long term aim would be to have a nice looking terrain map styles, for example here is a sample from Google Maps.

image

@hyperknot
Copy link
Owner Author

Original discussion started by @aschleck here #15

@aschleck
Copy link

Raw source datasets I'm aware of:

  • Copernicus from the EU
  • NASADEM from NASA
  • ASTER from Japan
  • (US only) 3DEP
  • (Arctic only) ArcticDEM

3DEP is the most accurate but it's very very very large and hard to process, and only in the US. Most RGB DEM tilesets use NASADEM, but I think Copernicus is slightly better (research indicates it's a toss up https://www.tandfonline.com/doi/full/10.1080/10095020.2023.2296010#d1e321 https://www.usgs.gov/publications/evaluation-copernicus-dem-and-comparison-dem-used-landsat-collection-2-processing). In zxy tiling schemes most of the Arctic gets warped and no one generally cares about elevation at the south pole, so I ignored that. ASTER just seemed bad but maybe that's unfair.

I'm not a GIS expert by any means so would be happy to be corrected. https://www.maptiler.com/terrain// covers a lot of high level stuff if that's helpful.

@aschleck
Copy link

(copying reply from the discussion)

I assume by terrain RGB you mean DEMs (digital elevation maps). In those layers you have a mapping from pixel to latlng where the value of the pixel encodes the elevation (note that with TIFF images you can do single channel 32-bit float values so it's not 3 channel RGB). My layers are generated from DEMs, though the tiling scheme for the source data I'm using (mostly Copernicus from the EU, some NASADEM) is not the standard zxy scheme so they are different.

I was separately working on generating a global zxy RGB DEM tileset but ran out of energy because I didn't desperately need it and the tooling I was using was being stupid.

There are very clever client side implementations that can generate contours (idk if they're vectorized, maybe) and hill shading rasters from zxy RGB DEMs at render time, however I decided to pregenerate them server side into actual tilesets. In my experience messing with hill shading, the gdal (the program I use to do the shading) implementation just looked visually better than the shader I wrote (my shader looked smoothed and weirdly shiny? gdal looks more real). Since I have implemented my own alternative to MapLibre it's possible that's just a flaw in my own code. Implementing contouring client side in my renderer seemed both too hard and also like an excellent way to crash mobile devices. Also my contour vector layer encodes when a contour is over a glacier (it's pretty!) and it's doable but bonus complexity to calculate that client side.

Not sure if I answered your question. I think it's good to have all three and I personally think they're orthogonal even though you can do everything from one DEM tileset at render time.

@hyperknot
Copy link
Owner Author

hyperknot commented Sep 25, 2024

Thanks a lot. I prefer to just collect options and information at the moment. You mentioned before that it's about 1.5 TB of data for contours and hillshades, I'm a bit worried it might not be possible to host this much easily.

I'm curious of what's possible by client generated solutions and when is it necessary to use server-generated tiles.

@aschleck
Copy link

One last thought: my contours are 900gb but MapTiler's dataset is only 215gb. I think I looked into why and I can't recall if mine are denser, more accurate, or if MapTiler's engineers are smarter than me and found some 4x optimization I didn't see. You could compare them to see. So anyway depending on your goals and how much over-zooming you anticipate (for my usecase I expect significant over-zoom) you could reduce the storage size.

@hyperknot
Copy link
Owner Author

Thanks a lot @aschleck!

Actually maplibre-contour looks great! I mean you probably immediately recognise the differences between your server rendered version and the maplibre-contour, but it looks quite nice for me.

image

@yetzt
Copy link

yetzt commented Sep 25, 2024

you can use hillshade vectors rendered from Jörð rgb terrain tiles in a 106GB versatiles container, zoom 0-12, precompressed with brotli.

@hyperknot
Copy link
Owner Author

hyperknot commented Sep 25, 2024

@yetzt thanks for coming by, I love your work on VersaTiles!

Can you explain me what is a vector in hillshade? In MapTiler what they call Hillshade are basically 8-bit greyscale images, AKA raster tiles, like

https://api.maptiler.com/tiles/hillshade/11/1092/729.webp?key=...

Also, do you have a demo which shows the hillshade vectors?

@yetzt
Copy link

yetzt commented Sep 25, 2024

Thanks, good question. I don't have anything public to show, but i dug out a screenshot. Instead of hillshade raster tiles, it's the shades vectorized; You get "shadow" and "highlight" polygons you can integrate into your map style.

Datawrapper did something similar.

09046be5a9a85d27f07f9213f71685ec54a171adce9d3446b201a7195394ef1b

@hyperknot
Copy link
Owner Author

Thanks for the explanation @yetzt. I understand now. The advantage is that it can be super high resolution without having to download the original DEM files, the disadvantage is that you have the vectorised / magazine look, like the one below.

Here is the sample area from datawrapper
image

So far, as I understand, we can do hillshading the following ways:

  • download DEM and calculate hillshade using MapLibre's built in algorithm
  • download precalculated hillshade in raster tiles
  • use precalculated hillshade vector

For non-full planet region, there are higher quality algorithms, like the ones built into ArcGIS, QGIS or Eduard.

I also found the article introducing the Terrain RGB layer, comparing it with the previous vector based hillshade. In that article the RGB is shown as an improvement over the vector based version.

@hyperknot
Copy link
Owner Author

Interestingly Mapbox seems to have moved back from Terrain RGB to vector hillshade again, as the current styles use vector, albeit with quite a detailed resolution.

image

@yetzt
Copy link

yetzt commented Sep 26, 2024

the advantage of using vectors for hillshades are better scaling, potentially smaller size, more design freedom and less computational intensity on the client when shading rgb dem tiles.

@ajnisbet
Copy link

As far as data sources: the Copernicus DEM is very high quality for the resolution. Although technically it's a surface model rather than a terrain model like NASADEM, my experience is that the surface reported by Copernicus is actually closer to the true terrain than the NASADEM value.

The DEM files are available as tifs on aws, but you'd have to build (and host) the xyz tiles yourself.

The Mapzen / tilezen tiles aren't bad where they use good quality sources (notably parts of the US), but their use of SRTM for most of the world means the quality is poor elsewhere.

Loxcel geomatics has a nice tool for comparing these different sources.


For exactly this usecase, I'm planning to release the next version of the GPXZ dataset as free/open 30m tiles. We convert Copernicus to a terrain model (processing to remove trees and buildings), then layer on lidar data from around the world. But this is a couple months out still!

@ajnisbet
Copy link

One more note on DEM evaluation: I'd recommend visualising the DEMs as well as looking at quantitative errors. Especially for use with hillshading which is quite a visual/subjective thing!

SRTM is decently accurate vertically, but it's rather noisy / blurry. Whereas copernicus captures a lot more detail.

To put it another way, applying a gaussian blur to a DEM doesn't impact the mean square error vs ground truth data that much, but you loose fine terrain detail pretty quickly!

Here's a cherry-picked but representative example

image

@hyperknot
Copy link
Owner Author

@ajnisbet thanks a lot for sharing your knowledge, as well as your planned work on making a 30m GPXZ dataset!

About hillshading, I've seen this image on Eduard's homepage about generalization.

So if I understand correctly, the best would be to start with a high resolution source, like Copernicus 30m and then apply different generalization filters for different zoom levels. Probably for low zooms we want to generalize it quite a lot, and then show the smallest details on higher zoom levels.

@dschep
Copy link

dschep commented Dec 7, 2024

FYI, Michael is working on porting his maplibre-contour plugin into maplibre-gl-js core.

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

5 participants