1、余弦距离:

描述:余弦夹角也可以叫余弦相似度。几何中夹角余弦可用来衡量两个向量方向的差异,机 器学习中借用这一概念来衡量向量样本之间的差异。余弦的取值范围[-1,1],求的两个向量 的夹角并得出夹角对应的余弦值,次余弦值就可以用来表征这两个向量的相似性。夹角越小, 趋近于零度,余弦值越接近于 1,方向也就更吻合。反之,夹角越大,余弦值越接近于-1.特 别的:余弦值为 0 两向量垂直。可以看出,余弦相似度只与方向有关。

公式:

在二维空间中向量 A(x1,y1),B(x2,y2)的夹角余弦公式为:

程序实现:

1 importnumpy as np2 from scipy.spatial.distance importpdist3 from numpy import *

4

5 #余弦距离

6 defcosDistance():7 vec1 = [1,2,3,4]8 vec2 = [5,6,7,8]9

10 print("vec1 =",vec1)11 print("vec2 =",vec2)12

13 #方法一:根据公式

14 dist1 = np.dot(vec1,vec2) / (np.linalg.norm(vec1) *np.linalg.norm(vec2))15 print ("余弦测试结果 dist1 ="+str(dist1))16

17 #方法二:根据scipy库求解

18 Vec =np.vstack([vec1,vec2])19 dist2 = 1 - pdist(Vec,'cosine')20 print("余弦测试结果 dist2 ="+str(dist2))

2、欧氏距离:

描述:欧里几得距离或欧几里得度量是空间两个点的直线距离。较早的文献称毕达哥拉斯度 量。

公式:

推倒到n维向量:

程序实现:

1 importnumpy as np2 from scipy.spatial.distance importpdist3 from numpy import *

4 #欧几里得距离

5 defoljdDistance():6 vec1 = np.mat([1,2,3,4])7 vec2 = np.mat([5,6,7,8])8

9 print("vec1 =",vec1)10 print("vec2 =",vec2)11

12 #方法一 公式求解

13 dist1 = np.sqrt(np.sum(np.square(vec1 -vec2)))14 print("欧氏距离测试的结果为 dist1 ="+str(dist1))15

16 #方法二 根据scipy库求解

17 Vec =np.vstack([vec1,vec2])18 dist2 =pdist(Vec)19 print("欧氏距离测试的结果为 dist2 ="+str(dist2))20

21 #方法三 根据公式求解

22 dist3 = sqrt((vec1 - vec2) * (vec1 -vec2).T)23 print("欧氏距离测试的结果为 dist3 ="+str(dist3))

3、曼哈顿距离:

描述:出租车几何或曼哈顿距离(Manhattan Distance)是由十九世纪的赫尔曼·闵可夫斯基 所创词汇 ,是种使用在几何度量空间的几何学用语,用以标明两个点在标准坐标系上的绝 对轴距总和。

红色:曼哈顿距离

绿色:欧氏距离

公式:

推广到 n 维向量

程序实现:

1 importnumpy as np2 from scipy.spatial.distance importpdist3 from numpy import *

4 #曼哈顿距离

5 defcitybolckDistance():6 vec1 = np.mat([1,2,3,4])7 vec2 = np.mat([5,6,7,8])8

9 print("vec1 =",vec1)10 print("vec2 =",vec2)11

12 #方法一 根据公式求解

13 dist1 = np.sum(np.abs(vec1 -vec2))14 print("曼哈顿距离测试的结果为 dist1 ="+str(dist1))15

16 #方法二 根据scipy库求解

17 Vec =np.vstack([vec1,vec2])18 dist2 = pdist(Vec,'cityblock')19 print("曼哈顿距离测试的结果为 dist1 ="+str(dist2))20

21 #方法三 根据公式

22 dist3 = sum(abs(vec1 -vec2))23 print("曼哈顿距离测试的结果为 dist1 ="+str(dist3))

4、明可夫斯基距离:

描述:明氏距离又叫做明可夫斯基距离,是欧氏空间中的一种测度,被看做欧氏距离和曼哈 顿距离的一种推广。

公式化: 两个 n 维向量 a(x1,x2,…,xn) 与 b(y1y2,…,yn) 之间的曼哈顿距离

也可写成:

根据变参数的不同,明可夫斯基距离可以表示一类的距离:

1. 当 p = 1 时,就是曼哈顿距离

2. 当 p = 2 时,就是欧氏距离

3. 当 p ->∞时,就是切比雪夫距

程序实现:

importnumpy as npfrom scipy.spatial.distance importpdistfrom numpy import *

#明可夫斯基距离

defminkowskiDistance():

vec1= np.mat([1,2,3,4])

vec2= np.mat([5,6,7,8])print("vec1 =",vec1)print("vec2 =",vec2)#方法一 用scipy库求解

Vec =np.vstack([vec1,vec2])

dist2= pdist(Vec,'minkowski',p = 1)print("p = 1时scipy库求解曼哈顿距离,结果是:\t"+str(dist2))#方法二 根据公式求解

