ImageVerifierCode 换一换
格式:DOCX , 页数:16 ,大小:278.33KB ,
资源ID:10473119      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/10473119.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(应用R语言实现信息熵距离算法.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

应用R语言实现信息熵距离算法.docx

1、应用R语言实现信息熵距离算法R语言实现46种距离算法前言距离算法是做数据挖掘常用的一类算法,距离算法有很多种,比如欧式距离、马氏距离、皮尔逊距离,距离算法主要应用在计算数据集之间关系。本文用R语言来philentropy包,实现多种距离的算法,很多可能是大家完全没有听过的,让我们在开拓一下知识领域吧。1. 距离算法包philentropy2. 46种距离算法详解3. 距离函数的使用1.距离算法包philentropy在做距离算法调研时,无意中发了philentropy包。它实现了46个不同距离算法和相似性度量,通过不同数据的相似度比较,为基础研究提供了科学基础。philentropy包,为聚类

2、、分类、统计推断、拟合优度、非参数统计、信息理论和机器学习提供了核心的计算框架,支持基于单变量或者多变量的概率函数的计算。philentropy包主要包括了2种度量的计算方法,距离度量和信息度量。本文介绍距离度量的使用,对于信息度量的使用,请参考文章R语言实现信息度量。philentropy项目github地址:本文的系统环境为: Win10 64bit R: 3.4.2 x86_64-w64-mingw32安装philentropy包,非常简单,一条命令就可以了。 R install.packages(philentropy) library(philentropy)查看距离算法列表 get

3、DistMethods() 1 euclidean manhattan minkowski chebyshev 5 sorensen gower soergel kulczynski_d 9 canberra lorentzian intersection non-intersection 13 wavehedges czekanowski motyka kulczynski_s 17 tanimoto ruzicka inner_product harmonic_mean 21 cosine hassebrook jaccard dice 25 fidelity bhattacharyya

4、hellinger matusita 29 squared_chord squared_euclidean pearson neyman 33 squared_chi prob_symm divergence clark 37 additive_symm kullback-leibler jeffreys k_divergence 41 topsoe jensen-shannon jensen_difference taneja 45 kumar-johnson avg 46个距离算法,有一些是我们常用的比如:euclidean,manhattan,minkowski,pearson, cos

5、ine,squared_chi, 其他的我也不知道,正好拓宽知识,好好学习一下。philentropy包的函数,其实很简单,只有14个,大量的算法其实都已经被封装到distance()函数中,直接使用distance()函数就行完成各种算法的计算,让我们使用起来会非常方便。我们来看一下,函数列表: distance(): 计算距离 getDistMethods(),获得距离算法列表 dist.diversity(),概率密度函数之间的距离差异 estimate.probability(),从计数向量估计概率向量 lin.cor(),线性相关性判断 H(): 香农熵, Shannons Entr

6、opy H(X) JE() : 联合熵, Joint-Entropy H(X,Y) CE() : 条件熵, Conditional-Entropy H(X|Y) MI() : 互信息, Shannons Mutual Information I(X,Y) KL() : KL散度, KullbackLeibler Divergence JSD() : JS散度,Jensen-Shannon Divergence gJSD() : 通用JS散度,Generalized Jensen-Shannon Divergence binned.kernel.est(),实现了KernSmooth包提供的核密

7、度估计函数的接口从函数列表来看,主要分为3种类别的函数,第一类是距离测量的函数,包括distance(),getDistMethods(), dist.diversity(), lin.cor()和 estimate.probability()。第二类是相关性分析,包括lin.cor()函数。第三类是信息度量函数H(),JE(),CE(),MI(),KL(),JSD(),gJSD()。信息度量函数的使用,请参考文章R语言实现信息度量。2. 46种算法详解接下来,就让我们深入每个算法吧,从名字到公式,再到函数使用,最后到使用场景。距离算法列表: euclidean:欧式距离,是一个通常采用的距离

8、定义,在m维空间中两个点之间的真实距离,或者向量的自然长度(即该点到原点的距离)。 manhattan:曼哈顿距离,用于几何空间度量,表示两个点在标准坐标系上的绝对轴距距离总和。 minkowski:闵可夫斯基距离,是欧氏空间中的广义距离函数,其参数p值的不同代表着对空间不同的度量。 chebyshev:切比雪夫距离,是向量空间中的一种度量,二个点之间的距离定义是其各坐标数值差绝对值的最大值。 sorensen:测量每个样本单位,对单位总数的距离测量贡献度,广告用于生态学。 gower:高尔距离,将向量空间缩放为规范化空间,可计算逻辑值,数字,文本的距离,距离结果为0到1之间的数字。 soer

9、gel:测量每个样本单位,对最大值总数的距离测量贡献度。 kulczynski:与soergel相反,测量每个样本单位,对最小值总数的距离测量贡献度。 canberra:堪培拉距离,是矢量空间中的点对之间的距离的数值度量,它是L_1距离的加权版本。 lorentzian:洛伦兹距离,绝对的差异并应用自然对数。 intersection:交叉距离,最小轨道交叉距离,是天文学中用于评估天文物体之间潜在的近距离接近和碰撞风险的度量。它被定义为两个物体的密切轨道的最近点之间的距离。 non-intersection:非交叉距离 wavehedges:波浪距离, czekanowski: motyka:

10、莫蒂卡方程,是czekanowski的一半。 kulczynski_s: tanimoto:是标准化内积的另一种变体。 ruzicka: inner_product:内部产品空间,计算两个向量的内积产生标量,有时称为标量积或点积。 harmonic_mean:调和平均值。 cosine:余弦距离,是用向量空间中两个向量夹角的余弦值作为衡量两个个体间差异的大小的度量。 hassebrook(PCE):利用PQ来测量能量的峰值,简称PCE。 jaccard:杰卡德距离,用于计算样本间的相似度,分子是A和B的交集大小,分母是A和B的并集大小。 dice:骰子 fidelity:保真度,在量子信息理论

11、中,保真度是两个量子态“接近”的度量。 bhattacharyya:巴氏距离,测量两个概率分布的相似性。 hellinger:海林格,用来度量两个概率分布的相似度,它是F散度的一种。 matusita: squared_chord: squared_euclidean:欧式距离的平方 pearson:皮尔森距离,分子是两个集合的交集大小,分母是两个集合大小的几何平均值,是余弦距离的一种变型。 neyman:奈曼, squared_chi: prob_symm: divergence:散度, clark:克拉克, additive_symm:算术和几何平均散度. kullback-leibler

12、:KL散度,用于计算相熵或信息偏差,是衡量两个分布(P、Q)之间的距离,越小越相似。 jeffreys:杰弗里斯,J分歧。 k_divergence:K散度, topsoe:托普索,是k_divergence加法的对称形式。 jensen-shannon:詹森香农,是topsoe距离的一半。 jensen_difference: taneja:塔内加,计算算术和几何平均偏差。 kumar-johnson:库马尔-约翰逊, avg:平均由于精力和基础知识有限,对每一种算法还没有更深入的理解和使用,后面会继续补充。这些距离的详细解释,请参考文章http:/csis.pace.edu/ctapper

13、t/dps/d861-12/session4-p2.pdf这么多种的距离算法,其实可以分成8大距离家族,每个家族中不同的算法思路是类似的,可以通过变形或参数不同赋值,进行算法的相互转换。L_p Minkowski家族,通过对Minkowski 算法p值的不同赋值,可以转换成不同的算法,当p=1时Minkowski距离转为曼哈顿距离;当p=2变Minkowski距离转为欧氏距离;当p接近极限最大值时,Minkowski距离是转为切比雪夫距离。L_1家族,用于准确的测量绝对差异的特征。Intersection 交叉距离家族,用于交叉点之间的相似度变换。Inter Product家族,几何空间的相似

14、性度量,用于特定的 PQ变量来计算。Squared-chord家族,在量子信息理论中,量子态“接近”的度量。Squared L_2家族( X2 Squared家族),以平方的欧几里得距离做为被除数。香浓信息熵家族,信息熵偏差测量。组合公式,利用多种算法思路,进行组合的距离测量方法。3. 距离函数的使用了解了这么多的距离算法后,让我们来使用一下philentropy包强大的功能函数,把算法落地。3.1 distance()函数使用distance()函数,用来计算两个概率密度函数之间的距离和相似度,上面所列出的所有的距离算法都被封装在了这个函数里。distance()函数定义:distance(

15、x, method = euclidean, p = NULL, test.na = TRUE, unit = log, est.prob = NULL)参数列表: x, 数值类型的向量或数据集 method, 算法的名称 p, minkowski闵可夫斯基距离的p值,p=1为曼哈顿距离,p=2为欧氏距离,p取极限时是切比雪夫距离 test.na, 检测数据集是否有NA值,不检测为FALSE,计算会快。 unit,对数化的单位,依赖于日志计算的距离 est.prob 从计数估计概率,默认值为NULL计算euclidean距离,用iris的数据集。 library(magrittr)# 查看ir

16、is数据集 head(iris) Sepal.Length Sepal.Width Petal.Length Petal.Width Species1 5.1 3.5 1.4 0.2 setosa2 4.9 3.0 1.4 0.2 setosa3 4.7 3.2 1.3 0.2 setosa4 4.6 3.1 1.5 0.2 setosa5 5.0 3.6 1.4 0.2 setosa6 5.4 3.9 1.7 0.4 setosa计算第1个点(第1行)和第2个点(第2行)的euclidean距离,分别使用philentropy包的distance(),Stats包的dist(),和自己通过公

17、式计算。# 使用distance()函数 dat1 distance(dat1, method=euclidean)Metric: euclidean using unit: log.euclidean 0.5385165 # 再使用系统自带的dist()函数 dist(dat1) 12 0.5385165# 公式计算 (dat11,-dat12,)2 % sum % sqrt1 0.53851653种方法,计算的结果是完全一致。接下来,我们构建一个iris的距离矩阵,为了展示清楚,我们选iris的前6个点来计算距离。分别使用distance()和dist()函数。 dat2 distance

18、(dat2)Metric: euclidean using unit: log. v1 v2 v3 v4 v5 v6v1 0.0000000 0.5385165 0.509902 0.6480741 0.1414214 0.6164414v2 0.5385165 0.0000000 0.300000 0.3316625 0.6082763 1.0908712v3 0.5099020 0.3000000 0.000000 0.2449490 0.5099020 1.0862780v4 0.6480741 0.3316625 0.244949 0.0000000 0.6480741 1.16619

19、04v5 0.1414214 0.6082763 0.509902 0.6480741 0.0000000 0.6164414v6 0.6164414 1.0908712 1.086278 1.1661904 0.6164414 0.0000000# 下三角距离矩阵 dist(dat2) 1 2 3 4 52 0.5385165 3 0.5099020 0.3000000 4 0.6480741 0.3316625 0.2449490 5 0.1414214 0.6082763 0.5099020 0.6480741 6 0.6164414 1.0908712 1.0862780 1.1661

20、904 0.6164414验证后,我们就可以放心使用distance()函数。通过对比实验,我们可以很快的学习并使用各种距离算法。3.2 dist.diversity()函数dist.diversity()函数,用来计算所有距离的值。由于有一些距离有对于数据集本身的要求,所以我们需要构建一个能适应所有距离算法的数据集。# 生成数据集,2个点,10个维度 P Q x head(x) ,1 ,2 ,3 ,4 ,5 ,6 ,7 ,8P 0.01818182 0.03636364 0.05454545 0.07272727 0.09090909 0.1090909 0.1272727 0.145454

21、5Q 0.08163265 0.08571429 0.08979592 0.09387755 0.09795918 0.1020408 0.1061224 0.1102041 ,9 ,10P 0.1636364 0.1818182Q 0.1142857 0.1183673使用dist.diversity()函数计算所有的距离。 dist.diversity(x,p=2)euclidean manhattan minkowski chebyshev sorensen 0.12807130 0.35250464 0.12807130 0.06345083 0.17625232 gower soer

22、gel kulczynski_d canberra lorentzian 0.03525046 0.29968454 0.42792793 2.09927095 0.34457827 intersection non-intersection wavehedges czekanowski motyka 0.82374768 0.17625232 3.16657887 0.17625232 0.58812616 kulczynski_s tanimoto ruzicka inner_product harmonic_mean 2.33684211 0.29968454 0.70031546 0.

23、10612245 0.94948528 cosine hassebrook jaccard dice fidelity 0.93427641 0.86613103 0.13386897 0.07173611 0.97312397 bhattacharyya hellinger matusita squared_chord squared_euclidean 0.02724379 0.32787819 0.23184489 0.05375205 0.01640226 pearson neyman squared_chi prob_symm divergence 0.16814418 0.3674

24、2465 0.10102943 0.20205886 1.49843905 clark additive_symm kullback-leibler jeffreys k_divergence 0.86557468 0.53556883 0.09652967 0.22015096 0.02922498 topsoe jensen-shannon jensen_difference taneja kumar-johnson 0.05257867 0.02628933 0.02628933 0.02874841 0.62779644 avg 0.20797774 3.3 estimate.prob

25、ability()函数estimate.probability()函数,采用数字计数来计算向量的估计概率。estimate.probability()函数方法实现,目前只有一个方法实现,计算每个值占合计的比率,其实就是一种数据标准归的计算方法。 estimate.probabilityfunction (x, method = empirical) if (!is.element(method, c(empirical) stop(Please choose a valid probability estimation method.) if (method = empirical) retu

26、rn(x/sum(x) environment: namespace:philentropy x1 x2 summary(x2)Min. 1st Qu. Median Mean 3rd Qu. Max.0.0002181 0.0044882 0.0096318 0.0100000 0.0153569 0.0206782# 画散点图 plot(x1,x2)从图中看到,整个数据分布在对角线上,x1为均匀分布生成的向量,x2为x1的估计概率,仅仅做了做数据值域进行了缩放,并没有影响数据的分布变化和线性特征,其实就是对数据做了一个标准化的过程。3.4 lin.cor()函数lin.cor()函数,用来

27、计算两个向量之间的线性相关,或计算矩阵的相关矩阵。函数定义:lin.cor(x, y = NULL, method = pearson, test.na = FALSE)参数列表: x,变量1 y,变量2,与x进行比较 method,相关性算法的名称,默认为pearson距离算法,支持5种算法分为是pearson,pearson2,sq_pearson,kendall,spearman test.na, 检测数据集是否有NA值,不检测为FALSE,计算会快。相关性计算,最大值1为完全正相关,最小值-1为完全负相关,0为不相关。我们来创建数据集,进行相关性的测试。# 创建向量x1,x2,x3 x

28、1 x2 x3 lin.cor(x1,x2)pearson 1 # 判断x1,x3的相关性,pearson 皮尔森相关系数 lin.cor(x1,x3) pearson 0.0852527 # 判断x1,x3的相关性,pearson2 皮尔森非集中的相关系数 lin.cor(x1,x3,method = pearson2) pearson2 0.01537887 # 判断x1,x3的相关性,sq_pearson 皮尔森平方的相关系数 lin.cor(x1,x3,method = sq_pearson)sq_pearson 0.00151915 # 判断x1,x3的相关性,kendall 肯德尔相关系数 lin.cor(x1,x3,method = kendall)kendall 0 # 判断x1,x3的相关性,spearman 斯皮尔曼相关系数 lin.cor(x1,x3,method = spearman)spearman 0 通过lin.cor()函数,可以快速进行线性相关性的验证,非常方便。本文重点介绍了philentropy包,对于距离算法的定义和距离测量的函数的使用。很多的距离算法我也是第一次学习,知识需要积累和总结,本文不完善的内容,后面我们

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1