本文主要来介绍NLP中的命名实体识别。命名实体识别与中文分词、词性标注一样,也是NLP的一个基础任务,是信息抽取、信息检索、机器翻译、问答系统等多种NLP技术不可或缺的一部分。其目的是:识别语料中的人名、地名、组织机构名等命名实体。
随着命名实体数量的不断增加,一般不可能在词典中全部列出,由于命名实体的构成方法具有规律性,通常把对这些词的识别在任务中进行独立处理,称之为命名实体识别。NER一般分为3大类和7小类。
1.中文命名实体识别的难点
各类命名实体的数量众多。命名实体的构成规律复杂。比如人名的构成规则各有不同,中文人名识别又可以细分为中国人名识别、日本人名识别和音译人名识别等;再比如机构名的组成方式,机构名的种类繁多,各有独特的命名方式,用词也相当广泛,只有结尾用词相对集中。嵌套情况复杂。一个命名实体经常和一些词组合成一个嵌套的命名实体,人名中嵌套着地名,地名中也经常嵌套着人名。长度不确定。与其他类型的命名实体相比,长度和边界难以确定,使得机构名更难识别。中国人名一般二到四字,常用地名一般二到四字,但是机构名长度变化范围极大,少的只有两个字简称,多的达到几十个字的全称。2命名实体识别方式
CF Benchmarks与Chainlink合作推出比特币利率曲线:金色财经报道,加密指数公司CF Benchmarks与Chainlink合作推出了比特币利率曲线。CF比特币利率曲线将使用三种不同的数据源、期货交易所的交易数据、Aave或Compound等DeFi借贷协议以及OTC加密货币贷方来衡量比特币的借贷。使用这些数据创建利率曲线,CF Benchmarks旨在改善借贷在加密货币中的工作方式。该公司表示,希望通过使曲线上的每个点“具有代表性、可复制性和效率”来促进金融产品的创造,例如利率衍生品合约。(theblock)[2022/9/29 5:59:37]
中文分词中,主要有基于规则方法、基于统计方法和基于二者的混合方法。命名实体识别主要也包含这三种方法。
基于规则的命名实体识别:规则加词典是早期命名实体识别中最行之有效的方式。依赖手工规则,结合命名实体库,对每条规则进行权重赋值,然后通过实体与规则的相符情况来进行类型判断。基于统计的命名实体识别:与分词类似,目前主流的基于统计的命名实体识别方法有:隐马尔可夫模型、最大熵模型、条件随机场等。其主要思想是:基于人工标注的语料,将命名实体识别任务作为序列标注问题来解决。基于混合的命名实体识别:NLP并不完全是一个随机过程,单独使用基于统计的方法使状态搜索空间非常庞大,必须借助规则知识提前进行过滤修剪处理。目前几乎没有单纯使用统计模型而不使用规则知识的命名实体识别系统,在很多情况下是使用混合方法,结合规则和统计方法。序列标注方式是目前命名实体识别中的主流方法,下面重点介绍基于CRF条件随机场的方法。
稳定资产RAI开发团队Reflexer已集成Chainlink ETH/USD喂价:3月30日消息,稳定资产RAI开发团队Reflexer Labs宣布,作为RAI主网发布的一部分,Reflexer已集成Chainlink的ETH/USD喂价。
该去中心化预言机提供与当前ETH/USD价格保持一致的最新链上喂价,RAI智能合约可以在一次调用中获取相关数据,为RAI完全按预期运行提供有力保证。[2021/3/30 19:30:20]
3基于CRF的命名实体识别
条件随机场的主要思想来源于HMM,也是一种用来标记和切分序列化数据的统计模型。不同的是,条件随机场是在给定观察的标记序列下,计算整个标记序列的联合概率,而HMM是在给定当前状态下,定义下一个状态的分布。
SnowSwap集成Chainlink预言机Fast Gas:金色财经报道,Chainlink官方发推文称,DEX项目SnowSwap已集成Chainlink的Fast Gas预言机,以为目前的以太坊Gas费提供高度可用的和防篡改的参考信息源,帮助用户确定与LP策略相关的成本。[2021/2/3 18:44:08]
条件随机场的定义为:假设X=(X1,X2,X3,…,Xn)和Y=(Y1,Y2,Y3,…,Ym)是联合随机变量,若随机变量Y构成一个无向图G=(V,E)表示的马尔可夫模型,则其条件概率分布P(Y|X)称为条件随机场,即:
P(Yv|X,Yw,w≠v)=P(Yv|X,Yw,w~v)
其中w~v表示无向图G=(V,E)中与结点v有边连接的所有节点,w≠v表示结点v以外的所有节点。
Theta与Chainlink合作以打击欺诈广告:金色财经报道,支持区块链的视频网络Theta与Chainlink合作,帮助打击视频广告局,这些局经常弹出并宣传“加密货币赠品”局。两家公司的解决方案使用来自Theta网络的视频性能数据,根据观看人数为每个流媒体分配一个“信誉评分”。该分数由谷歌的大数据解决方案BigQuery生成,然后通过Chainlink的oracle广播至以太坊网络,广告商可以在查看分数的同时决定向谁投放广告。[2020/9/26]
例如:对句子“我来到陶家村”进行标注,正确标注后的结果为:我/O来/O到/O陶/B家/M村/E。采用线性链CRF来进行解决,那么是其一种标注序列,也是是其一种标注选择,类似的可选择的标注序列有很多,在NER任务中就是在这么多的可选标注序列中,找出最靠谱的作为句子的标注。
以太坊混币平台Tornado.cash集成Chainlink以太坊Gas价格预言机:以太坊混币平台Tornado.cash已在主网集成Chainlink提供的以太坊Gas价格预言机,如果Tornado.cash无法获得链下Gas费用数据,其前端页面将会调用Chainlink的Gas价格预言机,为用户提交交易时的Gas费用预测提供数据支持。
目前该预言机已集成了四个链下的Gas价格来源,分别是EthGasStation、Gas Oracle、Etherchain和POA的GasPrice,Chainlink会将这些数据持续提交到以太坊链上,其他应用即可参考调用。[2020/6/6]
那么我们要解决的问题就是要判断标注序列是否靠谱。就刚才的两种标注方法,显然第一种比第二种更为准确,因为第二种将“陶”和“家”都作为地名首字标成了“B”,一个地名两个首字符,显然不合理。假如给每个标注序列打分,分值代表标注序列的靠谱程度,越高代表越靠谱,那么可以定一个规则,若在标注中出现连续两个“B”结构的标注序列,则给它低分。连续“B”结构打低分就对应一条特征函数。在CRF中,定义一个特征函数集合,然后使用这个特征函数集合为标注序列进行打分,据此选出最靠谱的标注序列,该序列的分值是通过特征函数集合得出的。
在CRF中有两种特征函数,分别为:转移函数tk(yi-1,yi,i)和状态函数sl(yi,X,i)。tk(yi-1,yi,i)依赖于当前和前一个位置,表示从标注序列中位置i-1的标记yi-1转移到位置i上的标记yi的概率。sl(yi,X,i)依赖当前位置,表示标记序列在位置i上为标记yi的概率。通常特征函数取值为1或0,表示符不符合该条规则约束。
4日期识别代码示例
应用场景:
现有一个智能外呼系统,由机器人拨打电话给客户,通知客户新股中签情况,客户与机器人进行对话。对话机器人根据用户的语音进行解析,发觉用户的需求,比如:新股中签的时间,新股买入的时间等。通过asr技术将用户的语音转换成中文文本,然后由于asr的识别准确度问题,许多日期类的数据并不是严格的数字,比如会出现“十一月12日”“2019年11月”“20191112”“后天下午”等形式。
现在的需求是识别出每个请求文本中可能的日期信息,并将其转换成统一的格式进行输出。比如:“我打算今天或明天买入新股”,那么通过日期解析后,应该输出为“2019-11-12”和“2019-11-13”。
通过结果分析可以看到,text1text2text3text4结果还是相对较好的,对于text5这种规则覆盖之外的场景,方法效果大大降低。
作者:KevinTao
知乎号:Kevin陶民泽
备注:转载请注明出处。
如发现错误,欢迎留言指正。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。