Почему мои значения X и Y всегда выходят за пределы размера моего растрового файла?
Я преобразовал довольно много координат WGS84, которые, как я знаю, существуют в моих растровых данных, в UTM и включил их в мою программу только для того, чтобы они сообщали мне, что они находятся вне диапазона. Мой растр 4695x9798, и я не уверен, почему мои координаты продолжают падать за пределы этого окна
import numpy as np
from osgeo import gdal,ogr
import struct
gdata = gdal.Open('sinusoidal.tif')
geot = gdata.GetGeoTransform()
x = (284905 - geot[0])/geot[1]
y = (5936117 - geot[3])/(geot[5])
myarray = np.array(gdata.GetRasterBand(1).ReadAsArray())
print gdata.RasterXSize
print gdata.RasterYSize
rb = gdata.GetRasterBand(1)
intval = rb.ReadAsArray(x,y,1,1)
print intval
Сообщение об ошибке: Доступ к окну вне диапазона в RasterIO(). Запрошено (6126,1437) размером 1х1 на растре 4695х9798.
1 ответ
Описание ошибки очень явное. Вы запрашиваете пиксель, который находится за пределами вашего растрового экстента. Это может быть связано с указанными вами UTM-координатами или с некоторыми аспектами геотрансформации, которые вы не учитываете (xskew или yskew). Более канонический способ получить индексы строки-столбца - использовать обратное геотрансформирование.
#...
rb = gdata.GetRasterBand(1)
geot = gdata.GetGeoTransform() # maps i,j to x,y
# try-except block to handle different output of InvGeoTransform with gdal versions
try:
inv_gt_success, inverse_gt = gdal.InvGeoTransform(geot) # maps x,y to i,j
except:
inverse_gt = gdal.InvGeoTransform(geot) # maps x,y to i,j
x_utm = 284905
y_utm = 5936117
pix_x = int(inverse_gt[0] + inverse_gt[1] * x_utm +
inverse_gt[2] * y_utm)
pix_y = int(inverse_gt[3] + inverse_gt[4] * y_utm +
inverse_gt[5] * y_utm)
val = rb.ReadAsArray(pix_x, pix_y, 1, 1)[0,0]