对于一个矩阵,如果想要找到这个矩阵中最大元素的值和这个元素在原矩阵中的索引,可以用下面的代码:
x = torch.randn(4,3)
print(x)
column = 3
index = torch.argmax(x)
x_view = x.view(-1)
print(x_view)
print(index)
if (index+1)% column == 0:
i = (index+1)//column - 1
j = column - 1
else:
i = (index+1)//column
j = ((index+1)%column) - 1
if x[i][j] == x_view[index]:
print(x[i][j])
print(x_view[index])
index = torch.argmax(x) 返回的是最大元素的一维索引
下面看一下代码运行的结果:
为了获取最大值在原始矩阵中的索引,而不是view为一维状态下的一维索引,我们需要对这个index进行分解,分解出row 和column的索引。分解分为两种情况:
(1)index + 1后的值为column的整数倍,说明这个最大值在每个行向量的最末尾,用if 下面对应的逻辑进行获取索引值。
(2)如果不满足上面的if判断,那么书名最大值落在某个行向量的中间位置,就按照else下面的逻辑获取 i 和j 的值。
在后面加了判断 if x[i][j] == x_view[index]:
是为了保证我们获取的 i 和 j 的索引值是正确的,因为通过view后的向量的索引为index的位置一定是最大值,将我们的计算出的索引位置对应的数值和真正的最大值比较,就能进一步判断我们算出的矩阵索引是否正确。