TF-IDF与余弦类似性的应用(一):自己主动提取关键词
这个标题看上去好像非常复杂,事实上我要谈的是一个非常easy的问题。
有一篇非常长的文章,我要用计算机提取它的关键词(Automatic Keyphrase extraction),全然不加以人工干预,请问如何才干正确做到?

这个问题涉及到数据挖掘、文本处理、信息检索等非常多计算机前沿领域,可是出乎意料的是,有一个非常easy的经典算法,能够给出令人相当惬意的结果。
它简单到都不须要高等数学。普通人仅仅用10分钟就能够理解,这就是我今天想要介绍的TF-IDF算法。
让我们从一个实例開始讲起。假定如今有一篇长文《中国的蜜蜂养殖》,我们准备用计算机提取它的关键词。

一个easy想到的思路,就是找到出现次数最多的词。
假设某个词非常重要。它应该在这篇文章中多次出现。于是。我们进行"词频"(Term Frequency,缩写为TF)统计。
结果你肯定猜到了。出现次数最多的词是----"的"、"是"、"在"----这一类最经常使用的词。它们叫做"停用词"(stop words)。表示对找到结果毫无帮助、必须过滤掉的词。
如果我们把它们都过滤掉了,仅仅考虑剩下的有实际意义的词。这样又会遇到了还有一个问题。我们可能发现"中国"、"蜜蜂"、"养殖"这三个词的出现次数一样多。这是不是意味着,作为关键词,它们的重要性是一样的?
显然不是这样。
由于"中国"是非经常见的词,相对而言,"蜜蜂"和"养殖"不那么常见。假设这三个词在一篇文章的出现次数一样多,有理由觉得,"蜜蜂"和"养殖"的重要程度要大于"中国",也就是说。在关键词排序上面,"蜜蜂"和"养殖"应该排在"中国"的前面。
所以。我们须要一个重要性调整系数,衡量一个词是不是常见词。假设某个词比較少见,可是它在这篇文章中多次出现,那么它非常可能就反映了这篇文章的特性,正是我们所须要的关键词。
用统计学语言表达,就是在词频的基础上。要对每一个词分配一个"重要性"权重。最常见的词("的"、"是"、"在")给予最小的权重,较常见的词("中国")给予较小的权重。较少见的词("蜜蜂"、"养殖")给予较大的权重。这个权重叫做"逆文档频率"(Inverse Document Frequency,缩写为IDF)。它的大小与一个词的常见程度成反比。
知道了"词频"(TF)和"逆文档频率"(IDF)以后,将这两个值相乘,就得到了一个词的TF-IDF值。某个词对文章的重要性越高,它的TF-IDF值就越大。
所以,排在最前面的几个词,就是这篇文章的关键词。
以下就是这个算法的细节。
第一步,计算词频。

考虑到文章有长短之分,为了便于不同文章的比較。进行"词频"标准化。

或者

第二步。计算逆文档频率。
这时。须要一个语料库(corpus),用来模拟语言的使用环境。

假设一个词越常见,那么分母就越大。逆文档频率就越小越接近0。分母之所以要加1。是为了避免分母为0(即全部文档都不包括该词)。log表示对得到的值取对数。
第三步,计算TF-IDF。

能够看到。TF-IDF与一个词在文档中的出现次数成正比,与该词在整个语言中的出现次数成反比。所以,自己主动提取关键词的算法就非常清楚了。就是计算出文档的每一个词的TF-IDF值,然后按降序排列,取排在最前面的几个词。
还是以《中国的蜜蜂养殖》为例。假定该文长度为1000个词,"中国"、"蜜蜂"、"养殖"各出现20次,则这三个词的"词频"(TF)都为0.02。然后。搜索Google发现,包括"的"字的网页共同拥有250亿张。假定这就是中文网页总数。
包括"中国"的网页共同拥有62.3亿张,包括"蜜蜂"的网页为0.484亿张,包括"养殖"的网页为0.973亿张。则它们的逆文档频率(IDF)和TF-IDF例如以下:

