您的问题(和链接页面)包含答案。。。作为
AffineTransform
允许您指定转换矩阵,并且您的链接wiki页面显示了这是什么,通过直接指定转换矩阵来减少操作的数量非常简单,例如。
from skimage import data, transform
import matplotlib.pyplot as plt
import numpy as np
img = data.astronaut()/255
v = 0.3
tf = transform.AffineTransform(shear=-v)
img2 = transform.warp(img, tf, order=1, preserve_range=True, mode='constant')
img3 = np.swapaxes(img, 0, 1)
img3 = transform.warp(img3, tf, order=1, preserve_range=True, mode='constant')
img3 = np.swapaxes(img3, 0, 1)
plt.imshow(np.hstack([img, img2, img3]))
# Using the transformation matrix directly...
tf_h = transform.AffineTransform(
np.array([[1, 0.3, 0], [0, 1, 0], [0, 0, 1]]))
img4 = transform.warp(img, tf, order=1, preserve_range=True, mode='constant')
tf_v = transform.AffineTransform(
np.array([[1, 0, 0], [0.3, 1, 0], [0, 0, 1]]))
img4 = transform.warp(img, tf_h, order=1, preserve_range=True, mode='constant')
img5 = transform.warp(img, tf_v, order=1, preserve_range=True, mode='constant')
plt.figure()
plt.imshow(np.hstack([img, img4, img5]))
plt.show()
您应该看到两个具有相同图像集的图形。