Skip to content

Instantly share code, notes, and snippets.

@olejorgenb
Created September 1, 2019 16:32
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save olejorgenb/19662a415b7e1d74c59a140f2d96f162 to your computer and use it in GitHub Desktop.
Save olejorgenb/19662a415b7e1d74c59a140f2d96f162 to your computer and use it in GitHub Desktop.
Lookup elevation in Norway based on geonorge's wms service
"""
Author: Ole Jørgen Brønner, olejorgen@yahoo.no
Lookup elevation in Norway (NB: might need to change dataset for northern Norway)
Dependencies:
- owslib
- rasterio
"""
import owslib.wcs as wcs
import rasterio as rio
import io
# See https://kartkatalog.geonorge.no/search?Facets%5B0%5D.name=theme&Facets%5B0%5D.value=H%C3%B8ydedata&Facets%5B1%5D.name=dataaccess&Facets%5B1%5D.value=%C3%85pne%20data&Facets%5B2%5D.name=DistributionProtocols&Facets%5B2%5D.value=WCS-tjeneste
# for other datasets.
# NB: owslib doesn't support 1.1.2 which is the native WCS version of geonorge atm. Request an older version explicitly as a workaround
wcs_url = "https://wms.geonorge.no/skwms1/wcs.hoyde-dom1_32?version=1.0.1"
client = wcs.WebCoverageService(wcs_url)
def bbox_around(long, lat, d=1e-4*3):
# IMPROVEMENT: calculate a square box (square in lat/lons is not square in meters)
return [long-d, lat-d, long+d, lat+d]
def find_ele(lon, lat):
"""
Find elevation in meters at given WGS84 coordinate
:param lon:
:param lat:
:return: elevation in meters
"""
# https://mapserver.org/ogc/wcs_server.html#test-with-a-getcoverage-request
res = client.getCoverage(
'1',
bbox=bbox_around(lon, lat),
crs='EPSG:4326', # Note: same as WGS84
width=100, height=100, # IMPROVEMENT: estimate resolution in a better way
format='geotiff'
)
bs = res.read()
with rio.open(io.BytesIO(bs)) as ds:
ele_map = ds.read()
i, j = ds.index(lon, lat)
return ele_map[0, i, j]
@olejorgenb
Copy link
Author

NB: the DTM model might be more suitable depending on your the application

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment