브로드 캐스팅하여 두 개의 numpy 배열의 유클리드 거리를 계산하는 방법 [중복]
두 개의 numpy 배열의 유클리드 거리를 계산하고 싶습니다.
배열의 각 행은 벡터입니다.
예 :
a = np.array([125, 20, 210, 55], [11, 97, 111, 71])
b = np.array([51, 19, 35, 65], [59, 80, 37, 60])
a의 각 행과 b의 각 행의 유클리드 거리를 계산해야합니다.
배열의 실제 크기는 5000 행과 4000 열이 될 수 있습니다.
두 개의 for 루프와 하나의 for 루프로 수행하는 방법을 알고 있습니다. 벡터화 된 numpy 배열로 해결해야합니다. 예 : 배열을 다른 사람에게 브로드 캐스트https://numpy.org/devdocs/user/theory.broadcasting.html
사용하지 않고
spatial.distance.cdist
하지만 어떻게해야할지 모르겠습니다.
어떤 도움을 주시면 감사하겠습니다.
답변
AagamSheth
import numpy as np
np.sqrt((np.square(a[:,np.newaxis] - b).sum(axis=2)))