TF-IDF

1.    概念

 

2.    原理

 

3.    java代码实现思路

数据集:
 
三个MapReduce
第一个MapReduce:(利用ik分词器,将一篇博文,也就是一条记录中的content进行词的拆分)
    第一个MapReduce最终运行的结果:
                                   1. 得到数据集中微博的总数
                                   2. 得到每个词在当前所属微博的TF值 
       
   Mapper端:key:LongWritable(偏移量)   value:3823890314914825    今天天气晴好,姐妹们约起,一起去逛街。
                                  步骤一:拆分读取(按照'\t'), 得到id, content    
                                  步骤二:利用ik分词器对内容进行分词(今天,天气,姐妹),遍历分词结果,对分词结果中的每一个             词输出(w_id, 1) 
                                  步骤三:当对内容进行遍历完成之后,记录当前这一条微博,输出(count,1)
 
   第一个MR自定义分区:extends HashPartitioner<Text, IntWritable>,重写getPartition
                                  默认的分区规则:key.hash()%reduce的个数
                                  这里对key的值进行判断,如果key.equals("count"),交给最后一个reduce,否则,交给reduceCount-1
                            
   Reducer端:第一种--key:w_id   value:{1,1,1}     第二种--key:count   value{1,1,1.....}
                                  步骤一:将经过shuffle过程后的数据,进行整合(key相同的值为一组,对迭代器中的值进行遍历)
                                  步骤二:将reduce后的结果进行写出,context.write(key, new IntWritable(sum))
                                                 !注意  
                                                           因为这里在FirstJob中设置了Reduce的个数 (job.setNumReduceTasks(4)),所以最后会有                                                              四个文件输出,而key=count又指定了Reduce,所以key:count   value{1,1,1.....}在最后一个文                                                                件,key:w_id   value:{1,1,1}在前三个文件   
       
