溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

spark mllib如何實現(xiàn)TF-IDF

發(fā)布時間:2021-12-16 14:42:45 來源:億速云 閱讀:139 作者:小新 欄目:云計算

這篇文章給大家分享的是有關(guān)spark mllib如何實現(xiàn)TF-IDF的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

運行代碼如下

package spark.FeatureExtractionAndTransformation

import org.apache.spark.mllib.feature.{HashingTF, IDF}
import org.apache.spark.{SparkContext, SparkConf}

/**
  * TF-IDF  是一種簡單的文本特征提取算法
  *  詞頻(Term Frequency): 某個關(guān)鍵詞在文本中出現(xiàn)的次數(shù)
  *  逆文檔頻率(Inverse Document Frequency): 大小與一個詞的常見程度成反比
  *  TF = 某個詞在文章中出現(xiàn)的次數(shù)/文章的總詞數(shù)
  *  IDF = log(查找的文章總數(shù) / (包含該詞的文章數(shù) + 1))
  *  TF-IDF = TF(詞頻) x IDF(逆文檔頻率)
  *  此處未考慮去除停用詞(輔助詞,如副詞,介詞等)和
  *  語義重構(gòu)("數(shù)據(jù)挖掘","數(shù)據(jù)結(jié)構(gòu)",拆分成"數(shù)據(jù)","挖掘","數(shù)據(jù)","結(jié)構(gòu)")
  *  這樣兩個完全不同的文本具有 50% 的相似性,是非常嚴(yán)重的錯誤.
  * Created by eric on 16-7-24.
  */
object TF_IDF {
  val conf = new SparkConf()               //創(chuàng)建環(huán)境變量
    .setMaster("local")                                             //設(shè)置本地化處理
    .setAppName("TF_IDF")                              //設(shè)定名稱
  val sc = new SparkContext(conf)

  def main(args: Array[String]) {
    val documents = sc.textFile("/home/eric/IdeaProjects/wordCount/src/main/spark/FeatureExtractionAndTransformation/a.txt")
      .map(_.split(" ").toSeq)

    val hashingTF = new HashingTF()			//首先創(chuàng)建TF計算實例
    val tf = hashingTF.transform(documents).cache()//計算文檔TF值
    val idf = new IDF().fit(tf)						//創(chuàng)建IDF實例并計算

    val tf_idf = idf.transform(tf) //計算TF_IDF詞頻
    tf_idf.foreach(println)

//    (1048576,[179334,596178],[1.0986122886681098,0.6931471805599453])
//    (1048576,[586461],[0.1823215567939546])
//    (1048576,[422129,586461],[0.6931471805599453,0.1823215567939546])
//    (1048576,[586461,596178],[0.1823215567939546,0.6931471805599453])
//    (1048576,[422129,586461],[0.6931471805599453,0.1823215567939546])
  }
}

a.txt

hello mllib
spark
goodBye spark
hello spark
goodBye spark

結(jié)果如下

spark mllib如何實現(xiàn)TF-IDF

感謝各位的閱讀!關(guān)于“spark mllib如何實現(xiàn)TF-IDF”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI