python计算召回率代码_序列标注的准确率和召回率计算

本文介绍了如何使用Python自行计算命名实体识别任务中BiLSTM+CRF模型的准确率和召回率。通过公式和具体实现代码详细阐述了从标签序列中抽取出实体并计算评估指标的过程。
摘要由CSDN通过智能技术生成

最近在用BiLSTM+CRF做命名实体识别问题。关于模型效果评估,很多提到用conlleval.pl来实现,conlleval.pl是perl语言写的,原谅我没看懂。最后还是决定自己写个程序算一算准确率和召回率。

公式

准确率 = 预测正确的实体个数 / 预测的实体总个数

召回率 = 预测正确的实体个数 / 标注的实体总个数

F1 = 2 *准确率 * 召回率 / (准确率 + 召回率)

实现

1、获取实体:包括预测的全部实体标注的全部实体

对于一个标签序列,例如:'B-PER', 'I-PER', 'O', 'B-PER', 'I-PER', 'O', 'O', 'B-LOC', 'I-LOC'

实体对应的标签块是指:从B开头标签开始的,同一类型(PER/LOC/ORG)的,非O的连续标签序列

因此可以采用形如{(position, type): [label1, label2, ...]}这种格式的字典来存储实体,其中position为实体起始标签对应的序列下标索引,type为实体对应的类型,[label1, label2, ...]为实体对应的标签序列

从标签序列中抽取实体的代码如下:

def split_entity(label_sequence):
    entity_mark = dict()
    entity_pointer = None
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值