我有一个像
这样的三维数组a = np.array(
[[[1, 2],
[3, 4]],
[[5, 6],
[7, 8]]]
)
我希望得到这个数组的对角线分量,我的意思是,
>> np.array([a[i,i,:] for i in range(min(a.shape[0], a.shape[1]))])
array([[1, 2],
[7, 8]])
有没有更快的方法可以像上面那样做?
答案 0 :(得分:1)
np.diagonal
适用于具有两个以上维度的数组,您可以使用参数axis1
和axis2
指定要查看的轴,对于您的情况,默认值(axis1 = 0) ,axis2 = 1)有效:
np.diagonal(a, axis1=0, axis2=1).T
# array([[1, 2],
# [7, 8]])
它也适用于在两个轴上看到不同大小的数组:
a = np.array(
[[[1, 2],
[3, 4]],
[[5, 6],
[7, 8]],
[[9, 10],
[11, 12]]]
)
np.diagonal(a).T
#array([[1, 2],
# [7, 8]])
a = np.array(
[[[1, 2],
[3, 4],
[9, 10]],
[[5, 6],
[7, 8],
[11, 12]]]
)
np.diagonal(a).T
#array([[1, 2],
# [7, 8]])
或者您可以使用advanced indexing:
创建范围索引:
idx = np.arange(min(a.shape[:2]))
idx
# array([0, 1])
使用整数数组索引第一维和第二维,使用切片索引第三维:
a[idx, idx, :]
#array([[1, 2],
# [7, 8]])
答案 1 :(得分:1)
您也可以使用np.diagonal
代替np.einsum
:
>>> a = np.arange(1,9).reshape(2,2,2)
>>> d = np.einsum('iij->ij', a)
>>> d
array([[1, 2],
[7, 8]])
优点:它返回一个可写视图,因此可以用来直接操作原始数组中的对角线:
>>> d[0,0] = -3
>>> a
array([[[-3, 2],
[ 3, 4]],
[[ 5, 6],
[ 7, 8]]])