博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
TF-IDF原理及使用
阅读量:6984 次
发布时间:2019-06-27

本文共 4632 字,大约阅读时间需要 15 分钟。

hot3.png

一. 什么是TF-IDF

TF-IDF(Term Frequency-Inverse Document Frequency, 词频-逆文件频率).

是一种用于资讯检索与资讯探勘的常用加权技术。TF-IDF是一种统计方法,用以评估一字词对于一个文件集或一个语料库中的其中一份文件的重要程度。字词的重要性随着它在文件中出现的次数成正比增加,但同时会随着它在语料库中出现的频率成反比下降。

上述引用总结就是, 一个词语在一篇文章中出现次数越多, 同时在所有文档中出现次数越少, 越能够代表该文章.

这也就是TF-IDF的含义.

词频 (term frequency, TF) 指的是某一个给定的词语在该文件中出现的次数。这个数字通常会被归一化(一般是词频除以文章总词数), 以防止它偏向长的文件。(同一个词语在长文件里可能会比短文件有更高的词频,而不管该词语重要与否。)

但是, 需要注意, 一些通用的词语对于主题并没有太大的作用, 反倒是一些出现频率较少的词才能够表达文章的主题, 所以单纯使用是TF不合适的。权重的设计必须满足:一个词预测主题的能力越强,权重越大,反之,权重越小。所有统计的文章中,一些词只是在其中很少几篇文章中出现,那么这样的词对文章的主题的作用很大,这些词的权重应该设计的较大。IDF就是在完成这样的工作.

公式:

 

TFw=在某一类中词条w出现的次数该类中所有的词条数目

逆向文件频率 (inverse document frequency, IDF) IDF的主要思想是:如果包含词条t的文档越少, IDF越大,则说明词条具有很好的类别区分能力。某一特定词语的IDF,可以由总文件数目除以包含该词语之文件的数目,再将得到的商取对数得到。

 

公式:

IDF=log(语料库的文档总数包含词条w的文档数+1),分母之所以要加1,是为了避免分母为0

 

  某一特定文件内的高词语频率,以及该词语在整个文件集合中的低文件频率,可以产生出高权重的TF-IDF。因此,TF-IDF倾向于过滤掉常见的词语,保留重要的词语。

  

TFIDF=TFIDF

 

二. 一个实例

参考:

这里写图片描述

三. Spark 中 TF-IDF 的实现

1. 基于spark1.4.1 ml算法包的TF-IDF算法

// 参考自spark官网教程 http://spark.apache.org/docs/latest/ml-features.html#tf-idf// In the following code segment, we start with a set of sentences. // We split each sentence into words using Tokenizer. For each sentence (bag of words),// we use HashingTF to hash the sentence into a feature vector. We use IDF to rescale// the feature vectors; this generally improves performance when using text as features. // Our feature vectors could then be passed to a learning algorithm.import org.apache.spark.{SparkContext, SparkConf}import org.apache.spark.ml.feature.{Tokenizer,HashingTF, IDF}import org.apache.spark.mllib.linalg.{Vectors, Vector}// 创建实例数据val sentenceData = sqlContext.createDataFrame(Seq(  (0, "Hi I heard about Spark"),  (0, "I wish Java could use case classes"),  (1, "Logistic regression models are neat"))).toDF("label", "sentence")//  scala> sentenceData.show//  +-----+--------------------+//  |label|            sentence|//  +-----+--------------------+//  |    0|Hi I heard about ...|//  |    0|I wish Java could...|//  |    1|Logistic regressi...|//  +-----+--------------------+//句子转化成单词数组val tokenizer = new Tokenizer().setInputCol("sentence").setOutputCol("words")val wordsData = tokenizer.transform(sentenceData)// scala> wordsData.show//  +-----+--------------------+--------------------+//  |label|            sentence|               words|//  +-----+--------------------+--------------------+//  |    0|Hi I heard about ...|ArrayBuffer(hi, i...|//  |    0|I wish Java could...|ArrayBuffer(i, wi...|//  |    1|Logistic regressi...|ArrayBuffer(logis...|//  +-----+--------------------+--------------------+// hashing计算TF值,同时还把停用词(stop words)过滤掉了. setNumFeatures(20)表最多20个词val hashingTF = new HashingTF().setInputCol("words").setOutputCol("rawFeatures").setNumFeatures(20)val featurizedData = hashingTF.transform(wordsData)// scala> featurizedData.show//  +-----+--------------------+--------------------+--------------------+//  |label|            sentence|               words|         rawFeatures|//  +-----+--------------------+--------------------+--------------------+//  |    0|Hi I heard about ...|ArrayBuffer(hi, i...|(20,[5,6,9],[2.0,...|//  |    0|I wish Java could...|ArrayBuffer(i, wi...|(20,[3,5,12,14,18...|//  |    1|Logistic regressi...|ArrayBuffer(logis...|(20,[5,12,14,18],...|//  +-----+--------------------+--------------------+--------------------+val idf = new IDF().setInputCol("rawFeatures").setOutputCol("features")val idfModel = idf.fit(featurizedData)val rescaledData = idfModel.transform(featurizedData)// 提取该数据中稀疏向量的数据,稀疏向量:SparseVector(size,indices,values)// rescaledData.select("features").rdd.map(row => row.getAs[linalg.Vector](0)).map(x => x.toSparse.indices).collectrescaledData.select("features", "label").take(3).foreach(println)//  [(20,[5,6,9],[0.0,0.6931471805599453,1.3862943611198906]),0]//  [(20,[3,5,12,14,18],[1.3862943611198906,0.0,0.28768207245178085,0.28768207245178085,0.28768207245178085]),0]//  [(20,[5,12,14,18],[0.0,0.5753641449035617,0.28768207245178085,0.28768207245178085]),1]// 其中,20是标签总数,下一项是单词对应的hashing ID.最后是TF-IDF结果

2.基于RDD的MLlib包中的TF_IDF算法

//参考: http://spark.apache.org/docs/1.4.1/mllib-feature-extraction.html#tf-idfark.mllib.feature.HashingTF//进阶参考//http://blog.csdn.net/jiangpeng59/article/details/52786344import org.apache.spark.mllib.linalg.Vectorval sc: SparkContext = ...// Load documents (one per line).val documents: RDD[Seq[String]] = sc.textFile("...").map(_.split(" ").toSeq)val hashingTF = new HashingTF()val tf: RDD[Vector] = hashingTF.transform(documents)tf.cache()val idf = new IDF().fit(tf)val tfidf: RDD[Vector] = idf.transform(tf)

四. 参考

转载于:https://my.oschina.net/airship/blog/1807403

你可能感兴趣的文章
hashCode()方法(覆盖hashCode()方法)
查看>>
端口号查询
查看>>
docker 安装 nginx
查看>>
wince RAS
查看>>
AdaBoost 和 Real Adaboost 总结
查看>>
Vue.js学习
查看>>
C语言中变量的理解
查看>>
oracle spfile和pfile文件
查看>>
java内存分配
查看>>
897A. Scarborough Fair# 斯卡布罗集市(模拟)
查看>>
创建数据库指定编码集
查看>>
xcode快速开发 代码块
查看>>
深入理解display属性
查看>>
2005 TCO Online Round 1 - RectangleError
查看>>
看博客学学Android(五)
查看>>
CentOS 7 安装MySQL 5.6遇到问题及解决方案
查看>>
Eclipse 一直Building Workspace 的解决办法
查看>>
ThinkPHP笔记——完全配置参考手册
查看>>
BZOJ1503[NOI2004]郁闷的出纳员——treap
查看>>
asp.net mvc的初学
查看>>