Pythonを使用してblinear補間を実行したいと思います。
高さを補間したいGPSポイントの例は次のとおりです。
B = 54.4786674627
L = 17.0470721369
既知の座標と高さの値を持つ 4 つの隣接点を使用します。
n = [(54.5, 17.041667, 31.993), (54.5, 17.083333, 31.911), (54.458333, 17.041667, 31.945), (54.458333, 17.083333, 31.866)]
z01 z11
z
z00 z10
そして、ここに私の原始的な試みがあります:
import math
z00 = n[0][2]
z01 = n[1][2]
z10 = n[2][2]
z11 = n[3][2]
c = 0.016667 #grid spacing
x0 = 56 #latitude of origin of grid
y0 = 13 #longitude of origin of grid
i = math.floor((L-y0)/c)
j = math.floor((B-x0)/c)
t = (B - x0)/c - j
z0 = (1-t)*z00 + t*z10
z1 = (1-t)*z01 + t*z11
s = (L-y0)/c - i
z = (1-s)*z0 + s*z1
ここで z0 と z1
z01 z0 z11
z
z00 z1 z10
私は 31.964 を取得しますが、他のソフトウェアからは 31.961 を取得します。
私のスクリプトは正しいですか?
別のアプローチを提供できますか?
2022 年編集:
この質問の公開から 10 年以上経った今でも、新しい回答を提供してくださっているすべての方々に感謝します。