Tod*_*ddP 3 arrays numpy multidimensional-array python-3.x argmax
对于 2D NumPy 数组中的每一列,该列的最大值可以出现多次。我想找到每列最大值的行索引,而不重复行索引。
np.argmax这是一个演示为什么不起作用的示例:
import numpy as np
a = np.array([[1, 1, 0],
[1, 0, 1],
[0, 0, 1]])
ind = np.argmax(a, axis=0)
print(ind)
Run Code Online (Sandbox Code Playgroud)
输出:
[0 0 2]
Run Code Online (Sandbox Code Playgroud)
我想要结果:[1, 0, 2]对于这个例子。
那是:
一个稍微复杂一点的例子是这个数组:
[0 0 2]
Run Code Online (Sandbox Code Playgroud)
在这种情况下,不存在具有唯一最大值的列。我会对以下任一答案感到满意:
[0, 1, 2][1, 0, 2]一个更复杂的例子是:
a = np.array([[1, 1, 0],
[1, 1, 1],
[0, 0, 1]])
Run Code Online (Sandbox Code Playgroud)
在这种情况下,我会对以下任何答案感到满意:
[0, 1, 2][0, 2, 1][1, 0, 2][1, 2, 0]我可以用循环和逻辑条件解决这些问题,但我想知道是否有办法使用 numpy 函数解决问题?
可能有点矫枉过正,但你可以使用scipy.optimize.linear_sum_assignment:
from scipy.optimize import linear_sum_assignment
a = np.array([[1, 1, 0],
[1, 0, 1],
[0, 0, 1]])
linear_sum_assignment(-a.T)[1]
# array([1, 0, 2])
Run Code Online (Sandbox Code Playgroud)
请注意,您始终可以使用类似的方法减少到 0,1 情况
abin = a==a.max(axis=0)
Run Code Online (Sandbox Code Playgroud)
这可以大大加快分配速度。
或者,请参阅这篇文章以获取图论解决方案。