Last active
April 22, 2022 06:54
-
-
Save breinbaas/579576d10db3c33f508fa1c74d61f0e1 to your computer and use it in GitHub Desktop.
Sample of using the ArcGIS REST API for AHN4 DTM height data
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import urllib.request | |
from tifffile import imread # pip install tifffile==2022.4.8 or add to requirements.txt | |
import numpy as np | |
class Tile: | |
def __init__(self): | |
self.xmin = 0 | |
self.xmax = 0 | |
self.ymin = 0 | |
self.ymax = 0 | |
self.data = None | |
@classmethod | |
def from_ahn4(cls, xmin: int, ymin: int, xmax: int, ymax: int) -> 'Tile': | |
result = Tile() | |
size_x = (xmax - xmin) * 2 | |
size_y = (ymax - ymin) * 2 | |
urllib.request.urlretrieve( | |
f"https://ahn.arcgisonline.nl/arcgis/rest/services/Hoogtebestand/AHN4_DTM_50cm/ImageServer/exportImage?bbox={xmin},{ymin},{xmax},{ymax}&bboxSR=&size={size_x},{size_y}&imageSR=&time=&format=tiff&pixelType=F64&noData=&noDataInterpretation=esriNoDataMatchAny&interpolation=+RSP_BilinearInterpolation&compression=&compressionQuality=&bandIds=&mosaicRule=&renderingRule=&f=image", | |
"data.tiff", | |
) # note that this might include interpolated values, check the API for the details | |
result.xmin = xmin | |
result.ymax = ymax | |
result.data = imread("data.tiff") | |
result.xmax = xmin + int(result.data.shape[1] * 0.5) | |
result.ymin = ymax - int(result.data.shape[0] * 0.5) | |
return result | |
def get_z(self, x: float, y: float) -> float: | |
if self.xmin <= x and x < self.xmax and self.ymin <= y and y <= self.ymax: | |
idx = int((x - self.xmin) / 0.5) | |
idy = int((self.ymax - y) / 0.5) | |
return self.data[idy, idx] | |
else: | |
return np.nan | |
if __name__ == "__main__": | |
ahn4tile = Tile.from_ahn4(131000, 476400, 131300, 476750) # watch the size because the tiff can become really large! | |
assert round(ahn4tile.get_z(131178.7, 476558.84), 4) == -0.0228 | |
assert round(ahn4tile.get_z(131178.47, 476558.79), 4) == 0.0572 | |
assert round(ahn4tile.get_z(131178.76, 476559.03), 4) == 0.1372 | |
assert round(ahn4tile.get_z(131179.02, 476558.98), 4) == -0.1028 |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
This example shows a simple class to extract a part of the height data for The Netherlands.
Note that interpolated values might be used, see https://support.esri.com/en/technical-article/000010452