来源:Paperweekly

本文长度为2218字,建议阅读4分钟

本文为你介绍中文文本标注工具的构建方法,并提供多个开源文本标注工具。

项目地址: https://github.com/crownpku/Chinese-Annotator

自然语言处理的大部分任务是监督学习问题。序列标注问题如中文分词、命名实体识别,分类问题如关系识别、情感分析、意图分析等,均需要标注数据进行模型训练。在深度学习大行其道的今天,基于深度学习的 NLP 模型更是数据饥渴。


最前沿的 NLP 技术往往首先针对英文语料。英文 NLP 的生态很好,针对不同有意思的问题都有不少大规模语料公开供大家研究,如斯坦福的 SQuAD 阅读理解语料。中文方面开源语料就少得多,各种英文 NLP 上的犀利模型和前沿技术都因为中文语料的匮乏很难迁移过来。


另一方面,对于一些垂直领域,如医疗、金融、法律、公安等等,专有名词和特有需求甚多,很难将比较 general 的比如在 wikipedia dump 上面训练的模型直接拿过来用。


传统人工标注数据的过程往往是繁琐和低效率的。刚标了一个“联想”是公司名,又来一个“联想集团”,再标一次又来一个“联想集团有限公司”,如此的例子令标注过程含有大量的重复劳动。另一方面也没有一个易上手的标注 UI,标注工作者往往需要直接按预先定好的格式直接在写字板之类的软件中修改原始数据,格式错误率也较高。


能不能构建一个中文文本的标注工具,需要看以下两个特点:


1. 标注过程背后含有智能算法,将人工重复劳动降到最低;


2. 标注界面显而易见地友好,让标注操作尽可能简便和符合直觉。


答案是可以的。事实上很多标注工具已经做到了这一点,最先进的如 Explosion.ai 的 Prodigy;然而开发了著名的 NLP 开源包 Spacy 的 explosion.ai 选择了将 Prodigy 闭源,而 Spacy 支持中文也仍然遥遥无期。我们希望构建一个开源的中文文本标注工具,而本文很多的技术灵感正是来自 Prodigy 文档[1]。


主动学习的智能标注算法


流程:


1. 用户标一个label;


2. 主动学习的后台算法分为 online 和 offline 部分。online 部分即时更新模型,可使用诸如 SVM、bag of words 等尽可能快的传统方法;offline 部分当标注数据积累到一定数量时更新模型,可使用准确度较高的深度学习模型;


3. 模型更新后,对尽可能多的 example 做预测,将确信度排序,取确信度最低的一个 example 作为待标注例子。重复 1 的过程。


可以想象如果模型训练得好的话,这个过程将直接忽略掉确信度最大的那些例子,而把所有重点放在分类边界上的那些确信度小的例子。这样可以尽算法所能减少用户端的人工工作量。


online 与 offline 模型互相协作,与用户手动标注的过程一起不断迭代;在最终标注任务完成之后,offline 模型可以重新在所有标注数据上重新训练,以达到最好的模型效果。


显而易见的友好标注前端

用户标注的界面应该尽可能符合直觉,让用户完全聚焦在当前的标注任务上。 Prodigy 给了一个非常好的 demo[2],每一次的标注只需要用户解决一个 case 的问题。以文本分类为例,对于算法给出的分类结果,只需要点击“正确”提供正样本,“错误”提供负样本,“略过”将不相关的信息滤除,“Redo”让用户撤回操作,四个功能键以最简模式让用户进行标注操作。


真正应用中,应该还要加入一个用户自己加入标注的交互方式,比如用户可以高亮一个词然后选择是“公司”,或者链接两个实体选择他们的关系等等。



以上是个人觉得的一个智能中文文本标注工具的最大亮点。算法本身还有很多细节需要思考,比如 online 机器学习算法与 offline 深度学习算法的协作、中文 NLP 的特征提取与模型构建、正则规则的引入、word embedding 的训练和使用等等。


系统本身还要考虑后台存储(SQLite?)和数据导入导出,前端框架选型和开发,前后端交互(django? flask? RestAPI?)等等的问题。下面是 Prodigy 的简单架构图。



我们希望专注于中文文本标注的功能。前期我们想实现三种中文 NLP 任务的标注工具:中文命名实体识别,中文关系识别,中文文本分类。未来如果有更多如中文图片问答、中文图片描述之类的任务,我们可以再研究加入图片标注这一块。


希望这个工具的开发会是以中文社区的开源协作方式,为整个中文 NLP 的开源生态做出一点贡献。