第二个MapReduce:   从第一个MapReduce输出的结果中读取,作为本次的输入
   第二个MapReduce最终运行的结果:
                                   1. 得到每一个词在数据集中多少条微博中出现过,即DF值 
 
   Mapper端:key:LongWritable(偏移量)   value:今天_3823890314914825   2
                                  步骤一:获取当前mapper task的数据片段(split),根据FlieSplit的所属文件名进行判断,保证不是最后一个文 件(因为最后一个文件的内容是count 1075
                                  步骤二:这时mapper端输入的value值是今天_3823890314914825   2 
对数据处理,按照“\t”切割,再按照“_”切割,输出context.write(今天,1)//注意这里将要统计的是包含今天的文件总数,所以不关注微博id
 
   Reducer端:key:w  value:{1,1,1}     数据样例:key=今天,value={1,1,1,1,1}  //每一个1表示数据集中有一条微博包含今天这个词
                                  步骤一:将经过shuffle过程后的数据,进行整合(key相同的值为一组,对迭代器中的值进行遍历)
                                  步骤二:将reduce后的结果进行写出,context.write(key, new IntWritable(sum))
   
   经过第二个MapReduce操作后,就获得了每一个词的df(document frequency)值   
                                        
第三个MapReduce:   目的-->计算TF*IDF值
   第三个MapReduce最终运行的结果:
                                   1. 得到每一条微博中,每个词的TF-IDF值
                                   结果样例:{3823890314914825 今天:2.78834   逛街:3.98071   姐妹:1.98712}
        技巧:
                第一个MapReduce输出的第四个文件(count  1075),计算每一个单词的TF-IDF值都需要用到,所以将这个文件在job运  时加载到内存中以提高运行效率
                第二个MapReduce输出的文件-->每一个单词在数据集中多少条微博出现过,即df值(今天  5),因为它里面包括常用的词  汇,不同于数据集,并不是很大也可以加载到内存,提高程序的执行效率

        1. // 把微博总数加载到内存
  1. job.addCacheFile(newPath("/user/tfidf/output/weibo1/part-r-00003")
  2. .toUri());
  3. // 把df加载到内存
  4. job.addCacheFile(newPath("/user/tfidf/output/weibo2/part-r-00000")
  5. .toUri());
 
   Mapper端:key:LongWritable(偏移量)   value:今天_3823890314914825   2
                                  步骤一:在正式执行map方法之前先执行setup(Context context)方法
                                                 目的:将加载到内存中的微博总数,以及DF值,封装到Map对象中(cmap,df),便于map的操作
                                  步骤二:开始执行map操作,因为mapper端的输入是第一次MapReduce的输出,所以还需要进行判断,是否   是最后一个文件(count,1075)
                                                 对数据处理,按照“\t”切割,得到tf值-->v[1]=2,同时将v[0]按照“_”切割,得到单词(今  天)和微博id(3823890314914825)
                                                 从cmap中获取“count”,从df中获取该单词的df值,在根据该单词的tf值,计算该单词的TF*IDF值
                                                     double s = tf * Math.log(cmap.get("count") / df.get(w));
                                   步骤三:将数据输出,key=微博的id,value=(w:tf*idf值)
 
   Reducer端:key=微博的id, value=(w:tf*idf值)    
                        数据样例:key=3823890314914825,value={今天:2.89101, 逛街:3.08092}
 
                                   步骤一:将经过shuffle过程后的数据,进行整合(key相同的值为一组,对迭代器中的值进行遍历,定义StringBuffer,对迭代器中每一个单词以及对应的TF*IDF值拼接
                                   步骤二:将reduce后的结果进行写出,context.write(key, new Text(sb.toString()))
 

4.    商家如何做到精准营销?

    经过以上过程,我们拿到的最终数据是3823890314914825  {今天:2.89101, 逛街:3.08092},即每一条微博中每个词的TF*IDF值
    比如韩国料理要推送大骨汤,这时候只需要对数据集中的每一条微博中的每一个词对应的TFIDF值做一个降序,然后取前3位,
对整个数据集中的数据遍历,凡是TF*IDF值前三位包含大骨汤的,就是商家要推送的对象
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

 

TF-IDF_MapReduceJava代码实现思路的更多相关文章

  1. ItemCF_基于物品的协同过滤_MapReduceJava代码实现思路

    ItemCF_基于物品的协同过滤 1.    概念 2.    原理 如何给用户推荐? 给用户推荐他没有买过的物品--103 3.    java代码实现思路 数据集: 第一步:构建物品的同现矩阵 第 ...

  2. PageRank_网页排名_MapReduceJava代码实现思路

    PageRank 1.    概念 2.    原理   3.    java代码实现思路   1.定义收敛标准     每次算出新的pr-oldpr=差值 ,所有页面的差值累加 ,除以pagecou ...

  3. iOS开发:代码通用性以及其规范 第一篇(附带,自定义UITextView\进度条\双表显示\瀑布流 代码设计思路)

    在iOS团队开发中,我见过一些人的代码,也修改过他们的代码.有的人的代码写的非常之规范.通用,几乎不用交流,就可以知道如何修改以及在它基础上扩展延生.有的人的代码写的很垃圾,一眼看过去,简直会怀疑自己 ...

  4. Android版网易云音乐唱片机唱片磁盘旋转及唱片机机械臂动画关键代码实现思路

     Android版网易云音乐唱片机唱片磁盘旋转及唱片机机械臂动画关键代码实现思路 先看一看我的代码运行结果. 代码运行起来初始化状态: 点击开始按钮,唱片机的机械臂匀速接近唱片磁盘,同时唱片磁盘也 ...

  5. PAT 1034 有理数四则运算(20)(代码框架+思路+测试点错误分析)

    1034 有理数四则运算(20)(20 分)提问 本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照"a1/b1 a2/b2"的格式给出两个分数形式的 ...

  6. JS初学之-代码精简思路

    1.差不多的代码,观察其不一样的地方,使用变量存起来,方便替代. 2.将其存入函数之中方便调用.

  7. 「赛后补题」HBCPC2018题目代码与思路简析

    这次比赛(2018年第二届河北省大学生程序设计竞赛)虽然没有打,但是题目还是要写的.未完成的题目(还差比较硬核的四题)和思路分析会陆续更新完. Problem A 2011 Mex Query /* ...

  8. PAT1080 MOOC期终成绩 (25分) ——同样参考了柳婼大神的代码及思路,在自己的代码上做了修改,还是很复杂

    1080 MOOC期终成绩 (25分)   对于在中国大学MOOC(http://www.icourse163.org/ )学习“数据结构”课程的学生,想要获得一张合格证书,必须首先获得不少于200分 ...

  9. JS实现登陆验证的主要代码及思路

    window.onload = function(){ // 获取input标签 var alInput = document.getElementsByTagName("input&quo ...

随机推荐

  1. django xdmin使用

    我们来看看我们原先django给我们自带的admin后台是什么样子的呢 有人说,你的界面怎么那么丑,我说这个还叫丑吗,他说丑,我说你来,我看看你的,上图 看到登录界面后,我说别看了,我去修改,修改,我 ...

  2. springBoot系列教程01:elasticsearch的集成及使用

    1.首先安装elasticsearch 集群环境,参考 http://www.cnblogs.com/xiaochangwei/p/8033773.html 注意:由于我的代码采用的是springbo ...

  3. 理解JavaScript原型

    Javascript原型总会给人产生一些困惑,无论是经验丰富的专家,还是作者自己也时常表现出对这个概念某些有限的理解,我认为这样的困惑在我们一开始接触原型时就已经产生了,它们常常和new.constr ...

  4. java面向对象知识整理(一)

    1.面向对象思想 概述:面向对象是相对于面向过程而言的,面向过程强调的是功能,面向对象强调的是将功能封装进对像,强调具备功能的对象. 特点:(1)符合人们思考习惯的一种思想. (2)将复杂的事情简单化 ...

  5. [js高手之路] es6系列教程 - Map详解以及常用api

    ECMAScript 6中的Map类型是一种存储着许多键值对的有序列表.键值对支持所有的数据类型. 键 0 和 ‘0’会被当做两个不同的键,不会发生强制类型转换. 如何使用Map? let map = ...

  6. HTML + CSS短标题(二,三,四文字长度)两端对齐的方式

    今天切图碰到了一个看似好弄,却并不好弄的文本两端对齐问题.如图1-1

  7. c/c++中static的详解

    C 语言的 static 关键字有三种(具体来说是两种)用途: 1. 静态局部变量:用于函数体内部修饰变量,这种变量的生存期长于该函数. int foo(){ ; // note:1 //int i ...

  8. Spring框架入门之开发环境搭建(MyEclipse2017平台)

    基于MyEclipse2017平台搭建Spring开发环境,这里MyEclipse已将Spring集成好了,我们只需要做一简单配置即可 一.环境配置 OS:Windows7 64位 IDE工具:MyE ...

  9. JavaScript(二)基本概念

    JS区分大小写 html/css 中 标签选择器不区分大小写 id class 选择器区分大小写 其中属性名 属性名 属性值  不区分大小写 行间事件  onclick  等  不区分大小写 而  执 ...

  10. 解决打开png图片黑屏问题(批量还原Xcode优化后的png)

    window 打开Xcode 里面的png图片会黑屏,但是在mac 打开就显示正常, 这是因为Xocde里面的png图片被 pngcrush 优化过了,需要还原它的优化,window 平台才可以打开. ...