precision、recall、F1的计算方法和物理意义

本文介绍了人工智能模型的评估指标,如精确率、召回率和F1分数,并通过一个命名实体识别(NER)的例子展示了如何计算这些指标。模型的精确率表示识别为猫类的准确性,召回率表示在所有类别中正确识别猫的概率,F1分数则综合了精确率和召回率,体现了模型的综合性能。
摘要由CSDN通过智能技术生成

类别


 1.2.3.

计算方法和物理意义

p r e c i s i o n 猫 precision_猫 precision= 识 别 为 猫 类 正 确 的 数 量 识 别 为 猫 类 总 数 量 {识别为猫类正确的数量} \over {识别为猫类总数量}

precision为50%物理意义:该模型识别出猫的可参考价值(准确率)为50%

r e c a l l 猫 recall_猫 recall= 标 签 为 猫 类 识 别 正 确 的 数 量 标 签 为 猫 类 的 总 数 量 {标签为猫类识别正确的数量} \over {标签为猫类的总数量}

recall为10%物理意义:该模型在猫、狗、猪中正确识别出猫的概率为10%

f 1 猫 f1_猫 f1= 2 ∗ p r e c i s i o n 猫 ∗ r e c a l l 猫 p r e c i s i o n 猫 + r e c a l l 猫 {2*precision_猫*recall_猫} \over {precision_猫+recall_猫} precision+recall2precisionrecall

f1物理意义:模型综合能力

ner例子说明:

    def calculatePRAndF1():
        with open("data/testresult.txt", mode="r", encoding="utf8") as f:
            allLocPre = 0  # 所有被模型识别为地名的数量
            locPreCorr = 0  # 被模型识别为地名且正确的数量
            allLocReal = 0  # 所有地名的数量
            for line in f:
                line = line.strip()
                if line == "":
                    continue
                word, realFlag, preFlag = line.split()  # 字, 实际状态标注, 预测状态标注
                if preFlag != "O":
                    allLocPre += 1
                if realFlag != "O":
                    allLocReal += 1
                if realFlag == preFlag:
                    if not realFlag == "O":
                        locPreCorr += 1
            precision = locPreCorr * 1.0 / allLocPre  # 查准率
            recall = locPreCorr * 1.0 / allLocReal  # 召回率
            f1 = 2 * precision * recall / (precision + recall)  # 调和平均
            return precision, recall, f1

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值