編集:ポールはこれを以下で解決しました。ありがとう!
3x3行列を5x5にリサンプリング(アップスケール)しようとしています。中間点にinterpolate.interp2dまたはinterpolate.RectBivariateSpline(または機能するもの)を入力します。
これを行うための単純な既存の関数があれば、それを使用したいのですが、まだ見つけていません。たとえば、次のように機能する関数:
# upscale 2x2 to 4x4
matrixSmall = ([[-1,8],[3,5]])
matrixBig = matrixSmall.resample(4,4,cubic)
したがって、3x3の行列/配列から始める場合:
0,-2,0
-2,11,-2
0,-2,0
新しい5x5行列(「I」は補間値を意味します)を計算したい:
0, I[1,0], -2, I[3,0], 0
I[0,1], I[1,1], I[2,1], I[3,1], I[4,1]
-2, I[1,2], 11, I[3,2], -2
I[0,3], I[1,3], I[2,3], I[3,3], I[4,3]
0, I[1,4], -2, I[3,4], 0
私はさまざまなテストコードを検索して読み、試してきましたが、自分がやろうとしていることの正しい構文を完全に理解していません。また、特定の行でmeshgrid、mgrid、またはlinspaceを使用する必要があるかどうかもわかりません。
編集: Paulのおかげで修正されて動作しています
import numpy, scipy
from scipy import interpolate
kernelIn = numpy.array([[0,-2,0],
[-2,11,-2],
[0,-2,0]])
inKSize = len(kernelIn)
outKSize = 5
kernelOut = numpy.zeros((outKSize,outKSize),numpy.uint8)
x = numpy.array([0,1,2])
y = numpy.array([0,1,2])
z = kernelIn
xx = numpy.linspace(x.min(),x.max(),outKSize)
yy = numpy.linspace(y.min(),y.max(),outKSize)
newKernel = interpolate.RectBivariateSpline(x,y,z, kx=2,ky=2)
kernelOut = newKernel(xx,yy)
print kernelOut