用mAP评估yolov3测试结果时用到的两段小代码

mAP的代码链接

对yolov3的测试代码进行了一点修改,将要检测的图片批量输入,再将检测结果分别保存到对应的txt文件中。但如果如果没有检测到框,就不会生成结果txt。

import os

path_new = './input/detection-results/'
path ='./input/ground-truth/'
list = os.listdir (path)
list2 = os.listdir (path_new)
for j in range(len(list)):
    name_d = [str (i) for i in list[j]]
    name = ''.join(name_d)
    # name2 = name.replace('png','txt')
    if name in list2:
        continue
    else:
        # os.remove(path+name)
        print(path+name)

目的就是检测出哪个图片没有被检测出目标,可以考虑把它删除掉或者移动到其他文件夹,便于后续分析。

import os

path = './input/ground-truth/'
path_new ='./input/ground-truth/'
list = os.listdir (path)
for j in range(len(list)):
    name_d = [str (i) for i in list[j]]
    name = ''.join (name_d)
    new_name = path_new+name
    f = open (path + name)
    fns = [line.strip () for line in f]
    for i in range(len(fns)):
        line = fns[i]
        lines = line.split (' ')
        x,y,w,h,cls = float(lines[0]),float(lines[1]),float(lines[2]),float(lines[3]),lines[4]
        x1=x-w/2
        y1=y-h/2
        x2=x+w/2
        y2=y+h/2
        with open (new_name, 'a+') as g:
            i = cls +' '+ str(x1) +' '+str(y1) + ' ' + str(x2) +' '+str(y2)+'\n'
            g.write(str(i))
            print(str(i))
    g.close()

因为我的数据集格式和这个算法默认的格式不太匹配,所以把它规范一下~

告知:需要学习YOLOv4进行TT100K数据集上中国交通标志识别的学员请前往(1) Ubuntu系统《YOLOv4目标检测实战:中国交通标志识别》课程链接:https://edu.youkuaiyun.com/course/detail/29362(2)《Windows版YOLOv4目标检测实战:中国交通标志识别》课程链接:https://edu.youkuaiyun.com/course/detail/29363在无人驾驶中,交通标志识别是一项重要的任务。本课程中的项目以美国交通标志数据集LISA为训练对象,采用YOLOv3目标检测方法实现实交通标志识别。具体项目过程包括包括:安装Darknet、下载LISA交通标志数据集、数据集格式转换、修改配置文件、训练LISA数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。YOLOv3基于深度学习,可以实地进行端到端的目标检测,以速度快见长。本课程将手把手地教大家使用YOLOv3实现交通标志的多目标检测。本课程的YOLOv3使用Darknet,在Ubuntu系统上做项目演示。 Darknet是使用C语言实现的轻型开源深度学习框架,依赖少,可移植性好,值得深入学习和探究。除本课程《YOLOv3目标检测实战:交通标志识别》外,本人推出了有关YOLOv3目标检测的系列课程,请持续关注该系列的其它课程视频,包括:《YOLOv3目标检测实战:训练自己的数据集》《YOLOv3目标检测:原理与源码解析》《YOLOv3目标检测:网络模型改进方法》另一门课程《YOLOv3目标检测实战:训练自己的数据集》主要是介绍如何训练自己标注的数据集。而本课程的区别主要在于学习对已标注数据集的格式转换,即把LISA数据集从csv格式转换成YOLOv3所需要的PASCAL VOC格式和YOLO格式。本课程提供数据集格式转换的Python代码。请大家关注以上课程,并选择学习。下图是使用YOLOv3进行交通标志识别的测试结果
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值