[python] 비평 탄 인덱스를 반환하는 numpy 배열의 Argmax

Numpy 배열에서 최대 요소의 인덱스를 얻으려고합니다. 이 작업은 numpy.argmax. 내 문제는 전체 배열에서 가장 큰 요소를 찾고 그 인덱스를 얻고 싶다는 것입니다.

numpy.argmax 내가 원하는 것이 아닌 하나의 축을 따라 적용하거나 내가 원하는 일종의 평평한 배열에 적용 할 수 있습니다.

내 문제는 사용하는 것입니다 numpy.argmax함께axis=None 하면 다차원 인덱스를 원할 때 플랫 인덱스 반환 입니다.

divmod평평하지 않은 인덱스를 얻는 데 사용할 수 있지만 이것은 추악한 느낌입니다. 이 작업을 수행하는 더 좋은 방법이 있습니까?



답변

numpy.unravel_index()다음 결과에 사용할 수 있습니다 numpy.argmax().

>>> a = numpy.random.random((10, 10))
>>> numpy.unravel_index(a.argmax(), a.shape)
(6, 7)
>>> a[6, 7] == a.max()
True


답변

np.where(a==a.max())

최대 요소의 좌표를 반환하지만 배열을 두 번 구문 분석해야합니다.

>>> a = np.array(((3,4,5),(0,1,2)))
>>> np.where(a==a.max())
(array([0]), array([2]))

이는와 비교 argmax하여 최대 값과 동일한 모든 요소의 좌표를 반환합니다. argmax그중 하나만 반환합니다 ( np.ones(5).argmax()반환 0).


답변

최대 값의 모든 발생에 대한 평탄하지 않은 인덱스를 얻으려면 다음 대신 사용하여 eumiro의 대답을 약간 수정할 수 있습니다 .argwherewhere

np.argwhere(a==a.max())

>>> a = np.array([[1,2,4],[4,3,4]])
>>> np.argwhere(a==a.max())
array([[0, 2],
       [1, 0],
       [1, 2]])


답변