FAQ


1. 待标注数据集如何分割


应该分为按句子、按段落、按文章三种,写入配置文件由用户选择。 原因是命名实体识别与关系抽取可能按句子或者段落为单位给用户标注比较合适;同时可能用户会有全文章分类的需求,需要给出全文。


2. 为什么要使用 online?


用户标注数据 + offline 标注数据,为什么还要使用 online model 更新数据呢?原因是 offline 的模型往往在全量数据上重新学习,也很可能需要使用深度学习模型,训练的速度会很慢。而 active learning 的人机迭代过程要求模型给出几乎实时的 stream 级别的训练和推断速度,这时候就需要 online model 来先行更新数据。


3. 使用什么机制触发 offline model?


这也可以是写入配置文件的参数。一种是用户标够了 100 个或提前设置好的足够多的新的数据,就可以启用 offline model 进行训练;另一种是给用户一个按钮,用户可以点击启动后台的 offline 模型训练并给出进度条。


4. 系统使用什么格式的配置文件?


推荐 json 格式的配置文件。请参考一个例子在这里[3]。


5. AIgo Factory 是什么?和 User Instance 里面的部分是不是有点重合?


Algo factory 是算法的代码模块,你可以想象一堆 tensorflow 或者 sklearn 的代码;而 user instance 是 config 文件与模型参数,是一堆用户生成的 json 文件和模型文件。algo factory 是可以不同 user instance 传入参数复用的,而每一个 user instance 代表了一个用户任务的实例。


这样设计的目的,是尽可能使系统可复用部分模块化,而抽出用户具体任务的配置与数据单独存储管理。


附录:几个开源文本标注工具


• IEPY


整个工程比较完整,有用户管理系统。前端略重,对用户不是非常友好。


代码:https://github.com/machinalis/iepy

说明:http://iepy.readthedocs.io/en/latest/index.

html


• DeepDive (Mindtagger)


Screenshot of Mindtagger precision task in progress


前端比较简单,用户界面友好。


介绍:http://deepdive.stanford.edu/labeling

前端代码:https://github.com/HazyResearch/mind

bender


将 DeepDive 的 corenlp 部分转为支持中文的代码尝试:


https://github.com/SongRb/DeepDiveChineseApps

https://github.com/qiangsiwei/DeepDive_Chinese

https://github.com/mcavdar/deepdive/commit/6882178cbd38a5bbbf4eee8b76b1e215537425b2


• BRAT



介绍:http://brat.nlplab.org/index.html

在线试用:http://weaver.nlplab.org/~brat/demo/

latest/#/

代码:https://github.com/nlplab/brat


• SUTDAnnotator



用的不是网页前端而是 pythonGUI,但比较轻量。


代码:https://github.com/jiesutd/SUTDAnnotator

Paper:https://github.com/jiesutd/SUTDAnnotator

/blob/master/lrec2018.pdf


• Snorkel



Page: https://hazyresearch.github.io/snorkel/

Github: https://github.com/HazyResearch/snorkel

Demo Paper: https://hazyresearch.github.io/snorkel/

pdfs/snorkel_demo.pdf


• Slate



Code: https://bitbucket.org/dainkaplan/slate/

Paper: http://www.jlcl.org/2011_Heft2/11.pdf


• Prodigy



和著名的 spacy 是一家做的。


Website: https://prodi.gy/docs/

Blog: https://explosion.ai/blog/prodigy-annotation-tool-active-learning


相关链接


[1] Prodigy 文档:https://prodi.gy/docs/

[2] Prodigy demo:https://prodi.gy/demo

[3] 系统配置参考:https://github.com/crownpku/

Rasa_NLU_Chi/tree/master/sample_configs

编辑:文婧

校对:王红玉

为保证发文质量、树立口碑,数据派现设立“错别字基金”,鼓励读者积极纠错

若您在阅读文章过程中发现任何错误,请在文末留言,或到后台反馈,经小编确认后,数据派将向检举读者发8.8元红包

同一位读者指出同一篇文章多处错误,奖金不变。不同读者指出同一处错误,奖励第一位读者。

感谢一直以来您的关注和支持,希望您能够监督数据派产出更加高质的内容。

