我正在使用 GDAL 处理 GIS 栅格的 Python 项目。这些栅格或图像可能会变得相当大,因此我通常使用 Numpy 中的内存映射来加载它们。目前我想对内存映射的 Numpy 数组进行距离变换操作。我试图使用 Scipy 的distance_transform_edt函数,但是,这个函数在内存中返回结果的副本,我最终得到了一个内存错误。
561, in distance_transform_dataset
dest_array = ndimage.distance_transform_edt(source_array) * pixel_size
File "/usr/local/lib/python2.7/dist-packages/scipy/ndimage/morphology.py", line 2173,
in distance_transform_edt
input = numpy.atleast_1d(numpy.where(input, 1, 0).astype(numpy.int8))
MemoryError
None
很多时候,像这样的函数会有一个“out”参数来写入结果。这个函数没有,所以我不能写入内存映射的 numpy 数组。
任何关于如何在大型 numpy 数组上进行内存有效距离变换计算的想法将不胜感激。谢谢。