【机器学习】性能度量

介绍

在机器学习中,性能度量主要体现在三个指标:

  • 查准率(P)
  • 查全率(R)
  • F1

代码模板

# coding=utf-8

import sys
reload(sys)
sys.setdefaultencoding('utf-8')

... ...

def performance(tp, fn, fp, tn):
    # 查准率
    P = tp / float(tp + fp)
    # 查全率
    R = tp / float(tp + fn)
    # F1
    F1 = (2 * P * R) / (P + R)
    # print P, R, F1
    return P, R, F1

... ...

P, R, F1 = performance(white_pixels, red_pixels, green_pixels, black_pixels)
print '查准率 P = {:>.3f},  查全率 R = {:>.3f},   F1 = {:>.3f}'.format(P, R, F1).encode('gb18030')

... ...

Note

  • fp: false positive,错误地判断为正例;
  • tp: truly positive,正确地判断为正例。

运用示例

# coding=utf-8

import sys
reload(sys)
sys.setdefaultencoding('utf-8')

diff_path = './data/diff.jpg'

black_pixels, white_pixels, green_pixels, red_pixels = 29158, 530899, 75994, 3949
sum_pixels = 640000

def performance(tp, fn, fp, tn):
    # 查准率
    P = tp / float(tp + fp)
    # 查全率
    R = tp / float(tp + fn)
    # F1
    F1 = (2 * P * R) / (P + R)
    # print P, R, F1
    return P, R, F1

def occupancy_cal(a, b):
    result = (a + b) / float(sum_pixels)
    return result

def loss_cal(a, b):
    result = (a - b) / float(a)
    return result

print '以 二值化结果 作为 预测值, 标注框结果 作为 ground_truth 时:'.encode('gb18030')
truth, predict = occupancy_cal(white_pixels, red_pixels), occupancy_cal(white_pixels, green_pixels)
loss = loss_cal(truth, predict)
print '实际 横截面区域 占图像 {:>.3f}, 预测值为 {:>.3f}, 损失比例为 {:>.3f}'.format(truth, predict, loss).encode('gb18030')
P, R, F1 = performance(white_pixels, red_pixels, green_pixels, black_pixels)
print '查准率 P = {:>.3f},  查全率 R = {:>.3f},   F1 = {:>.3f}'.format(P, R, F1).encode('gb18030')
print
print '以 标注框结果 作为 预测值, 二值化结果 作为 ground_truth 时:'.encode('gb18030')
truth, predict = occupancy_cal(white_pixels, green_pixels), occupancy_cal(white_pixels, red_pixels)
loss = loss_cal(truth, predict)
print '实际 横截面区域 占图像 {:>.3f}, 预测值为 {:>.3f}, 损失比例为 {:>.3f}'.format(truth, predict, loss).encode('gb18030')
P, R, F1 = performance(white_pixels, green_pixels, red_pixels, black_pixels)
print '查准率 P = {:>.3f},  查全率 R = {:>.3f},   F1 = {:>.3f}'.format(P, R, F1).encode('gb18030')

打印结果:

以 二值化结果 作为 预测值, 标注框结果 作为 ground_truth 时:
实际 横截面区域 占图像 0.836, 预测值为 0.948, 损失比例为 -0.135
查准率 P = 0.875,  查全率 R = 0.993,   F1 = 0.930

以 标注框结果 作为 预测值, 二值化结果 作为 ground_truth 时:
实际 横截面区域 占图像 0.948, 预测值为 0.836, 损失比例为 0.119
查准率 P = 0.993,  查全率 R = 0.875,   F1 = 0.930
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值