怎样构建中文文本标注工具?(附工具、代码、论文等资源)相关推荐

  1. 构想:中文文本标注工具(内附多个开源文本标注工具)

    ■ 项目地址 | https://github.com/crownpku/Chinese-Annotator 自然语言处理的大部分任务是监督学习问题.序列标注问题如中文分词.命名实体识别,分类问题如关 ...

  2. 结巴分词关键词相似度_中文文本相似度计算工具集

    [磐创AI导读]:前两篇文章中我们介绍了一些机器学习不错的项目合集和深度学习入门资源合集,本篇文章将对中文文本相似度计算工具做一次汇总.喜欢我们文章的小伙伴,欢迎大家点击上方蓝字关注我们的公众号:磐创 ...

  3. Pytorch TextCNN实现中文文本分类(附完整训练代码)

    Pytorch TextCNN实现中文文本分类(附完整训练代码) 目录 Pytorch TextCNN实现中文文本分类(附完整训练代码) 一.项目介绍 二.中文文本数据集 (1)THUCNews文本数 ...

  4. 基于TextRank算法的文本摘要(附Python代码)

    基于TextRank算法的文本摘要(附Python代码): https://www.jiqizhixin.com/articles/2018-12-28-18

  5. 最准的中文文本相似度计算工具

    向AI转型的程序员都关注了这个号???????????? 机器学习AI算法工程   公众号:datayx text2vec, chinese text to vetor.(文本向量化表示工具,包括词向 ...

  6. 中文文本相似度计算工具集

    欢迎大家关注我们的网站和系列教程:http://www.tensorflownews.com/,学习更多的机器学习.深度学习的知识! 一.基本工具集 1.分词工具 a.jieba 结巴中文分词 htt ...

  7. 利用OpenCV、Python和Ubidots构建行人计数器程序(附完整代码)

    作者 | Jose Garcia 译者 | 吴振东 校对 | 张一豪.林亦霖,编辑 | 于腾凯 来源 | 数据派(ID:datapi) 导读:本文将利用OpenCV,Python和Ubidots来编写 ...

  8. 最新最全-中文生物医学命名实体识别最新研究论文、资源、数据集、性能整理分享

    本资源旨在跟踪中文生物医学自然语言处理的进展,收集整理相关的论文列表和展示现存方法性能. 内容整理自网络,源地址:https://github.com/lingluodlut/Chinese-BioN ...

  9. 用Bi-GRU语义解析,实现中文人物关系分析 | 附完整代码

    作者 | 李秋键 责编 | Carol 来源 | AI科技大本营(ID:rgznai100) 语义解析作为自然语言处理的重要方面,其主要作用如下:在词的层次上,语义分析的基本任务是进行词义消歧:在句子 ...

最新文章

  1. 2021年大数据常用语言Scala(十二):基础语法学习 方法调用方式
  2. php foreach是什么,php中foreach的用法是什么
  3. Android10.0 Binder通信原理(五)-Binder驱动分析
  4. 谷歌新模型突破BERT局限:NLP版「芝麻街」新成员Big Bird长这样
  5. 关于sql和MySQL的语句执行顺序
  6. 对php专业的认识,对PHP要有个全面的认识
  7. Dubbo-Dependency
  8. 漫步VR——Unity语音聊天室开发小结
  9. c++ opencv 识别车牌_小强学Python+OpenCV之-1.0开篇
  10. java面试关于ssh的_[Java教程]ssh面试题
  11. 测试面试题集-Python编程题(1)
  12. 制造业Google Glass 焕发巨大活力
  13. exchange无法收发邮件_MAPI session超过Exchange最大限制,邮件发送失败的终极解决方法...
  14. OpnCV_(HoughCircles to find circles)霍夫变换检测圆形
  15. apple 关闭双重认证_这次Apple可以关闭工作吗?
  16. 「Deep Learning」Note on the Shattered Gradients Problem
  17. 键盘密码(Qwerty)——python解密
  18. 揭秘公共WiFi安全黑幕
  19. 商用清洁机器人:科沃斯“破圈”、高仙机器人“纵深”
  20. Burp Suite之Scaner模块(三)

热门文章

  1. 使用PowerShell调用MTools分析MongoDB性能并发送邮件
  2. 4个开源在线调查工具
  3. HTML DOM getElementById() 方法
  4. 设置div中的div居中显示
  5. 嵌入式开发之赛灵思 xilinx Zynq芯片简介---Zynq-7000 EPP (XC7Z010 and XC7Z020)
  6. IE6动态插入option
  7. c语言选择题写小写字母表,C语言选择题(最全版).doc
  8. java 登录按钮响应数据库_用户登录功能的实现—从前端到后台(包括数据库)...
  9. 2021年4月16日 阿里供应链Java研发实习面试(二面)
  10. Leetcode刷题 1441题: 用栈操作构建数组(基于python3和c++两种语言)