V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
macg0406
V2EX  ›  机器学习

11 款开放中文分词引擎大比拼

  •  
  •   macg0406 · 2015-11-09 16:30:57 +08:00 · 2573 次点击
    这是一个创建于 3305 天前的主题,其中的信息可能已经有所发展或是发生改变。

    DT ( Data Technology )时代的今天,自然语义分析技术越发不可或缺。对于我们每天打交道的中文来说,并没有类似英文空格的边界标志。而理解句子所包含的词语,则是理解汉语语句的第一步。汉语自动分词的任务,通俗地说,就是要由机器在文本中的词与词之间自动加上空格。
    一提到自动分词,通常会遇到两种比较典型的质疑。一种质疑是来自外行人的:这件事看上去平凡之极,好像一点儿也不“ fancy ”,会有什么用呢?另一种质疑则是来自业内:自动分词研究已经进行了数年,而网上也存在各种不同的开放分词系统,但对于实际商用似乎也未见一个“即插即用”的系统。
    那么,目前常见的开放分词引擎,到底性能如何呢?为了进行测试,我们调研了 11 款网上常见的并且公开提供服务的分词系统,包括:

    序号 分词系统 序号 分词系统
    1 BosonNLP 7 庖丁解牛
    2 IKAnalyzer 8 搜狗分词
    3 NLPIR 9 腾讯文智
    4 SCWS 10 新浪云
    5 结巴分词 11 语言云
    6 盘古分词

    分词的客观量化测试离不开标注数据,即人工所准备的分词“标准答案”。在数据源方面,我们将测试分为:
    1.新闻数据: 140 篇,共 30517 词语;
    2.微博数据: 200 篇,共 12962 词语;
    3.汽车论坛数据(汽车之家) 100 篇:共 27452 词语;
    4.餐饮点评数据(大众点评): 100 条,共 8295 词语。

    准确度计算规则:
    1. 将所有标点符号去除,不做比较
    2. 参与测试的部分系统进行了实体识别,可能造成词语认定的不统一。我们将对应位置替换成了人工标注的结果,得到准确率估算的上界。
    3. 经过以上处理,用 SIGHAN 分词评分脚本比较得到最终的准确率,召回率和 F1 值。

    以上所有数据采用北大现代汉语基本加工规范对所有数据进行分词作为标准。具体数据下载地址请参见附录。通过这四类数据综合对比不同分词系统的分词准确度。

    分词服务 新闻数据 微博数据 汽车论坛 餐饮点评
    IKAnalyzer 74.8% 72.1% 72.7% 68.0%
    盘古分词 80.3% 80.0% 79.1% 76.0%
    腾讯文智 85.7% 86.1% 87.5% 84.8%
    SCWS 87.0% 87.0% 89.9% 86.6%
    结巴分词 87.2% 88.0% 88.5% 87.5%
    搜狗分词 87.5% 84.9% 86.1% 81.2%
    新浪云 88.5% 87.4% 88.3% 85.9%
    NLPIR 91.3% 89.5% 87.2% 84.2%
    语言云 93.7% 92.6% 92.8% 89.1%
    BosonNLP 94.7% 93.3% 94.2% 89.5%

    上面为参与比较的 10 款分词引擎在不同数据的分词准确度结果。可以看出,在所测试的四个数据集上, BosonNLP 和哈工大语言云都取得了较高的分词准确率,尤其在新闻数据上。因为庖丁解牛是将所有可能成词的词语全部扫描出来(例如:“最不满意”分为:“最不 不满 满意”),与其他系统输出规范不同,因而不参与准确率统计。
    为了更直接的比较不同数据源的差别,我们从每个数据源的测试数据中抽取比较典型的示例进行更直观的对比。

    [新闻数据]
    新闻数据的特点是用词规整,符合语法规则,也是普遍做得比较不错的一个领域。对比其他数据源,有 7 家系统都在新闻领域达到最高。包括 IKAnalyzer 、盘古分词、搜狗分词、新浪云、 NLPIR 、语言云、 BosonNLP 。并且有三家系统准确率超过 90%。
    样例:香港 中文 大学 将 来 合肥 一中 进行 招生 宣传 今年 在 皖 招 8 人 万家 热线 安徽 第一 门户

    [微博数据]
    微博数据用词多样、话题广泛,并常包含错别字及网络流行词。能够比较全面的体现每家分词系统的准确度。
    样例:补 了 battle 赛 峰暴班 的 两 个 弟弟 妹妹 @杨宝心 @修儿 一个 是 我 很 挺 的 好 弟弟 一个 是 我 推荐 进 好声音 的 妹子 虽然 都 在 battle 阶段 都 下来 了 但是 我 依然 像 之前 那样 觉得 你们 非常 棒

    [汽车论坛]
    汽车数据是针对汽车领域的专业评价数据,会出现很多的专业术语。例如示例中的“胎噪”、“风燥”等,如果系统没有足够强大的训练词库或领域优化,会使准确率有较大程度降低。比较有意思的是,对比其他数据源,有 3 家系统都在汽车论坛领域达到最高:腾讯文智、 SCWS 中文分词、结巴分词。
    样例:舒适性 胎噪 风噪 偏 大 避震 偏 硬 过 坎 弹跳 明显

    [餐饮点评]
    餐饮点评数据为顾客评论数据,更偏重口语化。会出现很多类似“闺蜜”、“萌萌哒”口语化词语和很多不规范的表达,使分词更加困难。
    样例:跟 闺蜜 在 西单 逛街 想 吃 寿司 了 在 西单 没 搜 到 其他 的 日料店 就 来 禾绿 了 我们 俩 都 觉得 没 以前 好 了

    各家系统对于多数简单规范的文本的分词已经达到很高的水平。但在仔细对比每一家中文分词后依旧发现切分歧义词和未登陆词(即未在训练数据中出现的词)仍然是影响分词准确度的两大“拦路虎”。
    1.切分歧义:根据测试数据的切分结果,一类属于机器形式的歧义,在真实语言环境下,只有唯一可能的正确切分结果,称其为伪歧义。另一类有两种以上可实现的切分结果,称为真歧义。由于真歧义数据无法比较正确或者错误。所有我们着重举例来比较各家系统对伪歧义的处理效果。

    正确: 在 伦敦 奥运会 上 将 可能 有 一 位 沙特阿拉伯 的 女子
    ( BosonNLP 、新浪云、语言云、 NLPIR 、腾讯文智)

    错误: 在 伦敦 奥运会 上将 可能 有 一 位 沙特阿拉伯 的 女子
    ( PHP 结巴分词、 SCWS 中文分词、搜狗分词、庖丁解牛)

    示例中原意指伦敦奥运会可能有一位沙特阿拉伯的女子,错误分词的意思是指上将(军衔)中有一位是沙特阿拉伯的女子,句意截然不同。当然,分析的层次越深,机器对知识库质量、规模等的依赖性就越强,所需要的时间、空间代价也就越大。
    2.未登录词:未登录词大致包含三大类:
    a)新涌现的通用词:类似“神马”、“纳尼”、“甩卖”、“玫瑰金”等新思想、新事物所带来的新词汇,不管是文化的、政治的、还是经济的,在人们的生活中不断涌现。同时很多词语也具有一定的时效性。
    b)专业术语:是相对日常用语而言的,一般指的某一行业各种名称用语,大多数情况为该领域的专业人士所熟知。这种未登录词理论上是可预期的。能够人工预先添加到词表中(但这也只是理想状态,在真实环境下并不易做到)。
    c)专有名词:如中国人名、外国译名、地名、公司名等。这种词语很多基本上不可通过词典覆盖,考验分词系统的新词识别能力。

    [新涌现的通用词或专业术语]
    示例中的蓝色字包括专业术语:“肚腩”、“腹肌”、“腹直肌”、“腹外斜肌”、“腹横肌”;新涌现的通用词:“人鱼线”、“马甲线”。大多数的系统对于示例文本的分词结果都不够理想,例如:“大肚 腩”( SCWS 中文分词) “腹 直 肌 腹 外 斜 肌”(搜狗分词、 IKAnalyer 、 NLPIR 、 SCWS 中文分词)、“人 鱼线”( PHP 结巴分词)。总的来说这两种类型的数据每家系统都存在一定的缺陷,相对而言哈工大的语言云在这方面表现的较好。

    本 季 最 强 家庭 瘦 腰 计划 彻底 告别 大 肚腩 没有 腹肌 的 人生 是 不 完整 的 平面 模特 yanontheway 亲身 示范 的 9 个 动作 彻底 强化 腹直肌 腹外斜肌 腹内斜肌 以及 腹横肌 每个 动作 认真 做 足 50 次 一定 要 坚持 做 完美 的 人鱼线 性感 的 马甲线 都 要 我们 自己 去 争取

    [专有名词]
    示例出现的专有名词包括“蒂莫西伊斯顿”(姓名)、“英国”“意大利”“北欧”(地点)、“金斯敦”(机构名)、“伊丽莎白 格林希尔兹”(机构名)。而这种用词典无法穷尽的专有名词也成为各家分词准确率降低的重要原因。其中搜狗分词、 IKAnalyer 、 PHP 结巴分词、腾讯文智、 SCWS 中文分词在新词识别时较为谨慎,常将这类专有名词切分成多个词语。

    油画 英国 画家 蒂莫西伊斯顿 唯美 风 油画 timothy easton 毕业 于 英国 金斯敦 艺术 学院 曾 获 伊丽莎白 格林希尔兹 基金会 奖 得以 前往 意大利 和 北欧 学习 一 年 的 机会

    当然在分词准确度可以接受的情况下,很多细节问题,包括是否有出错情况、是否支持各种字符、是否标注词性等都可能让我们望而却步。在分词颗粒度选择当中, BosonNLP 、 SCWS 、盘古分词、结巴分词、庖丁解牛都提供了多种选择,可以根据需求来采用不同的分词粒度。与北大的分词标准对比来说,新浪云默认的分词粒度较大,而搜狗分词、腾讯文智分词粒度相对较小。除此之外, BosonNLP 、新浪云、 NLPIR 、腾讯文智同时提供了实体识别、情感分析、新闻分类等其他扩展服务。下表给出了各家系统在应用方面的详细对比。

    分词服务 分词粒度 出错情况 支持处理字符 新词识别 词性标注 认证方法 接口
    BosonNLP 多选择 识别繁体字 Token REST API
    IKAnalyzer 多选择 兼容韩文、日文字符 jar 包
    NLPIR 多选择 中文间隔符,返回局部乱码 未知 多语言接口
    SCWS 多选择 未知 PHP 库 /命令行工具
    结巴分词 多选择 识别繁体字 python 库
    盘古分词 多选择 识别繁体字并自动转换
    庖丁解牛 多选择 识别繁体字 jar 包
    搜狗分词 放弃超过一定字符长度的句子 识别繁体字并自动转换 未知 支持上传文档,但是一直失败
    腾讯文智 空白字符、中文间隔符,整段返回错误码 未知 返回中文词性 Signature REST API
    新浪云 未知 需要在新浪有一个仓库 REST API
    语言云 适中 识别繁体字 Token REST API

    中文分词是其他中文信息处理的基础,并且在很多领域都有广泛的应用,包括搜索引擎、机器翻译( MT )、语音合成、自动分类、自动摘要、自动校对等等。随着非结构化文本的广泛应用,中文分词等文本处理技术也变得越来越重要。通过评测可以看出,部分开放分词系统在不同领域已经达到较高准确率。对于数据分析处理的从业者,相信在此之上构建数据分析系统、人机交互平台,更能够起到事半功倍的效果。

    注意:分词数据准备及评测由 BosonNLP 完成。

    附录
    评测数据地址
    http://bosonnlp.com/dev/resource

    各家分词系统链接地址
    BosonNLP : http://bosonnlp.com/dev/center
    IKAnalyzer : http://www.oschina.net/p/ikanalyzer
    NLPIR : http://ictclas.nlpir.org/docs
    SCWS 中文分词: http://www.xunsearch.com/scws/docs.php
    结巴分词: https://github.com/fxsjy/jieba
    盘古分词: http://pangusegment.codeplex.com/
    庖丁解牛: https://code.google.com/p/paoding/
    搜狗分词: http://www.sogou.com/labs/webservice/
    腾讯文智:
    http://www.qcloud.com/wiki/API%E8%AF%B4%E6%98%8E%E6%96%87%E6%A1%A3
    新浪云: http://www.sinacloud.com/doc/sae/python/segment.html
    语言云: http://www.ltp-cloud.com/document

    10 条回复    2015-11-10 10:21:41 +08:00
    leavic
        1
    leavic  
       2015-11-09 16:49:14 +08:00
    结巴以上都是云端的分词系统吧,这些大公司的数据学习量优势太明显了,如果就本地应用来讲,应该是结巴最方便了。
    zts1993
        2
    zts1993  
       2015-11-09 17:14:11 +08:00
    我看第一张表排名就知道是广告了。。

    没有 Ansj4J 啊。。

    还有这种带学习的来虐结巴和 IK 真的好么,你和人家比精确,人家没和你比速度。。。/。。。
    imn1
        3
    imn1  
       2015-11-09 17:20:37 +08:00
    想知道各家对这句话分词结果是怎样的?
    “乒乓球拍卖得不错”
    macg0406
        4
    macg0406  
    OP
       2015-11-09 17:32:06 +08:00
    @leavic @zts1993 各有所长吧,满足需要就好。
    zmj1316
        5
    zmj1316  
       2015-11-09 17:44:47 +08:00
    我觉得这个还是放推广比较好
    macg0406
        6
    macg0406  
    OP
       2015-11-09 17:47:16 +08:00
    乒乓球拍 /n 卖 /v 得 /ude 不错 /a
    macg0406
        7
    macg0406  
    OP
       2015-11-09 17:48:45 +08:00
    乒乓球拍 /n 卖 /v 得 /ude 不错 /a
    @imn1
    imn1
        8
    imn1  
       2015-11-09 18:11:32 +08:00
    @macg0406
    各家都是这个结果么?

    其实另一个也是合理的,只是出现场合不多
    乒乓球 拍卖 得 不错
    master
        9
    master  
       2015-11-10 01:23:25 +08:00
    不否认楼主的产品确实挺好 但这样既做裁判又做选手做个评测 然后评出自己是同行最高分有啥意思呢
    macg0406
        10
    macg0406  
    OP
       2015-11-10 10:21:41 +08:00
    @master 宣传一下我们自己的产品,让需要的人有更多的选择。之前我们的分词引擎只有 500 次 /天的调用额度限制,想要更多的就要收费了,但是现在我们把这个限制取消了,就是因为看到越来越多的人对中文分词的需求。以上这些领域的数据是我们经常需要处理的,相信也有其他人需要处理这样的数据。

    至于说我们评出自己是同行最高分,大家也可以亲自试试,比较一下各家的表现如何。我们不否认我们有很多 bad case ,我们也不否认我们处理的速度慢。但是我们的分词引擎满足了我们其他引擎,以及数据处理任务的需求,希望也能为其他人提供帮助。

    敝厂是初创型小公司,没有其他大厂有名气,希望大家多多关注和支持。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   4298 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 35ms · UTC 10:12 · PVG 18:12 · LAX 02:12 · JFK 05:12
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.