coco语义分割标注json转png

news/2024/5/20 7:35:06 标签: 语义分割, coco, cityscapes

        COCO格式的语义分割数据json,转为png格式,如CityScapes采用的。使用本脚本可以将coco格式转为CityScapes格式的语义标注。语义分割标注转为png图片格式,可便于进行语义分割标注结果可视化,及时查看标注效果。

        语义分割标注是对图像每个像素的类别进行标注,采用图片形式标注更加直观。

        函数名称为cocojson2png,代码如下所示。

# -*- coding: utf-8 -*-
"""
Created on Fri Apr  8 2022
@author: suiyingy
"""
import cv2
import numpy as np
import os
import json
from collections import defaultdict

def cocojson2png(coco_dir, json_path='instances_train2017.json', cls_type = 'train2017', save_dir = 'res/'):
    save_path = os.path.join(save_dir, cls_type)
    if not os.path.exists(save_path):
        os.makedirs(save_path)
    annotation_file = os.path.join(coco_dir, 'annotations', json_path)
    with open(annotation_file, 'r', encoding='utf-8') as annf:
        annotations = json.load(annf)
        images = [i['id'] for i in annotations['images']]

    img_anno = defaultdict(list)
    for anno in annotations['annotations']:
        for img_id in images:
            if anno['image_id'] == img_id:
                img_anno[img_id].append(anno)
    imgid_file = {}
    for im in annotations['images']:
        imgid_file[im['id']] = im['file_name']

    for img_idx in img_anno:
        image = cv2.imread(coco_dir+'images/'+cls_type+'/'+imgid_file[img_idx])
        h, w, _ = image.shape
        instance_png = np.zeros((h, w), dtype=np.uint8)
        for idx, ann in enumerate(img_anno[img_idx]):
            im_mask = np.zeros((h, w), dtype=np.uint8)
            mask = []
            for an in ann['segmentation']:
                ct = np.expand_dims(np.array(an), 0).astype(int)
                contour = np.stack((ct[:, ::2], ct[:, 1::2])).T
                mask.append(contour)
            imm = cv2.drawContours(im_mask, mask, -1, 1, -1)
            imm = imm * (1000 * anno['category_id'] + idx)
            instance_png = instance_png + imm
            instance_png = np.clip(instance_png,0 ,255)
        instance_png = np.expand_dims(instance_png,axis=2).repeat(3,axis=2).astype(np.uint8)
    
        print(instance_png.shape)
        cv2.imwrite(os.path.join(save_path, imgid_file[img_idx].split('.')[0]+".png"), instance_png)

if __name__ == '__main__':
    coco_dir = "coco/"
    cocojson2png(coco_dir, json_path='instances_train2017.json')

更多三维、二维感知算法和金融量化分析算法请关注“乐乐感知学堂”微信公众号,并将持续进行更新。


http://www.niftyadmin.cn/n/1257607.html

相关文章

C#重写ToString

C# 中的每个类或结构都可隐式继承 <xref:System.Object> 类。 因此&#xff0c;C# 中的每个对象都会获取 <xref:System.Object.ToString%2A> 方法&#xff0c;该方法返回该对象的字符串表示形式。 例如&#xff0c;类型为 int 的所有变量都有一个 ToString 方法&am…

Java 用post请求调用webservice

先说下遇到的坑&#xff0c;最先用post请求的时候一直返回500的错误码 最终通过打印错误信息分析&#xff0c;请求头必须添加SOAPAction //请求头必须设置SOAPAction connection.setRequestProperty("SOAPAction","application/soapxml; charsetutf-8");…

c语言中,在结构体中如何将void *转存为具体需要的数据类型

1. 只需要将该void *类型成员&#xff0c;强制转换为具体的数据类型指针即可。需要注意的是&#xff0c;该强制转换是有风险的&#xff0c;转换时&#xff0c;必须确定void*指向内存实际数据为目标结构体格式&#xff0c;否则可能会出现内存越界访问&#xff0c;从而导致程序出…

Anaconda和pip异常

一、Anaconda异常 1 No module named ‘unicodedata‘ 正常使用时出现这个问题&#xff0c;与其想着怎么解决&#xff0c;不如直接重装python环境或者试试卸载并重新安装pip。卸载并重新安装pip请参考博客python pip使用总结&#xff08;持续更新&#xff09;_Coding的叶子的博…

python点云可视化

Python三种点云可视化方案&#xff1a;mayavi、matplotlib、CloudCompare。 方案一&#xff1a;mayavi可视化点云 安装方式&#xff1a; pip install mayavi 可视化代码&#xff1a;其中airplane_0001.txt数据下载地址为&#xff1a;modelnet40点云样例数据-深度学习文档类…

python三维点云投影(一)

一、立体几何基础知识 1.1 平面表示 三维平面的统一表示方法&#xff1a; 1.2 法向量 假设&#xff08;x1, y1, z1&#xff09;、&#xff08;x2&#xff0c;y2&#xff0c;z2&#xff09;为平面上两个点&#xff0c;那么可以得到&#xff1a; (x2-x1, y2-y1, z2-z1)是平面上…

svn提交代码报错Server SSL certificate verification failed

使用IntelliJ IDEA 2019.3.1开发工具中的svn提交代码报错&#xff1a; Problems while loading file history: svn: E170013: Unable to connect to a repository at URL https://192.168.0.204/svn/project/xxx项目 svn: E230001: Server SSL certificate verifi…

VS2017 libTorch cpu 环境搭建

C libTorch cpu 环境搭建 一、下载libTorch 下载地址&#xff1a;Start Locally | PyTorch。 可以在图中选择下载cuda版本或cpu版本的。 以CPU Release版本的libTorch为例&#xff0c;下载地址为&#xff1a; https://download.pytorch.org/libtorch/cpu/libtorch-win-shar…