网络模型mAP计算实现代码

一、mAP精度计算

  这里首先介绍几个常见的模型评价术语,现在假设我们的分类目标只有两类,计为正例(positive)和负例(negtive)分别是:

  1)True positives(TP):  被正确地划分为正例的个数,即实际为正例且被分类器划分为正例的实例数(样本数);

  2)False positives(FP): 被错误地划分为正例的个数,即实际为负例但被分类器划分为正例的实例数;

  3)False negatives(FN):被错误地划分为负例的个数,即实际为正例但被分类器划分为负例的实例数;

  4)True negatives(TN): 被正确地划分为负例的个数,即实际为负例且被分类器划分为负例的实例数。 

P

代表precision即准确率,计算公式为预测样本中实际正样本数 / 所有的正样本数 即  precision=TP/(TP+FP);

R

代表recall即召回率,计算公式为 预测样本中实际正样本数 / 预测的样本数即   Recall=TP/(TP+FN)=TP/P

一般来说,precision和recall是鱼与熊掌的关系,往往召回率越高,准确率越低

AP

AP 即 Average Precision即平均精确度

mAP

mAP 即 Mean Average Precision即平均AP值,是对多个验证集个体求平均AP值,作为 object dection中衡量检测精度的指标。

F

度量(F-measure),F度量涵盖了准确率和召回率这两个指标。其计算公式如下:F = 2 * P * R / (P + R)

P-R曲线

P-R曲线即 以 precision 和 recall 作为 纵、横轴坐标 的二维曲线。通过选取不同阈值时对应的精度和召回率画出

总体趋势,精度越高,召回越低,当召回达到1时,对应概率分数最低的正样本,这个时候正样本数量除以所有大于等于该阈值的样本数量就是最低的精度值。

另外,P-R曲线围起来的面积就是AP值,通常来说一个越好的分类器,AP值越高。

总结一下,在目标检测中,每一类都可以根据 recall 和 precision绘制P-R曲线,AP就是该曲线下的面积,mAP就是所有类AP的平均值。

二.评测代码

import tensorflow as tf

#精确率评价指标

def metric_precision(y_true,y_pred):

TP=tf.reduce_sum(y_true*tf.round(y_pred))

TN=tf.reduce_sum((1-y_true)*(1-tf.round(y_pred)))

FP=tf.reduce_sum((1-y_true)*tf.round(y_pred))

FN=tf.reduce_sum(y_true*(1-tf.round(y_pred)))

precision=TP/(TP+FP)

return precision

#召回率评价指标

def metric_recall(y_true,y_pred):

TP=tf.reduce_sum(y_true*tf.round(y_pred))

TN=tf.reduce_sum((1-y_true)*(1-tf.round(y_pred)))

FP=tf.reduce_sum((1-y_true)*tf.round(y_pred))

FN=tf.reduce_sum(y_true*(1-tf.round(y_pred)))

recall=TP/(TP+FN)

return recall

#F1-score评价指标

def metric_F1score(y_true,y_pred):

TP=tf.reduce_sum(y_true*tf.round(y_pred))

TN=tf.reduce_sum((1-y_true)*(1-tf.round(y_pred)))

FP=tf.reduce_sum((1-y_true)*tf.round(y_pred))

FN=tf.reduce_sum(y_true*(1-tf.round(y_pred)))

precision=TP/(TP+FP)

recall=TP/(TP+FN)

F1score=2*precision*recall/(precision+recall)

return F1score<br><br>

#编译阶段引用自定义评价指标示例

model.compile(optimizer='adam',

loss='binary_crossentropy',

metrics=['accuracy',

metric_precision,

metric_recall,

metric_F1score])

# AUC for a binary classifier

def auc(y_true, y_pred):

ptas = tf.stack([binary_PTA(y_true,y_pred,k) for k in np.linspace(0, 1, 1000)],axis=0)

pfas = tf.stack([binary_PFA(y_true,y_pred,k) for k in np.linspace(0, 1, 1000)],axis=0)

pfas = tf.concat([tf.ones((1,)) ,pfas],axis=0)

binSizes = -(pfas[1:]-pfas[:-1])

s = ptas*binSizes

return K.sum(s, axis=0)

#-----------------------------------------------------------------------------------------------------------------------------------------------------

# PFA, prob false alert for binary classifier

def binary_PFA(y_true, y_pred, threshold=K.variable(value=0.5)):

y_pred = K.cast(y_pred >= threshold, 'float32')

# N = total number of negative labels

N = K.sum(1 - y_true)

# FP = total number of false alerts, alerts from the negative class labels

FP = K.sum(y_pred - y_pred * y_true)

return FP/N

#-----------------------------------------------------------------------------------------------------------------------------------------------------

# P_TA prob true alerts for binary classifier

def binary_PTA(y_true, y_pred, threshold=K.variable(value=0.5)):

y_pred = K.cast(y_pred >= threshold, 'float32')

# P = total number of positive labels

P = K.sum(y_true)

# TP = total number of correct alerts, alerts from the positive class labels

TP = K.sum(y_pred * y_true)

return TP/P

#接着在模型的compile中设置metrics

# False Discovery Rate(FDR)

from sklearn.metrics import confusion_matrix

y_true = [0,0,0,0,0,0,,1,1,1,1,1]

