File Exchange

image thumbnail

Pair-wise Euclidean Distance Matrix

version 1.2.0.0 (2.62 KB) by Quan Wang
Computing the distance matrix without loops

4 Downloads

Updated 20 May 2014

View Version History

View License

This is a very simple function to compute pair-wise Euclidean distances within a vector set, from between two vector sets. Although simple, it is very useful. Using loops will be too slow.
D=distanceMatrix(X), where X is N*d data, and D is N*N distance matrix.

or D=distanceMatrix2(X,Y).

Cite As

Quan Wang (2020). Pair-wise Euclidean Distance Matrix (https://www.mathworks.com/matlabcentral/fileexchange/45968-pair-wise-euclidean-distance-matrix), MATLAB Central File Exchange. Retrieved .

Comments and Ratings (1)

Jonas Lundgren

Dear Quan Wang,

It is a widespread misunderstanding that MATLAB loops are slow in general. Loops with simple math operations can be very fast. Waste of memory is always slow and so is the function repmat.

Compare distanceMatrix(X) with distmat(X) below. X = rand(1000,3).

I am sure you will reply with something even faster. I look forward to update the rating.

Kind regards
Jonas Lundgren

%------------------
function D = distmat(X)
%DISTMAT Compute euclidian distance matrix from coordinates

[n,dim] = size(X);
D = zeros(n);
for j = 1:n
for k = 1:dim
v = X(:,k) - X(j,k);
D(:,j) = D(:,j) + v.*v;
end
end
D = sqrt(D);

MATLAB Release Compatibility
Created with R2013b
Compatible with any release
Platform Compatibility
Windows macOS Linux

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!