dist1 = np.sqrt(np.sum(np.square(vec1 -vec2)))print("平= 2 求解欧氏距离,结果是:\t"+str(dist1))#方法三 根据公式求解 p = 1

dist3 = sum(abs(vec1 -vec2))print("p = 1 公式求解曼哈顿距离,结果是:\t"+str(dist3))#方法四 根据公式求解 p = 2

dist4 = sqrt((vec1 - vec2) * (vec1 -vec2).T)print("p = 2 公式求解欧氏距离,结果是:\t"+str(dist4))

5、切比雪夫距离:

描述:在数学中,切比雪夫距离(Chebyshev distance)或是 L∞度量,是向量空间中的一种 度量,二个点之间的距离定义是其各坐标数值差绝对值的最大值

如图:

国际象棋棋盘上二个位置间的切比雪夫距离是指王要从一个位子移至另一个位子需要走的步数。由于王可 以往斜前或斜后方向移动一格,因此可以较有效率的到达目的的格子。上图是棋盘上所有位置距 f6 位置的 切比雪夫距离。

公式化: 二维平面两点 a(x1,y1) b(x2,y2)之间的切比雪夫距离

程序实现:

1 importnumpy as np2 from scipy.spatial.distance importpdist3 from numpy import *

4 #切比雪夫距离

5 defchebyshevDistance():6 vec1 = np.mat([1,2,3,4])7 vec2 = np.mat([5,6,7,8])8

9 print("vec1 =",vec1)10 print("vec2 =",vec2)11

12 #方法一 根据公式求解

13 dist1 = np.max(np.abs(vec1 -vec2))14 print("公式求解切比雪夫距离:\t"+str(dist1))15

16 #方法二 根据scipy库求解

17 Vec =np.vstack([vec1,vec2])18 dist2 = pdist(Vec,'chebyshev')19 print("scipy库求解切比雪夫距离:\t"+str(dist2))

6、杰卡德距离:

描述: 1. 杰卡德相似系数:两个集合 A 和 B 的交集元素在 A、B 并集中所占的比例,称为两个集 合的杰卡德相似系数,用符号 J(A,B)表示。

2. 杰卡德距离:与杰卡德系数相反的概念,用两个集合中不同元素占所有元素的比例来衡 量两个集合的区分度,这就是杰卡德距离。

其应用:杰卡德相似系数用在衡量样本相似度上。

公式化:

程序实现:

1 importnumpy as np2 from scipy.spatial.distance importpdist3 from numpy import *

4 #杰卡德距离

5 defjaccardDistance():6 v1 = np.random.random(10) > 0.5

7 v2 = np.random.random(10) > 0.5

8

9 vec1 =np.asarray(v1,np.int32)10 vec2 =np.asarray(v2,np.int32)11

12 print("vec1 =",vec1)13 print("vec2 =",vec2)14

15 #方法一 根据公式求解

16 up = np.double(np.bitwise_and((vec1 != vec2),np.bitwise_or(vec1 != 0,vec2 !=0)).sum())17 down = np.double(np.bitwise_or(vec1 != 0,vec2 !=0).sum())18 dist1 = (up /down)19 print("公式求解杰卡德距离:\t"+str(dist1))20

21 #方法二 根据scipy库求解

22 Vec =np.vstack([vec1,vec2])23 dist2 = pdist(Vec,'jaccard')24 print("scipy求解杰卡德距离:\t"+str(dist2))

7、汉明距离

描述:在信息论中两个等长字符串之间的距离是两个字符串对应位置的不同字符的个数。换 句话说,也就是将一个字符串换成另一个字符串所需要替换的字符个数。

公式化描述:  1011101 与 1001001 之间的汉明距离是 2

程序实现:

1 importnumpy as np2 from scipy.spatial.distance importpdist3 from numpy import *

4 #汉明距离

5 defhammingDistance():6 v1 = np.random.random(10)>0.5

7 v2 = np.random.random(10)>0.5

8

9 vec1 =np.asarray(v1,np.int32)10 vec2 =np.asarray(v2,np.int32)11

12 print("vec1 =",vec1)13 print("vec2 =",vec2)14

15 #方法一 根据公式求解

16 dist1 = np.mean(vec1!=vec2)17 print("公式求解汉明距离为:\t"+str(dist1))18

19 #方法二 根据scipy库求解

20 Vec =np.vstack([vec1,vec2])21 dist2 = pdist(Vec,'hamming')22 print("scipy库求解汉明距离:\t"+str(dist2))

