zoukankan      html  css  js  c++  java
  • coco 数据集显示

    参考链接: https://blog.csdn.net/zym19941119/article/details/80241663

    # coding=UTF-8
    from pycocotools.coco import COCO
    import skimage.io as io
    import matplotlib.pyplot as plt
    import pylab
    import cv2
    import os
    from skimage.io import imsave
    import numpy as np
    pylab.rcParams['figure.figsize'] = (8.0, 10.0)
    
    img_path = 'maskrcnn-benchmark/datasets/coco/val2014/'
    annFile = 'maskrcnn-benchmark/datasets/coco/annotations/instances_val2014.json'
    
    if not os.path.exists('anno_image_coco/'):
        os.makedirs('anno_image_coco/')
    
    
    def draw_rectangle(coordinates, image, image_name):
        for coordinate in coordinates:
            left = np.rint(coordinate[0])
            right = np.rint(coordinate[1])
            top = np.rint(coordinate[2])
            bottom = np.rint(coordinate[3])
            # 左上角坐标, 右下角坐标
            cv2.rectangle(image,
                          (int(left), int(right)),
                          (int(top), int(bottom)),
                          (0, 255, 0),
                          2)
        imsave('anno_image_coco/'+image_name, image)
    
    
    # 初始化标注数据的 COCO api
    coco = COCO(annFile)
    
    # display COCO categories and supercategories
    cats = coco.loadCats(coco.getCatIds())
    nms = [cat['name'] for cat in cats]
    # print('COCO categories: 
    {}
    '.format(' '.join(nms)))
    
    nms = set([cat['supercategory'] for cat in cats])
    # print('COCO supercategories: 
    {}'.format(' '.join(nms)))
    
    
    catIds_1 = coco.getCatIds(catNms=['yuanhuan','yellow', 'green', 'red','indicator'])
    
    imgIds_1 = coco.getImgIds(catIds=catIds_1)
    #imgIds_1 = coco.getImgIds(catIds=[1,2])
    #img_path = 'data/train/'
    img_list = os.listdir(img_path)
    # for i in range(len(img_list)):
    for i in range(7):
        # imgIds = i+1
        # img = coco.loadImgs(imgIds)[0]
        # image_name = img['file_name']
        # print(img)
    
        img = coco.loadImgs(imgIds_1[np.random.randint(0, len(imgIds_1))])[0]
        image_name = img['file_name']
    
    
    
        # 加载并显示图片
        # I = io.imread('%s/%s' % (img_path, img['file_name']))
        # plt.axis('off')
        # plt.imshow(I)
        # plt.show()
    
        # catIds=[] 说明展示所有类别的box,也可以指定类别
        annIds = coco.getAnnIds(imgIds=img['id'], catIds=[], iscrowd=None)
        anns = coco.loadAnns(annIds)
    
        coco.showAnns(anns)
        
    
        # print(anns)
        coordinates = []
        img_raw = cv2.imread(os.path.join(img_path, image_name))
        for j in range(len(anns)):
            coordinate = []
            coordinate.append(anns[j]['bbox'][0])
            coordinate.append(anns[j]['bbox'][1]+anns[j]['bbox'][3])
            coordinate.append(anns[j]['bbox'][0]+anns[j]['bbox'][2])
            coordinate.append(anns[j]['bbox'][1])
            # print(coordinate)
            coordinates.append(coordinate)
        # print(coordinates)
        draw_rectangle(coordinates, img_raw, image_name)
    
  • 相关阅读:
    Ubuntu安装GTK+教程
    Qt 错误GL/gl.h: No such file or directory的解决方法
    Qt 解决Could not start process "make" qmake_all问题
    Feign解决服务之间调用传递token
    python闭包和装饰器
    python高阶函数
    ping 和 traceroute 的区别
    ICMP协议
    OSPF协议
    RIP协议
  • 原文地址:https://www.cnblogs.com/yanghailin/p/11246432.html
Copyright © 2011-2022 走看看