visdrone验证集标签可视化

为了方便实验对比结果,先在将visdrone的验证集可视化出来,脚本是git别人的,实测可行,分享给需要的人吧。
代码是根据xml标签可视化的,需要将visdrone的txt标签转成xml,可参考我另一篇文章:

import os
import os.path
import numpy as np
import xml.etree.ElementTree as xmlET
from PIL import Image, ImageDraw

#'1': 'people', '2': 'people','3': 'bicycle', '4': 'car', '5': 'car',
# 6':'others','7':'others','8':'others','9':'others','10': 'motor','11':'others'

classes = ('__background__', # always index 0
           'ignored regions','pedestrian', 'people','bicycle','car','van','truck','tricycle','awning-tricycle',
           'bus','motor','others')

# 把下面的路径改为自己的路径即可
file_path_img = r'D:\object_detection_data\datacovert\VisDrone2019-DET-val\images'
file_path_xml = r'D:\object_detection_data\datacovert\VisDrone2019-DET-val\Annotations_XML'
save_file_path = r'D:\object_detection_data\datacovert\VisDrone2019-DET-val\image_ann_show'

pathDir = os.listdir(file_path_xml)
for idx in range(len(pathDir)):
    filename = pathDir[idx]
    tree = xmlET.parse(os.path.join(file_path_xml, filename))
    objs = tree.findall('object')
    num_objs = len(objs)
    boxes = np.zeros((num_objs, 5), dtype=np.uint16)

    for ix, obj in enumerate(objs):
        bbox = obj.find('bndbox')
        # Make pixel indexes 0-based
        x1 = float(bbox.find('xmin').text)
        y1 = float(bbox.find('ymin').text)
        x2 = float(bbox.find('xmax').text)
        y2 = float(bbox.find('ymax').text)

        cla = obj.find('name').text
        label = classes.index(cla)

        boxes[ix, 0:4] = [x1, y1, x2, y2]
        boxes[ix, 4] = label

    image_name = os.path.splitext(filename)[0]
    img = Image.open(os.path.join(file_path_img, image_name + '.jpg'))

    draw = ImageDraw.Draw(img)
    for ix in range(len(boxes)):
        xmin = int(boxes[ix, 0])
        ymin = int(boxes[ix, 1])
        xmax = int(boxes[ix, 2])
        ymax = int(boxes[ix, 3])
        draw.rectangle([xmin, ymin, xmax, ymax], outline=(255, 0, 0))
        draw.text([xmin, ymin], classes[boxes[ix, 4]], (255, 0, 0))

    img.save(os.path.join(save_file_path, image_name + '.png'))

如代码所示只需要修改三个路径即可
在这里插入图片描述
可视化结果:
在这里插入图片描述

在这里插入图片描述

网上这方面的代码较少,找到了两三个不同版本,这个代码可视化出来的效果比较好。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
COCO数据集是一个广泛使用的图像识别和目标检测的数据集,包含着多个类别的标注信息,如人、车、动物等。为了更好地理解和分析COCO数据集的标签,我们可以使用可的方法。 首先,我们可以利用图像处理和计算机觉的技术,将COCO数据集中的图像进行读取和展示。可以使用Python编程语言中的OpenCV库或其他计算机觉库,读取图像数据,并在屏幕上显示出来。 其次,我们可以将标签信息与图像绑定在一起,用不同的颜色或形状来表示不同的类别。可以使用矩形框或者多边形来表示目标的位置和边界框,在框内部标注目标的类别名称。可以使用Python中的Matplotlib库或其他可工具,将图像中的目标标签展示出来。 另外,我们还可以将COCO数据集中的多张图像进行批量可,将多个图像的标签信息一目了然地展示出来。可以使用Python中的循环语句,遍历数据集中的每张图像,并依次进行展示。可以在每张图像上添加图像索引号,以便于对应和追踪。 同时,我们还可以利用可工具来统计和分析COCO数据集中的标签信息,比如每个类别的数量分布、类别之间的关系等。可以使用Python中的统计分析库,如Pandas和NumPy来进行数据处理和分析,并将结果以可的方式展示出来,比如柱状图、饼图等。 总之,可COCO数据集的标签信息,可以帮助我们更好地了解数据集的内容和特点,从而更好地进行图像识别和目标检测的研究和应用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值