python 余弦距离_距离公式汇总以及Python实现相关推荐

  1. 用python画皇冠_手把手教你用 Python 绘制酷炫的桑基图!

    原标题:手把手教你用 Python 绘制酷炫的桑基图! 作者 | 周志鹏 责编 | 郭 芮 最近,不止一次收到小伙伴的截图追问: "这个图叫什么???" "这个图真好看! ...

  2. python半圆代码_趣味项目:用Python代码做个月饼送给你!

    所用工具 1.Python中的turtle包 2.对Python似火的热情 先来介绍一番 Turtle作图又叫海龟作图,是Python中比较有趣的一个模块,功能强大,使用方便.简单来说,比如有一块空地 ...

  3. python画图宽度_手把手教你用 Python 绘制酷炫的桑基图!

    作者 | 周志鹏 责编 | 郭   芮 最近,不止一次收到小伙伴的截图追问: "这个图叫什么???" "这个图真好看!!!怎么画啊?" ...... 笔者本没有 ...

  4. 怎么用python自制计算公式_手把手教你用python制作简易计算器,能够记录你使用的情况...

    话不多说,首先先看效果图,它能够记录你在使用过程中的历史,方便你查看是否有错: 接下来就仔细分析一下是如何制作的: 简易计算器 第一步:导入资源库 在过程中使用到了tkinter这个资源库,win+R ...

  5. python做运动控制_第一课:用Python操控小龟小车运动

    欢迎来到小龟的课堂,今天我们讲如何用小龟小车的车载Python控制小车运动. 如果小伙伴还不会使用小龟小车的Python编辑器的话,可以阅读这篇教程<如何使用小龟小车的Python编辑器> ...

  6. print python excel分隔_合并/拆分 Excel?Python、VBA轻松自动化

    作者 | Ryoko 来源 | 凹凸数据 当你收集了 n 个人的 EXCEL 记录表,需要将它们汇成一个总表时你会怎么做呢? 如果不通过技术手段,要一个个打开再复制粘贴也太麻烦了吧! 此时就需要一个通 ...

  7. python 温度 符号_【火马】Python学习小记01

    Python 学习小记 Life is short,you need Python! 写在前面 自从重新拾起2016年开始注册的公众号"火马编程",我就把TA当作了自己的一块&qu ...

  8. python数据结构题目_《数据结构与算法Python语言描述》习题第二章第三题(python版)...

    ADT Rational: #定义有理数的抽象数据类型 Rational(self, int num, int den) #构造有理数num/den +(self, Rational r2) #求出本 ...

  9. python矩阵乘法_鱼书——第一章 Python入门

    one 第一章 1.1 Python是什么 Python是一个简单.易读.易记的编程语言,而且是开源的,可以免费地自由使用.Python可以用类似英语的语法编写程序,编译起来也不费力,因此我们可以很轻 ...

  10. python 简历处理_按照这个方式学Python,老板把垃圾桶里的简历舔回来:月薪50000...

    对于Python相信很多人都不陌生,相较于Excel.Tableau.PowerBI等普通的数据分析工具来说,Python的优势显然要大很多.Python有很多优点,如果你能很好的运用到工作中,会发现 ...

最新文章

  1. upgrade lnmpa php.sh,LNMP 状态管理命令说明及Nginx、MySQL/MariaDB、PHP升级教程
  2. Silverlight Analytics Framework(开源分析框架)
  3. python上海培训哪里比较好-python培训班上海哪里比较好?
  4. WCF传送大数据时的错误“ 超出最大字符串内容长度配额”
  5. 《ASP.NET MVC企业实战》(二) MVC开发前奏
  6. 完美解决ALEXA工具条无法显示或显示白框
  7. win更改文件默认打开方式
  8. 为什么python的命名不能以数字开头,Python模块名称以数字开头
  9. [Beego模型] 五、构造查询
  10. c语言智能公交系统,基于单片机智能公交小车控制系统设计(含电路图,程序清单)...
  11. 在vue中安装axios库
  12. 2021-2027全球与中国创建和销售在线课程平台市场现状及未来发展趋势
  13. 腾讯电子签小程序就能开收据了
  14. Golang 编译成DLL文件
  15. 如果光猫+hadoop,有化学反应吗?
  16. 吴恩达深度学习学习笔记——C1W2——神经网络基础——练习题
  17. 苹果公司的 iCloud
  18. 对HackTheBox里面的Netmon进行攻破
  19. Oracle图书馆借阅管理数据库,图书馆管理系统Oracle数据库平台升级研究
  20. 【人工智能实验室】第三次培训之手写数字识别代码理解

热门文章

  1. python主题壁纸_Python教你如何下载你喜欢的桌面壁纸
  2. mongodb的id的唯一性_探讨MongoDB的_id字段含义,及对MongoDB数据库的重要性
  3. html5摒弃的标记,全新改进的HTML5表单创建
  4. CTF-压缩包密码CRC爆解工具安装
  5. python基础教程: 自定义函数
  6. Python基础教程:菱形继承问题
  7. javascript技术教程蔡敏_程序员都必掌握的前端教程之JavaScript基础教程(上)
  8. 服务器挂起文件怎么删除,撤消挂起的更改或查看挂起的更改的列表
  9. c++ 人脸识别_应用层下的人脸识别(四):人脸研判
  10. 基于栅格地图的粒子群算法_基于GMapping的栅格地图的构建