1

在 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); 

你能告诉我为什么吗?

4

1 回答 1

1

kullback_leibler_divergence不是对称的,因此顺序很重要:

one_dist = pdist2(A, A(1,:), @kullback_leibler_divergence);

pdist我没有看到任何使用带有or的非对称函数的实际应用pdist2

于 2016-02-09T12:23:48.747 回答