matlab 计算对数似然相似度
·
计算对数似然相似度
clc,clear;
%计算对数似然相似度
K=[1 2 3;
1 2 3;
1 2 3];
N=sum(sum(K));
%计算行熵
rowEntropy=[K(1,1)*log(K(1,1)/sum(K(1,:))),K(1,2)*log(K(1,2)/sum(K(1,:))),K(2,1)*log(K(2,1)/sum(K(2,:))),K(2,2)*log(K(2,2)/sum(K(2,:)))];
rowEntropy(find(isnan(rowEntropy)==1))=0;
rowEntropy=sum(rowEntropy./N);
%计算列熵
columEntropy=[K(1,1)*log(K(1,1)/sum(K(:,1))),K(1,2)*log(K(1,2)/sum(K(:,2))),K(2,1)*log(K(2,1)/sum(K(:,1))),K(2,2)*log(K(2,2)/sum(K(:,2)))];
columEntropy(find(isnan(columEntropy)==1))=0;
columEntropy=sum(columEntropy./N);
%计算矩阵熵
matrixEntropy=K./N.*log(K./N);
matrixEntropy(find(isnan(matrixEntropy)==1))=0;
matrixEntropy=sum(sum(matrixEntropy));
%计算相似度
UserSimilarity=1-2*(matrixEntropy-rowEntropy-columEntropy)
result
rowEntropy =
-0.4432
columEntropy =
-0.3662
matrixEntropy =
-2.1100
UserSimilarity =
3.6012
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐


所有评论(0)