zoukankan      html  css  js  c++  java
  • Hanlp实战HMM-Viterbi角色标注中国人名识别

    这几天写完了人名识别模块,与分词放到一起形成了两层隐马模型。虽然在算法或模型上没有什么新意,但是胜在训练语料比较新,对质量把关比较严,实测效果很满意。比如这句真实的新闻“签约仪式前,秦光荣、李纪恒、仇和等一同会见了参加签约的企业家。”,分词结果:[签约/v, 仪式/n, /f, /w, 秦光荣/nr, /w, 李纪恒/nr, /w, 仇和/nr, /u, 一同/d, 会见/v, /ul, 参加/v, 签约/v, /uj, 企业家/n, /w],三个人名“秦光荣”“李纪恒”“仇和”一个不漏。一些比较变态的例子也能从容应对,比如下面:

     

    这是hankcs将自己的分词与ansj作比较得出的结果,由于自己可以随时调整算法,所以主场占了很大便宜。但是第一句绝对没有放水,说实话能识别出“仇和”这么冷僻的名字着实让人惊喜了一下。

     

    开源项目

    本文代码已集成到HanLP中开源:https://github.com/hankcs/HanLP 

    原理

    推荐仔细阅读《基于角色标注的中国人名自动识别研究.doc》这篇论文,该论文详细地描述了算法原理和实现。从语料库的整理、标注到最后的模式匹配都讲得清清楚楚。hankcs在这篇论文的基础上做了改进,主要步骤总结如下:

    1对熟语料库自动标注,将原来的标注转化为角色标注。角色标注一共有如下几种:

     

    hankcs在此基础上拓展了一个S,代表句子的开始。

    2、统计标签的出现频次,标签的转移矩阵。

    3、对粗分结果角色标注,模式匹配。

    hankcs对论文中的几个模式串做了拓充,并且采用了AC模式匹配算法。

    体会

    论文中将三字名称拆分为BCD,实测在2-gram模型下,C很容易被识别为E,导致人名缺一半。

    人民日报2014中的人名并不能覆盖所有常用字,所以hankcs去别的地方找了个人名库,拆成BCDBE补充了进去。

    人民日报2014语料库中有很多错误,比如

    /vf 年老/vi 张中秋/nr /vf /w 泡茶/vi /w /w 送礼/vi 遭到/v /ule 拒绝/v /w 老张/nz 担心/v 金额/n 不够/a

    中秋很明显不是人名的组成部分,这个必须手工剔除。

    “中秋安全”会识别出“中 秋安全”来,因为2-gram词典中没有“中秋@安全”这种接续,而有“中@##人”这种接续。初步的解决方法是手工往2-gram词典里面加一条“中秋@安全”。这反映了这种方法的局限性,另一方面也说明词典的重要性。

     

    文章转载自hankcs的博客!

  • 相关阅读:
    PHP:第四章——PHP数组处理函数
    PHP:第四章——PHP数组array_intersect计算数组交集
    PHP:第四章——PHP数组array_diff计算数组差集
    PHP:第四章——PHP数组查找,替换,过滤,判断相关函数
    GPG入门
    GPG入门教程
    运行gpg --gen-key生成key时出现卡住的问题
    程序员练级攻略(2018) 与我的专栏
    构建一个在线ASCII视频流服务
    Ubuntu 16.04配置国内高速apt-get更新源
  • 原文地址:https://www.cnblogs.com/adnb34g/p/9829857.html
Copyright © 2011-2022 走看看