从上表可见,"蜜蜂"的TF-IDF值最高,"养殖"其次。"中国"最低。
(假设还计算"的"字的TF-IDF,那将是一个极其接近0的值。)所以。假设仅仅选择一个词,"蜜蜂"就是这篇文章的关键词。
除了自己主动提取关键词,TF-IDF算法还能够用于很多别的地方。比方。信息检索时,对于每一个文档,都能够分别计算一组搜索词("中国"、"蜜蜂"、"养殖")的TF-IDF,将它们相加,就能够得到整个文档的TF-IDF。这个值最高的文档就是与搜索词最相关的文档。
TF-IDF算法的长处是简单高速。结果比較符合实际情况。缺点是,单纯以"词频"衡量一个词的重要性。不够全面,有时重要的词可能出现次数并不多。并且,这样的算法无法体现词的位置信息,出现位置靠前的词与出现位置靠后的词。都被视为重要性同样。这是不对的。
(一种解决方法是,对全文的第一段和每一段的第一句话,给予较大的权重。
)
下一次,我将用TF-IDF结合余弦相似性,衡量文档之间的相似程度。
(完)
TF-IDF与余弦类似性的应用(一):自己主动提取关键词的更多相关文章
- TF/IDF(term frequency/inverse document frequency)
TF/IDF(term frequency/inverse document frequency) 的概念被公认为信息检索中最重要的发明. 一. TF/IDF描述单个term与特定document的相 ...
- 基于TF/IDF的聚类算法原理
一.TF/IDF描述单个term与特定document的相关性TF(Term Frequency): 表示一个term与某个document的相关性. 公式为这个term在document中出 ...
- 使用solr的函数查询,并获取tf*idf值
1. 使用函数df(field,keyword) 和idf(field,keyword). http://118.85.207.11:11100/solr/mobile/select?q={!func ...
- TF/IDF计算方法
FROM:http://blog.csdn.net/pennyliang/article/details/1231028 我们已经谈过了如何自动下载网页.如何建立索引.如何衡量网页的质量(Page R ...
- tf–idf算法解释及其python代码实现(下)
tf–idf算法python代码实现 这是我写的一个tf-idf的简单实现的代码,我们知道tfidf=tf*idf,所以可以分别计算tf和idf值在相乘,首先我们创建一个简单的语料库,作为例子,只有四 ...
- tf–idf算法解释及其python代码实现(上)
tf–idf算法解释 tf–idf, 是term frequency–inverse document frequency的缩写,它通常用来衡量一个词对在一个语料库中对它所在的文档有多重要,常用在信息 ...
- 文本分类学习(三) 特征权重(TF/IDF)和特征提取
上一篇中,主要说的就是词袋模型.回顾一下,在进行文本分类之前,我们需要把待分类文本先用词袋模型进行文本表示.首先是将训练集中的所有单词经过去停用词之后组合成一个词袋,或者叫做字典,实际上一个维度很大的 ...
- 信息检索中的TF/IDF概念与算法的解释
https://blog.csdn.net/class_brick/article/details/79135909 概念 TF-IDF(term frequency–inverse document ...
- Elasticsearch学习之相关度评分TF&IDF
relevance score算法,简单来说,就是计算出,一个索引中的文本,与搜索文本,他们之间的关联匹配程度 Elasticsearch使用的是 term frequency/inverse doc ...
随机推荐
- (8) openssl rsautl(签名/验证签名/加解密文件)和openssl pkeyutl(文件的非对称加密)
rsautl是rsa的工具,相当于rsa.dgst的部分功能集合,可用于生成数字签名.验证数字签名.加密和解密文件. pkeyutl是非对称加密的通用工具,大体上和rsautl的用法差不多,所以此处只 ...
- CSS3---关于文本
1.text-overflow用来设置是否使用一个省略标记(...)标示对象内文本的溢出. 2.但是text-overflow只是用来说明文字溢出时用什么方式显示,要实现溢出时产生省略号的效果,还须定 ...
- fit in gnuplot
Table of Contents 1. fit-gnuplot 1 fit-gnuplot syntax >> fit [xrange][yrange] function 'datafi ...
- 杭电 5326 Work (并查集求子结点为k的结点数)
Description It’s an interesting experience to move from ICPC to work, end my college life and start ...
- LR性能测试问题解决方法
一.Error -27727: Step download timeout (120 seconds)has expired when downloading resource(s). Set the ...
- iOS第三方语音-微信语音
网址链接:http://pr.weixin.qq.com/ 里面包含了微信语音和图像,集成很简单,下载方demo后会有个文档,按照流程来(因为它只提供了真机的.a文件,所以只能用真机哦,不然会报错) ...
- java web 项目常用框架
java框架实在是太多了,网上一搜索一大箩筐,根本就了解不到什么. 我还是以我的经验来说一下j2ee的框架. 1.首先力推struts2框架,这是最经典的框架(可以说没有“之一”).可以帮你快速搭建出 ...
- [转]Android SDK下载和更新失败的解决方法
今天更新sdk,遇到了更新下载失败问题: Fetching https://dl-ssl.google.com/android/repository/addons_list-2.xmlFetched ...
- Atlantis(hdu1542)
题意:求n个矩阵的面积并. /* 线段树维护扫描线 把每个矩形看成两条线段,从左到右添加线段,如果是矩形左边的线段,那就给线段所在的区间(y值)cover+1,反之则cover-1. 并且如果这条线段 ...
- 「CodePlus 2018 3 月赛」白金元首与克劳德斯
所有的云在此时没有重叠的面积 所有的云在此时没有重叠的面积 所有的云在此时没有重叠的面积 所有的云在此时没有重叠的面积 所有的云在此时没有重叠的面积 所有的云在此时没有重叠的面积 所有的云在此时没有重 ...