y_pred = [0,0,0,0,0,0,,1,1,1,1,1]

tn, fp , fn, tp = confusion_matrix(y_true, y_pred).ravel()

fdr = fp / (fp + tp)

print(fdr)

网络模型mAP计算实现代码的更多相关文章

  1. 前端JS面试题汇总 Part 2 (null与undefined/闭包/foreach与map/匿名函数/代码组织)

    原文:https://github.com/yangshun/front-end-interview-handbook/blob/master/questions/javascript-questio ...

  2. C++算法之大数加法计算的代码

    如下代码段是关于C++算法之大数加法计算的代码,希望对大家有用. { int length; int index; int smaller; int prefix = 0; if(NULL == sr ...

  3. Javascript时间差计算函数代码实例

    Javascript时间差计算函数代码实例 <script language="javascript"> Date.prototype.dateDiff = funct ...

  4. 基于ACCESS和ASP的SQL多个表查询与计算统计代码(一)

    近期在写几个关于"Project - Subitem - Task"的管理系统,说是系统还是有点夸大了,基本就是一个多表查询调用和insert.update的数据库操作.仅仅是出现 ...

  5. 关于UDP的检验和计算(附代码)

    关于UDP的检验和计算(附代码) 在下午的学习过程中https://www.cnblogs.com/roccoshi/p/13032356.html 有一张图讲述了UDP的校验方法, 如下: 老师只粗 ...

  6. 目标检测性能评价——关于mAP计算的思考

    1. 基本要求 从直观理解,一个目标检测网络性能好,主要有以下表现: 把画面中的目标都检测到--漏检少 背景不被检测为目标--误检少 目标类别符合实际--分类准 目标框与物体的边缘贴合度高-- 定位准 ...

  7. asp.net中C#中计算时间差代码

    我用的最简单的办法是 代码如下 复制代码 DateTime dtone = Convert.ToDateTime("2007-1-1 05:32:22");DateTime dtw ...

  8. 使用java8的StreamAPI对集合计算进行代码重构

    方法: 查询出所有部门成员中年龄大于30的员工姓名 部门对象: 员工对象: 模拟数据: private static List<Dept> list=new ArrayList<De ...

  9. 计算Python代码运行时间长度方法

    在代码中有时要计算某部分代码运行时间,便于分析. import time start = time.clock() run_function() end = time.clock() print st ...

随机推荐

  1. hdu3986 spfa + 枚举最短路上的边

    题意: 删除一条边后,求最短路中最长的那个(敌人搞破坏). 思路: 如果你是敌人你肯定删除最短路上的边,删除别的边最短路的值是不会变的,所以直接枚举最短路上的边去删除,取得最大的就行了... #inc ...

  2. Android的so注入( inject)和函数Hook(基于got表) - 支持arm和x86

    本文博客地址:http://blog.csdn.net/qq1084283172/article/details/53942648 前面深入学习了古河的Libinject注入Android进程,下面来 ...

  3. IIS6目录解析漏洞的实验

    ​​​​​​​​​​Windows 打开IIS管理器的方式 这个是网站IIS网站目录 右击默认网站中的属性,可以查看网站的属性,比如网站根目录,或者是端口 这个是网站的目录C:\www,有三个文件分别 ...

  4. <JVM从入门到精通>导航

    笔记来源:尚硅谷JVM全套教程,百万播放,全网巅峰(宋红康详解java虚拟机) 同步更新:https://gitee.com/vectorx/NOTE_JVM https://codechina.cs ...

  5. Wampserver-删除虚拟主机

    对hosts操作 到目录C:\Windows\System32\drivers\etc中修改hosts 比如你想删除iwh2.com 选中这2行进行删除,保存退出 对httpd-vhosts操作 到目 ...

  6. 【maven】mvn不是内部命令 也不是可运行的程序

    按解压.配置环境变量,重启cmd,还是出现这个问题 使用java -version确定是不是安装了jdk.因为maven是java开发,需要依赖jdk 将系统变量中Path的%MAVEM_HOME%\ ...

  7. DevEco Device Tool 2.1 Beta1在Hi3861开发板上可视化分析的体验

    DevEco Device Tool迎来了2.1 Beta1,新版本有很多亮点.在上次"DevEco Device Tool 2.1 Beta1 的Hi3861在Windows平台的编译体验 ...

  8. 简单说几个MySQL高频面试题

    前言: 在各类技术岗位面试中,似乎 MySQL 相关问题经常被问到.无论你面试开发岗位或运维岗位,总会问几道数据库问题.经常有小伙伴私信我,询问如何应对 MySQL 面试题.其实很多面试题都是大同小异 ...

  9. 驰骋CCFlow开源工作流程引擎如何设置PDF打印

    前言 经常有驰骋CCFlow爱好者朋友提问关于打印相关问题.在这篇博文中大家介绍一下工作流引擎CCFlow的HTML打印和PDF打印,针对Java版本和.NET版本有不同的操作步骤,包括开关设置.水印 ...

  10. [Linux]常用命令、组合命令以及输入输出重定向

    [Linux]常用命令.组合命令以及输入输出重定向 2020-03-10阅读 1580   原创文章 文章目录 0.切换目录 1.复制文件和目录`cp` 1.1.复制文件 1.2.复制目录 1.3.扩 ...