从张量中提取补丁的更快方法?
Faster way to extract patches from a tensor?
我正在尝试提取以某个给定位置 (x,y,z) 为中心的固定大小的补丁。代码如下:
x = np.random.randint(0,99,(150, 80, 50, 3))
patch_size = 32
half = int(patch_size//2)
indices = np.array([[40, 20, 30], [60, 30, 27], [20, 18, 21]])
n_patches = indices.shape[0]
patches = np.empty((n_patches, patch_size, patch_size,patch_size, x.shape[-1]))
for ix,_ in enumerate(indices):
patches[ix, ...] = x[indices[ix, 0]-half:indices[ix, 0]+half,
indices[ix, 1]-half:indices[ix, 1]+half,
indices[ix, 2]-half:indices[ix, 2]+half, ...]
谁能告诉我如何使这项工作更快?或任何其他替代方案,如果您可以建议它会有很大帮助。我在 中看到类似的问题已解决,但仅适用于 2D 图像。谁能帮我概括一下这个解决方案?
我们可以利用 np.lib.stride_tricks.as_strided
based scikit-image's view_as_windows
to get sliding windows. .
from skimage.util.shape import view_as_windows
# Get sliding windows
w = view_as_windows(x,(2*half,2*half,2*half,1))[...,0]
# Get starting indices for indexing along the first three three axes
idx = indices-half
# Use advanced-indexing to index into first 3 axes with idx and a
# final permuting of axes to bring the output format as desired
out = np.moveaxis(w[idx[:,0],idx[:,1],idx[:,2]],1,-1)
我正在尝试提取以某个给定位置 (x,y,z) 为中心的固定大小的补丁。代码如下:
x = np.random.randint(0,99,(150, 80, 50, 3))
patch_size = 32
half = int(patch_size//2)
indices = np.array([[40, 20, 30], [60, 30, 27], [20, 18, 21]])
n_patches = indices.shape[0]
patches = np.empty((n_patches, patch_size, patch_size,patch_size, x.shape[-1]))
for ix,_ in enumerate(indices):
patches[ix, ...] = x[indices[ix, 0]-half:indices[ix, 0]+half,
indices[ix, 1]-half:indices[ix, 1]+half,
indices[ix, 2]-half:indices[ix, 2]+half, ...]
谁能告诉我如何使这项工作更快?或任何其他替代方案,如果您可以建议它会有很大帮助。我在
我们可以利用 np.lib.stride_tricks.as_strided
based scikit-image's view_as_windows
to get sliding windows.
from skimage.util.shape import view_as_windows
# Get sliding windows
w = view_as_windows(x,(2*half,2*half,2*half,1))[...,0]
# Get starting indices for indexing along the first three three axes
idx = indices-half
# Use advanced-indexing to index into first 3 axes with idx and a
# final permuting of axes to bring the output format as desired
out = np.moveaxis(w[idx[:,0],idx[:,1],idx[:,2]],1,-1)