我建议使用 griddata-method 进行插值。一个样本是:
import numpy as np
from matplotlib.mlab import griddata
import matplotlib.pyplot as plt
xs0 = np.random.random((1000)) * np.pi - np.pi/2
ys0 = np.random.random((1000)) * 3.5
zs0 = np.random.random((1000))
N = 30j
extent = (-np.pi/2,np.pi/2,0,3.5)
xs,ys = np.mgrid[extent[0]:extent[1]:N, extent[2]:extent[3]:N]
resampled = griddata(xs0, ys0, zs0, xs, ys)
plt.imshow(resampled.T, extent=extent)
plt.plot(xs0, ys0, "r.")
plt.plot(xs, ys, "b.")
plt.title("imshow for irregularly spaced data using griddata")
plt.show()
我想从您的 3*X 阵列到三个 X 阵列的过渡是显而易见的。
结果是:
红点表示数据的“原始”位置,蓝点表示现在规则间隔的数据。
griddata 返回一个掩码数组。无法评估插值的所有点都被屏蔽,然后绘制为白色区域。
HTH,托尔斯滕