我需要在 4 个维度(纬度、经度、高度和时间)中线性插入温度数据。
点的数量相当高(360x720x50x8),我需要一种快速的方法来计算数据范围内空间和时间的任何点的温度。
我尝试过使用scipy.interpolate.LinearNDInterpolator
,但使用 Qhull 进行三角测量在矩形网格上效率低下,需要数小时才能完成。
通过阅读此SciPy 票证,该解决方案似乎正在实施一个新的 nd 插值器,使用该标准interp1d
来计算更多数量的数据点,然后对新数据集使用“最近邻”方法。
但是,这又需要很长时间(几分钟)。
有没有一种快速的方法可以在 4 维的矩形网格上插入数据而无需花费几分钟的时间来完成?
我想在不interp1d
计算更高密度的点的情况下使用4 次,而是将其留给用户使用坐标调用,但我不知道如何做到这一点。
否则,在这里可以选择根据我的需要编写自己的 4D 插值器吗?
这是我用来测试的代码:
使用scipy.interpolate.LinearNDInterpolator
:
import numpy as np
from scipy.interpolate import LinearNDInterpolator
lats = np.arange(-90,90.5,0.5)
lons = np.arange(-180,180,0.5)
alts = np.arange(1,1000,21.717)
time = np.arange(8)
data = np.random.rand(len(lats)*len(lons)*len(alts)*len(time)).reshape((len(lats),len(lons),len(alts),len(time)))
coords = np.zeros((len(lats),len(lons),len(alts),len(time),4))
coords[...,0] = lats.reshape((len(lats),1,1,1))
coords[...,1] = lons.reshape((1,len(lons),1,1))
coords[...,2] = alts.reshape((1,1,len(alts),1))
coords[...,3] = time.reshape((1,1,1,len(time)))
coords = coords.reshape((data.size,4))
interpolatedData = LinearNDInterpolator(coords,data)
使用scipy.interpolate.interp1d
:
import numpy as np
from scipy.interpolate import LinearNDInterpolator
lats = np.arange(-90,90.5,0.5)
lons = np.arange(-180,180,0.5)
alts = np.arange(1,1000,21.717)
time = np.arange(8)
data = np.random.rand(len(lats)*len(lons)*len(alts)*len(time)).reshape((len(lats),len(lons),len(alts),len(time)))
interpolatedData = np.array([None, None, None, None])
interpolatedData[0] = interp1d(lats,data,axis=0)
interpolatedData[1] = interp1d(lons,data,axis=1)
interpolatedData[2] = interp1d(alts,data,axis=2)
interpolatedData[3] = interp1d(time,data,axis=3)
非常感谢您的帮助!