歪みを判別して補間し直して補正することができます。
import numpy as np
from scipy.ndimage.interpolation import map_coordinates
m, n = g.shape
j_shift = np.interp(g[:,0], g[0,:], np.arange(n))
pad = int(np.max(j_shift))
i, j = np.indices((m, n + pad))
z = map_coordinates(g, [i, j - j_shift[:,None]], cval=np.nan)
これは、例えば画像に動作しますが、あなたはそれが他の勾配に機能させるためにいくつかの追加のチェックを行う必要があります。しかし、x方向に非線形なグラデーションでは機能しません。デモ:
全スクリプト:
import numpy as np
from scipy.ndimage.interpolation import map_coordinates
def fix(g):
x = 1 if g[0,0] < g[0,-1] else -1
y = 1 if g[0,0] < g[-1,0] else -1
g = g[::y,::x]
m, n = g.shape
j_shift = np.interp(g[:,0], g[0,:], np.arange(n))
pad = int(np.max(j_shift))
i, j = np.indices((m, n + pad))
z = map_coordinates(g, [i, j - j_shift[:,None]], cval=np.nan)
return z[::y,::x]
import matplotlib.pyplot as plt
i, j = np.indices((50,100))
g = 0.01*i**2 + j
plt.figure(figsize=(6,5))
plt.subplot(211)
plt.imshow(g[::-1], interpolation='none')
plt.title('original')
plt.subplot(212)
plt.imshow(fix(g[::-1]), interpolation='none')
plt.title('fixed')
plt.tight_layout()
http://stackoverflow.com/questions/33085142/skewing-an-array-in-pythonの可能重複? – dnalow
@dnalowそれは近いですが、その解決策は補間しません。私が説明を書いているように、それはかなり直線的な勾配ではないので、実行する必要のあるスキュー以上のものがあります。私はxで翻訳される前に、各行を最下行の値に補間する必要があると思います。 –