在 MATLAB 代码中,我使用了kullback_leibler_divergence
可以在此处找到的相异函数。
我有一个矩阵A
,我使用下载的函数计算相异矩阵。
理论上,如果我计算
clear
A = rand(132,6); % input matrix
diss_mat = pdist(A,'@kullback_leibler_divergence'); % calculate the dissimilarity
square_diss_mat = squareform(diss_mat); % I put the dissimilarities in a square matrix
one_dist = pdist2(A(1,:),A,@kullback_leibler_divergence);
我应该得到square_diss_mat
等于的第一行one_dist
,但我不是。
如果我使用欧几里得距离,我得到它:
diss_mat = pdist(A);
square_diss_mat = squareform(diss_mat);
one_dist = pdist2(A(1,:),A);
你能告诉我为什么吗?