- 浏览: 423625 次
- 性别:
- 来自: 杭州
文章分类
最新评论
-
Iuranus:
“查询文本的64位simhash code的所有3位以内变化的 ...
我的数学之美系列二 —— simhash与重复信息识别 -
夜的那种黑丶:
博主,请教一个问题,我利用OpenCV3提取得到SIFT特征, ...
JAVA实现的Locality Sensitive Hash -
夜的那种黑丶:
最近要用到这方面的内容,楼主贴出的代码少了一些工具类吧,求一份 ...
JAVA实现的Locality Sensitive Hash -
wang_zhao:
博主您好 ,能否求一份该博文对应源码,在下学生狗一枚,非常感谢 ...
JAVA实现的Locality Sensitive Hash -
qwertykln:
博主,能不能发一份完整代码给我啊,我现在正在学习这个,邮箱:3 ...
JAVA实现的Locality Sensitive Hash
基于统计概率和机器学习的文本分类技术
—— 社区产品机器审核机制
一、现状
目前,所在公司社区类产品(论坛、博客、百科)每天都会接收到大量的垃圾、灌水信息,高峰期16小时内(晚6点以后到第二天9点前)可以达到十万量级。大量的人力、时间被浪费在删除、屏蔽这些重复无用信息上,从而导致无法更好地为客户服务。用人工审核的方式去对抗机器发帖,类似于二战时的“长矛战坦克”。如果继续采用这种方式,正在和未来可能面临的问题主要一下几点:
- 未来版本量增加导致人工审核压力的增大。
- 目前负责版本审核的人员约2-3人/天,基本能保证答案在4-5小时内被审核,但该速度不是令大多数用户满意的
- 对于百科wiki类产品,除了判别是否违禁以外,还有一个需求,就是客户答案是否与问题确实相关。wiki的审核大多牵扯到一个多版本问题。由于审核延迟,可能造成部分答案有多个版本,而后面的用户在回答时不能看到前面用户的版本,故不是在原来答案基础上做修改,造成多个版本质量接近或后面的版本质量不高,被退回影响用户通过率和使用体验;
- 特定任务中部分功能的实现遇到问题。任务中的倒计时功能,由于审核有延迟,不能做自动到时结束,必须人工审核完成后人工手动结束
总结目前产品中常见的垃圾广告主要有以下特点:
- 批量垃圾信息是同几拨人发的,只是内容变来变去,感觉像专门的发帖公司。
- 现在大都采取变换不同ID发帖的方式,导致黑名单方式不可用
- 有些会在帖子标题中加很多符号或标点等分隔符隔断内容,所以之前尝试将他们的热线电话的号码加到违禁词里的办法,效果也不佳;另外还有火星文等样式
目前,了解到同行百科类网站审核情况如下
- 百度知道:先发后审,机器过滤+人工检举
- 搜搜问问:机器审核,能够计算出比较准确的审核时间,基本在5分钟以内
- 百度百科:先审后发,机器过滤+人工审核,人工审核为主,所需时间从几分钟到小时不等,且晚上23:00以后没有审核不生成新版本
- 互动百科:先发后审,人工审核,所需时间平均8小时左右
二、背景
在日常生活中,人们往往进行常识推理,而这种推理通常并不是十分准确的。例如,你看见一个头发潮湿的人走进来,你可能会认为外面下雨了,那你也许错了;如果你在公园里看到一男一女走得很近,你可能会认为他们是情侣,你可能也犯了错误。对结果的预测往往是建立在原有经验积累的基础上,并对现有现象各个特征分别属于某一结果的概率加权。
基于贝叶斯定理的进行分类或决策需要一系列特征向量(即某些东西,它们或存在、或不存在、或部分存在于某个分类中)。比如对于一套可以根据照片识别男女性别的系统,它决策所依赖的特征向量可能就是眼睛、鼻梁、脸庞、发型等;用它正确识别张靓颖的成功率就要高于李宇春,因为后者的许多特征向量的没有明显的倾向性。
对文本过滤来说,特征向量就是某段给定文本的各个词语。贝叶斯决策优于常用敏感词库过滤的一个重要原因在于,它考虑到了文本的上下问环境。我们先考虑简单的情况(不考虑中文分词),以英语为例,假设我们需要一个系统来识别一段包含单词python的文本,究竟应该是属于编程类,还是生物类。首先,我们需要模拟人知识积累的过程,给计算机一些已有的样本进行学习,如下表所示。
文本 | 归类(Bio or Pro) |
Pythons are constrictors that feed on birds and mammals | Bio |
Python was originally developed as a scripting language | Pro |
A 49-ft.-long python was found in China | Bio |
Python has dynamic type system | Pro |
Python with vivid scales | Bio |
An Open source project developed by python | Pro |
…… | …… |
我们统计各特征向量(单词)在各类别(编程类或生物类)中出现的频率,得到类似如下的结果:
词 | Pro | Bio |
dynamic | 0.6 | 0.1 |
constrictor | 0.0 | 0.6 |
long | 0.1 | 0.2 |
source | 0.3 | 0.1 |
and 0.95 | 0.95 | |
…… | …… | …… |
使用足够多的数据进行训练,上表的结果就很有意思。dynamic相对较常出现在编程类的文本中,而constrictor则相对较常出现在生物类的文本中,而source和long就没有那么强的倾向性。另外,像and这些词,它在各类目中出现的频率几乎一样(因为基本每篇文章中都会用到and),所以对于机器学习来说没有任何价值,这类词我们称为“停用词”(stop word),意味着以后在样本训练之前可以将它们去除,从而减少学习时间。几乎每个搜索引擎都会维护一份“停用词表”(stop word list),后面的章节会讲到如何使用它。
在使用贝叶斯分类器之前,让我们先来看看以下定义:
1.Pr(Category):属于某一特定分类的概率,先验概率
2.Pr(Document):某一文本的概率,先验概率,对任一文本,其值均为常量,故此值可以忽略
3.Pr(Category|Document):已知文本A,它属于某一分类的概率,就是我们要求的结果,条件概率、后验概率
4.Pr(Document | Category):某一分类下,文本A可能出现的概率,条件概率、非后验概率
一般的, Pr(Document | Category) = Pr(Word1 | Category) × Pr(Word2 | Category) × ……,例如“Python is a dynamic language”去除停用词 (is、a)后属于编程类的概率即为Pr(python | Pro) × Pr(dynamic | Pro) × Pr(language | Pro), 其中各Pr(Word | Category)的值取自前表。事实上,由于Pr(Word | Category) < 1,文本所包含的单词越多,Pr(Document | Category)的结果就越小。但这并非会影响最后的结果,因为我们使用的是各分类的相对值,例如,判断某一段文字是属于编程类还是生物类,计算的是Pr(Document | Pro)/ Pr(Document | Bio)。
使用贝叶斯分类器本质上就是根据先验概率、条件概率求后验概率的过程,描述为
Pr(Category|Document) = Pr(Document | Category) × Pr(Category) / Pr(Document)
事实上,正如前面所说的,Pr(Document)对所有待测文本都是相同的,而我们又只关心相对值,因此该公式可进一步简化为
Pr(Category|Document) = Pr(Document | Category) × Pr(Category)
计算Pr(Category|Document)所需的两个参数搜可以通过类似的方法训练历史数据得到,并且每次计算机决策、运营手工订正后以及错判投诉的结果又都会被加入到样本库中进行修正和再学习,这就是“有监督的机器学习”。
MicroSoft的工程师在Outlook中就使用了这种机制,并在
http://www.gfi.com/whitepapers/why-bayesian-filtering.pdf
阐述了为什么贝叶斯分类器是最有效的文本过滤算法,同时宣称合理的参数设置和足够丰富的样本能保证99.7%的审核正确率。
它的优点:
1、贝叶斯分类器识别整段代词文本内容。它在检索某些常用垃圾词的同时,也会兼顾那些在正常邮件中出现的词语。例如,并不是每封包含“free”和“cash”的邮件都是垃圾邮件,事实上,如果贝叶斯分类器在文本的其它地方发现了商业术语、公司合同等,还是可能会将它归为正常邮件。贝叶斯分类器考虑了上下文的语境,并智能化地使用概率、词频来权衡各词语,这是它与关键词\敏感词算法相比的最大优势。
2、贝叶斯分类器是完全自适应的 —— 它会从垃圾邮件和正常邮件不断地学习、抽取知识,甚至会在对抗中成长 —— 随着新出现的垃圾邮件而进化。比如专业的spammer使用“f-r-e-e”来代替“free”,或是使用“5ex”来代替“sex”,来逃避敏感词库的过滤。对于贝叶斯分类器来说,刚开始它从未见过这个单词,因此可能会将其归为“unknown”;但随着人工审核的复查,它会很快学习到这是个垃圾词。以后,spammer在垃圾帖中使用“f-r-e-e”的效果甚至还不如使用“free”,因为“f-r-e-e”几乎不会出现在正常邮件中,因此分类器更有自信将其归为垃圾邮件(useful/spam的比率更高)。
3、贝叶斯分类会分析用户的行为,更适合与定制化需求。例如对于一家经营五金的公司来说,“mortgage“ 几乎以为着垃圾邮件,但对于一家金融服务公司来说,它很有肯能是正常邮件(起码是”unknown”的) 。
4、贝叶斯分类器与敏感词相比,更适合国际化\多语言。事实上,要维护一份敏感词库十分困难,需要专业人士的参与。贝叶斯分类器采用自然语言分类的方式,某个词语属于垃圾邮件/正常邮件的概率完全由日常的行为所决定,即使是中英文混合的内容,也照常处理。
5、基于贝叶斯分类器的文本过滤机制较难被绕过 。一位高级的 spammer 想要绕过它,无非两种方法,较少采用强垃圾邮件倾向的词(比如free, Viagra等),或是较多采用强正常邮件倾向的词语。一般来说,采用后者较为困难,因为需要了解收件方公司的详细业务,而采用一些中性词(比如public等)对最后的结果有影响甚微。
6、不需要维护、下载、更新敏感词库,贝叶斯分类器是完全可以自循环的
它的缺点:
1、唯一的缺点是需要原始数据的进行学习/训练,或是需要运行一段时间才能看出效果。随着时间的推移,不同于其它静态技术,贝叶斯分类器会越来越有效,因此之前花一段时间等待是完全值得的,正如《基督山伯爵》结语,“人类最伟大的智慧,在于等待和希望”……
三、原型设计
初步写了个原型,想测试一下效果,(无接口、无抽象、单类、命名不规范、无注释,汗),详细过程不说了,有兴趣的可参考附件。
首先给出五个训练样本:
cf.train("Nobody owns the water", "good");
cf.train("the quick rabbit jumps fences", "good");
cf.train("buy pharmaceuticals now", "bad");
cf.train("make quick money at the online casino", "bad");
cf.train("the quick brown fox jumps", "good");
接下来,我们试一下“make quick money at the online casino“的效果
cf.prob("make quick money at the online casino", "good")
cf.prob("make quick money at the online casino", "bad")
输出结果分别是0.0013183593749999999和0.00625,这并没有显示出贝叶斯分词的优势,毕竟这段文本在以前出现过。如果我们将文本修改为“make quick money, visit XXX.htm“
cf.prob("make quick money, visit XXX.htm ", "good")
cf.prob("make quick money, visit XXX.htm ", "bad")
输出结果分别是0.005859375和0.0125。由于分类器从未见过visit、XXX.htm等词语,因此它也不是非常确定这是一条垃圾文本,如果我们通过人工审核将其加入训练库
cf.train("make quick money, visit XXX.htm ", "bad");
下一次,如果接收到文本“make quick money , visit YYY.htm, earn dollars“,分类器将会毫不犹豫地将它划分为垃圾邮件(good:4.1232638888888883E-4;bad:0.004199620627572015)。
前面提过的都是英文文本的识别。对于中文,则要考虑分词器的影响。这里选用MMAnalyzer,建议使用最大正向匹配方式(细粒度为零),因为“人民”和“人民币”是两个不同的概念。对“2008年前三季度,美国次贷危机升级,全球金融持续动荡,世界经济增长全面放缓,全球经济增长动力减弱,世界主要经济体与新兴市场正面临巨大的外部冲击。“ 的分词效果还是比较理想的。
2008] [年前] [三季度] [美国] [次] [贷] [危机] [升级] [全球] [金融] [持续] [动荡] [世界经济] [增长] [全面] [放] [缓] [全球] [经济] [增长] [动力] [减弱] [世界] [主要] [经济] [体] [新兴] [市场] [正] [面临] [巨大] [外部] [冲击]
我们采用生意经中的数据来模拟,锁定“机票“这一关键词
cf.train( " 网上预定了飞机票,请问具体付款流程的怎样的" , "good");
cf.train( "请问高手们,如何开办一家预定销售机票的公司?谢谢" , "good");
cf.train( "中国民航全国统一订票(销售)热线" , "bad");
cf.train( "杭州到上海机票预定热线是多少?" , "bad");
cf.train( "机票预定热线是多少?" , "bad");
cf.train( "特价机票预定方法有哪些?" , "good");
cf.train( "东方航空特价机票:400+6918118" , "bad");
cf.train( "携程机票预定中心:400.6888.932" , "bad");
cf.train( "机票销售代理" , "bad");
假设我们新接收一条文本“广州到青岛机票预定热线是多少?“,贝叶斯分类器将其判定为垃圾文本(bad:0.010416666666666666;good:0.0010363520408163264)
假设我们新接收一条文本“预定国内机票具体应该注意那些问题?“,贝叶斯分类器将其判定为正常文本(bad:0.003348214285714286;good:0.005181760204081632)
考虑大多数的情况下,可以原谅几篇广告文本绕过审核,却无法忍受一篇有效文本被过滤,因此特别维护一个thresholds的HashMap,比如当bad/good > 3时才判定,该文本为垃圾广告。比如“预定国内机票应该怎么做?”,贝叶斯分类器将其判定为unknown(未知)(bad:0.013392857142857144;good:0.012436224489795918),因为3 > bad/good > 1。运营人员在审核unknown的文本时,发觉这是一条正常文本,因此将其加入训练库
cf.train( "预定国内机票应该怎么做?" , "good");
下一次,再接收到类似文本比如“预定国内机票怎么操作?”,分类器将会自动将其归类为正常邮件(bad:0.006054687499999999;good:0.018951416015625)。
四、初步架构
五、展望
1、自然语义(主、谓、宾)的引入
2、将标题、内容、副标题、相关类目的文本内容作为权值引入
3、非文本因素的引入(id、ip、web行为)
4、论坛、博客、百科等词库共享
六、参考文献
1、《垃圾信息相关范例和情况》
2、《每日审核战报》
3、http://www.gfi.com/whitepapers/why-bayesian-filtering.pdf
4、《Programming Collective Intelligence,Building Smart Web 2.0》 Toby Segaran
5、《Collective Intelligence in Action》 Satnam Alag
6、http://nlp.stanford.edu/IR-book/html/htmledition/naive-bayes-text-classification-1.html
7、http://www.emis.de/journals/GM/vol14nr4/pop/pop.pdf
8、http://mathforum.org/~ken/bayes/bayes.html
发表评论
-
使用opencv作物件识别(三) —— 训练数据
2011-04-26 15:50 0对于前面所计算得到的HOG特征,我们采用现在比较流行的SVM来 ... -
使用opencv作物件识别(一) —— 积分直方图加速HOG特征计算
2011-04-26 09:45 16294方向梯度直方图(Histograms of Oriented ... -
使用opencv作物件识别(二) —— HOG特征的计算
2011-04-25 14:54 0关于HOG检测中的一些名词解释,参考下面的说明: ... -
【翻译】Seeing With OpenCV - Part 1: Introduction to OpenCV
2011-04-19 14:24 4845本文翻译自Robin Hewitt的 ... -
我的数学之美(三) —— 使用支持向量机进行预测
2011-04-09 18:20 8177现实生活中充满着预测问题,即对未知世界的大胆猜测。我们基于什么 ... -
一个运用SVM进行回归的例子
2011-04-08 11:29 7831#include "cv.h" #inc ... -
黄色-图片识别引擎
2011-04-04 16:45 7000黄色-图片自动识别是一 ... -
黄色-图片识别引擎的一些心得
2011-04-02 17:49 9364黄色-图片自动识别是一个涉及到图像处理、模式识别、机器学习、统 ... -
使用标签云扩展自己的应用
2011-03-23 21:50 1613标签云或文字云是关键词的视觉化描述,用于汇总用户生成的标签或一 ... -
Pascal VOC Challenge —— 图像识别与物件分类的挑战
2011-03-22 13:35 27214在计算视觉的领域中,Pascal VOC Challenge ... -
我的数学之美(一)——RANSAC算法详解
2011-03-14 12:53 101823给定两个点p1与p2的坐标 ... -
JAVA实现的Locality Sensitive Hash
2011-03-07 11:36 8542我在之前的博客已大致介绍了LSH的原理及其的适用场景,有兴趣的 ... -
漫谈计算机视觉
2011-02-22 17:27 2898从输入图象到信息获取之间存在着巨大的认知空白,其间需要经过一系 ... -
Standard Kmean Cluster的实现[Java]
2011-02-17 13:56 5599Kmean Cluster是一种机器学习中常用的无监督分析方法 ... -
使用tesseract-ocr破解网站验证码
2011-02-12 10:24 41753首先我得承认,关注tesseract-ocr, 是冲着下面这篇 ... -
利用贝叶斯制定反垃圾邮件策略
2011-02-12 09:48 0目前,我正在将词袋模型应用于机器视觉&物体识别,这个会 ... -
视觉特征抽取算法——SURF
2010-12-27 13:34 4955目前公司PF系统(违禁图片机器审核)运营尚存在一些问题,主要包 ... -
互联网相似图像识别检索引擎 —— 基于图像签名的方式
2010-11-29 14:06 9706一、引言 多媒体识别 ...
相关推荐
预研目标的设定应基于对市场需求和技术发展可能性的预测,旨在发现具有潜力的新技术或产品概念。 接下来,报告详细列出了在预研过程中取得的工作成果,这可能包括初步的研发原型、研究报告、专利申请等。这些成果...
技术预研的启动准则包括项目的需求和约束、技术预研的目的和范围、技术预研的输入和输出等。技术预研的启动准则是技术预研活动的基础,确保技术预研活动的正确性和有效性。 技术预研的输入 技术预研的输入包括项目...
ARToolKit技术预研报告详尽探讨了增强现实(AR)技术的核心概念、技术状态、特性、应用领域以及ARToolKit这一开源库的详细介绍。增强现实(AR)是一种融合现实世界与虚拟信息的技术,它通过计算机图形学和可视化手段...
《项目管理技术预研报告模板》是一份针对项目管理中技术预研阶段的重要参考资料,它旨在为项目团队提供一个清晰、规范的框架,以便于系统地进行技术预研工作,确保项目的顺利启动和实施。这份报告通常包含了项目背景...
基于Web打印、打印预览技术预研报告.doc
- 预研完成后,需要提交的技术报告、原型、测试结果或其他形式的证明材料,以展示预研的成果和价值。 6. **进度表** - 使用项目管理工具如Microsoft Project制定详细的预研进度表,明确各个阶段的开始和结束时间...
本资源包——"IT项目管理表单大全-技术预研篇(10个文档)"提供了全面的工具和模板,帮助项目经理和团队高效地进行技术预研工作。 首先,技术预研是项目启动阶段的核心活动,通过这个过程,团队可以对新技术、新...
**软件项目技术预研报告**是项目管理中的关键文档,其主要目的是为项目干系人、决策者和团队成员提供关于技术预研活动的详细信息和结论,以便于制定明智的决策并规划项目的后续步骤。以下是对报告主要内容的详细解释...
### 工作流引擎Activiti预研报告 #### 一、引言 ##### 1.1 背景 随着企业信息化建设的不断深入和发展,业务流程自动化的需求日益凸显。工作流作为企业管理的重要组成部分,其高效性和灵活性对于提高企业的运作...
【软件技术预研报告模板】是软件开发过程中一个至关重要的环节,它为项目的前期规划提供了必要的技术信息和决策依据。这份报告通常包含了对潜在技术的深入研究,旨在探索和评估新技术的可能性、适用性以及可能带来的...
### ARToolkit技术预研报告知识点概述 #### 一、增强现实(AR)基本概念 - **定义**: 增强现实(Augmented Reality,简称AR)是一种通过计算机技术将虚拟信息与真实世界相结合的技术,使用户能够在真实环境中看到...
《XXX项目》技术预研报告,作为一份专业的软件开发过程控制文档,不仅对技术背景进行了深入的分析和研究,还对项目的后续开展提供了明确的技术方向和决策依据。 报告的撰写首要考虑的是目的性。通过阐明预研的目的...
《XXX技术预研计划》是项目管理中的一个重要文档模板,主要针对即将进行的技术探索和研究活动进行规划和安排。这份文档通常包含以下几个关键部分: 1. **技术预研目标**: - 这一部分需要清晰地定义技术预研的目标...
预研项目分为技术预研和产品预研,它们都是为了在市场竞争中抢占先机,通过探索新技术或新产品的可行性,为企业长远发展奠定基础。 一、产品预研 产品预研主要在市场需求不明朗或技术难度大的情况下进行,旨在验证...
这份报告将为产品改进提供依据,并作为项目进度和技术决策的重要参考。 综上所述,"预研产品测试数据"涉及了硬件产品开发的多个关键环节,从测试方法到数据分析,每个步骤都对产品的最终质量和市场竞争力产生直接...
总的来说,"IMS终端预研"报告深入研究了IMS技术在移动终端上的应用,通过对国际标准的解析、系统发展的分析以及业务需求的描述,为行业内的开发者和技术决策者提供了全面的参考,推动了IMS技术在4G LTE网络环境下的...
这套代码是对SuperObjects 6R.net进行技术预研,测试开发过程中使用的,基本上全面覆盖了SuperObjects 6R.net的Map组件,数据组件,数据转换组件,空间分析组件,以及版本管理等GIS高级应用,对研究和测试超图GIS...
输出包括技术预研报告、专利申请、技术原型、合作意向书等,为后续的研发和产品开发提供基础。 10.2.7 结束准则 预研项目的结束通常基于以下情况: - 达到预期目标,确认技术可行性和商业价值。 - 发现技术不可行,...
撰写技术预研报告是技术预研的第三步,目的是将技术预研的结果记录下来,以便于企业的决策。 输出是技术预研的结果部分。输出包括技术预研报告、技术规范、技术标准等信息。这些信息将会被用于企业的决策和技术的...