打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
各种相似度计算的python实现

前言

在数据挖掘中有很多地方要计算相似度,比如聚类分析和协同过滤。计算相似度的有许多方法,其中有欧几里德距离、曼哈顿距离、Jaccard系数和皮尔逊相关度等等。我们这里把一些常用的相似度计算方法,用python进行实现以下。如果是初学者,我认为把公式先写下来,然后再写代码去实现比较好。

欧几里德距离

几个数据集之间的相似度一般是基于每对对象间的距离计算。最常用的当然是欧几里德距离,其公式为:

#-*-coding:utf-8 -*-#计算欧几里德距离:def euclidean(p,q):#如果两数据集数目不同,计算两者之间都对应有的数same = 0for i in p:    if i in q:        same +=1#计算欧几里德距离,并将其标准化e = sum([(p[i] - q[i])**2 for i in range(same)])return 1/(1+e**.5)

我们用数据集可以去算一下:

p = [1,3,2,3,4,3]q = [1,3,4,3,2,3,4,3]print euclidean(p,q)

得出结果是:0.261203874964

皮尔逊相关度

几个数据集中出现异常值的时候,欧几里德距离就不如皮尔逊相关度‘稳定’,它会在出现偏差时倾向于给出更好的结果。其公式为:

-*-coding:utf-8 -*-#计算皮尔逊相关度:def pearson(p,q):#只计算两者共同有的    same = 0    for i in p:        if i in q:            same +=1    n = same    #分别求p,q的和    sumx = sum([p[i] for i in range(n)])    sumy = sum([q[i] for i in range(n)])    #分别求出p,q的平方和    sumxsq = sum([p[i]**2 for i in range(n)])    sumysq = sum([q[i]**2 for i in range(n)])    #求出p,q的乘积和    sumxy = sum([p[i]*q[i] for i in range(n)])    # print sumxy    #求出pearson相关系数    up = sumxy - sumx*sumy/n    down = ((sumxsq - pow(sumxsq,2)/n)*(sumysq - pow(sumysq,2)/n))**.5    #若down为零则不能计算,return 0    if down == 0 :return 0    r = up/down    return r

用同样的数据集去计算:

p = [1,3,2,3,4,3]q = [1,3,4,3,2,3,4,3]print pearson(p,q)

得出结果是:0.00595238095238

曼哈顿距离

曼哈顿距离是另一种相似度计算方法,不是经常需要,但是我们仍然学会如何用python去实现,其公式为:

#-*-coding:utf-8 -*-#计算曼哈顿距离:def manhattan(p,q):#只计算两者共同有的    same = 0    for i in p:        if i in q:        same += 1#计算曼哈顿距离    n = same    vals = range(n)    distance = sum(abs(p[i] - q[i]) for i in vals)    return distance

用以上的数据集去计算:

p = [1,3,2,3,4,3]q = [1,3,4,3,2,3,4,3]print manhattan(p,q)

得出结果为4

Jaccard系数

当数据集为二元变量时,我们只有两种状态:0或者1。这个时候以上的计算相似度的方法就无法派上用场,于是我们引出Jaccard系数,这是一个能够表示两个数据集都是二元变量(也可以多元)的相似度的指标,其公式为:

#-*-coding:utf-8 -*-# 计算jaccard系数def jaccard(p,q):    c = [a for i in p if v in b]    return float(len(c))/(len(a)+len(b)-len(b))#注意:在使用之前必须对两个数据集进行去重我们用一些特殊的数据集去测试一下:p = ['shirt','shoes','pants','socks']q = ['shirt','shoes']print jaccard(p,q)得出结果是:0.5
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
编程语言入门经典100例【Python版】
Python:Python技巧之80个经典题——课程笔记(一)
Tensor 张量的维数 shape
Python 函数 | w3cschool菜鸟教程
[快学Python3]循环控制
解决Python 文件 使用utf-8编码引起的错误
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服