给定一个2D数组和两对索引,分别定义子矩阵的左上角和右下角:
a = np.arange(25).reshape(5,5)
# array([[ 0, 1, 2, 3, 4],
# [ 5, 6, 7, 8, 9],
# [10, 11, 12, 13, 14],
# [15, 16, 17, 18, 19],
# [20, 21, 22, 23, 24]])
ij_ul = (1, 1) # upper left
ij_lr = (4, 3) # lower right
我可以通过以下方式获得子矩阵:
a[ij_ul[0]:ij_lr[0], ij_ul [1]: ij_lr[1]]
# array([[ 6, 7],
# [11, 12],
# [16, 17]])
但是我想使用更优雅的东西:
a[ij_ul:ij_lr] # Wish
# TypeError: slice indices must be integers or None or have an __index__ method
同时切片所有尺寸。 ij_ul 中的第一个索引切入 ij_lr 中的第一个索引,第二个索引切换到第二个索引。
我想将它用于适用于2D和3D的功能。 这样的配方会更加通用,因为不需要计算尺寸并调整切片:
a[i:j] # 1D
a[i:j, k:l] # 2D
a[i:j, k:l, n:m] # 3D
a[tuple_1:tuple_2] # Wish
如果arrray和两个索引元组是最后一行总是有效 匹配维度。
在python / numpy中是否有同时切割多个维度的东西?
答案 0 :(得分:1)
鉴于你有这两个列表,我们可以按如下方式构造一个元组:
our_submatrix = a[tuple(map(slice, ij_ul, ij_lr))]
在这里,我们同时迭代两个迭代ij_ul
和ij_lr
,我们构造slice(..)
个对象(如果你写i:j
,你实际上在幕后构建这样的对象)
所以我们在这里做的是构建一个切片元组,我们可以将它传递给a
来构造一个带有指定切片的视图。
例如:
>>> A = np.random.randn(5, 7)
>>> A
array([[-0.41526531, 0.88895983, 1.25061578, -0.01930474, 0.90183725,
0.169831 , -0.67271614],
[ 0.26148559, -1.24269541, 0.72472787, -2.75687495, -0.64511098,
-1.5535446 , 0.74714421],
[ 0.8423359 , 0.26620621, 0.26581058, -1.20667371, 0.60521744,
2.02856815, -0.43339106],
[ 0.29617257, 1.86195973, -1.33591589, 0.97233933, -0.69254736,
-0.31652783, 0.78613453],
[-0.93928881, 0.26735583, -0.27057705, 0.78084479, -0.76763169,
0.12574734, -1.88236193]])
>>> A[tuple(map(slice, ij_ul, ij_lr))]
array([[-1.24269541, 0.72472787],
[ 0.26620621, 0.26581058],
[ 1.86195973, -1.33591589]])