2つの配列間の多次元(24次元)でユークリッド距離を計算したいと思います。私はNumpy-Scipyを使用しています。多次元ユークリッド距離(Python)
import numpy,scipy;
A=numpy.array([116.629, 7192.6, 4535.66, 279714, 176404, 443608, 295522, 1.18399e+07, 7.74233e+06, 2.85839e+08, 2.30168e+08, 5.6919e+08, 168989, 7.48866e+06, 1.45261e+06, 7.49496e+07, 2.13295e+07, 3.74361e+08, 54.5, 3349.39, 262.614, 16175.8, 3693.79, 205865]);
B=numpy.array([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 151246, 6795630, 4566625, 2.0355328e+08, 1.4250515e+08, 3.2699482e+08, 95635, 4470961, 589043, 29729866, 6124073, 222.3]);
は、しかし、私はeucleidan距離をcalcuateするscipy.spatial.distance.cdist(A[numpy.newaxis,:],B,'euclidean')
を使用:
は、ここに私のコードです。
しかし、それは私がそれを理解していないよう私にエラー
raise ValueError('XB must be a 2-dimensional array.');
を与えました。
私はscipy.spatial.distance.pdist
を見上げましたが、それを使用する方法を理解していませんか?
他にも良い方法がありますか?
おそらく['scipy.spatial.distance.euclidean'](http://docs.scipy.org/doc/scipy/reference/generated/scipy.spatial.distance.euclidean.html#scipy.spatial.distance。ユークリッド)? –
これはすばやく簡単でした!ありがとう。 – garak
だから、あなたは、24次元のポイントを持っていますか?その場合、@ Mr.Eの答えは最良の選択肢です。しかし、2つ以上のポイントがある場合は、さまざまな 'scipy.spatial.distance'関数がより効率的になります。 –