EADST

YOLOv5: Data Preparation for Training

YOLOv5: Data Preparation for Training, from VOC Format to YOLO Format

First, split the data to train and val, and get txt files

import os
import random

train_percent = 0.95 xmlfilepath = 'bucket_v1/Annotations' txtsavepath = 'bucket_v1/ImageSets' total_xml = os.listdir(xmlfilepath)

num = len(total_xml) trainval = range(num) tr = int(num * train_percent) train = random.sample(trainval, tr)

ftrain = open('bucket_v1/ImageSets/Main/train.txt', 'w') fval = open('bucket_v1/ImageSets/Main/val.txt', 'w')

for i in trainval: name = total_xml[i][:-4] + '\n' if i in train: ftrain.write(name) else: fval.write(name)

Second, convert VOC format data (xml) to YOLO format data (txt)

import os
from tqdm import tqdm
from lxml import etree
import json
import shutil

voc_root = "/dfs/data/others/byolov5/dataset/bucket_v1" voc_version = "bucket_v1"

train_txt = "train.txt" val_txt = "val.txt" save_file_root = "/dfs/data/others/byolov5/dataset/yolo_data"

voc_images_path = os.path.join(voc_root, "JPEGImages") voc_xml_path = os.path.join(voc_root, "Annotations") train_txt_path = os.path.join(voc_root, "ImageSets", "Main", train_txt) val_txt_path = os.path.join(voc_root, "ImageSets", "Main", val_txt)

def parse_xml_to_dict(xml): if len(xml) == 0: return {xml.tag: xml.text} result = {} for child in xml: child_result = parse_xml_to_dict(child)
if child.tag != 'object': result[child.tag] = child_result[child.tag] else: if child.tag not in result:
result[child.tag] = [] result[child.tag].append(child_result[child.tag]) return {xml.tag: result}

def translate_info(file_names: list, save_root: str, class_dict: dict, train_val='train'): save_txt_path = os.path.join(save_root, train_val, "labels") if os.path.exists(save_txt_path) is False: os.makedirs(save_txt_path) save_images_path = os.path.join(save_root, train_val, "images") if os.path.exists(save_images_path) is False: os.makedirs(save_images_path)

for file in tqdm(file_names, desc="translate {} file...".format(train_val)):
    img_path = os.path.join(voc_images_path, file + ".jpg")
    assert os.path.exists(img_path), "file:{} not exist...".format(img_path)

    xml_path = os.path.join(voc_xml_path, file + ".xml")
    assert os.path.exists(xml_path), "file:{} not exist...".format(xml_path)

    # read xml
    with open(xml_path, encoding='UTF-8') as fid:
        xml_str = fid.read()
    xml = etree.fromstring(xml_str)
    data = parse_xml_to_dict(xml)["annotation"]
    img_height = int(data["size"]["height"])
    img_width = int(data["size"]["width"])
    # write object info into txt
    # assert "object" in data.keys(), "file: '{}' lack of object key.".format(xml_path)
    if "object" not in data.keys():
        print("Warning: in '{}' xml, there are no objects.".format(xml_path))
        continue

    with open(os.path.join(save_txt_path, file + ".txt"), "w") as f:
        for index, obj in enumerate(data["object"]):
            xmin = float(obj["bndbox"]["xmin"])
            xmax = float(obj["bndbox"]["xmax"])
            ymin = float(obj["bndbox"]["ymin"])
            ymax = float(obj["bndbox"]["ymax"])
            class_name = obj["name"]
            class_index = class_dict[class_name] - 1

            if xmax <= xmin or ymax <= ymin:
                print("Warning: in '{}' xml, there are some bbox w/h <=0".format(xml_path))
                continue

            xcenter = xmin + (xmax - xmin) / 2
            ycenter = ymin + (ymax - ymin) / 2
            w = xmax - xmin
            h = ymax - ymin

            xcenter = round(xcenter / img_width, 6)
            ycenter = round(ycenter / img_height, 6)
            w = round(w / img_width, 6)
            h = round(h / img_height, 6)

            info = [str(i) for i in [class_index, xcenter, ycenter, w, h]]

            if index == 0:
                f.write(" ".join(info))
            else:
                f.write("\n" + " ".join(info))

    # copy image into save_images_path
    path_copy_to = os.path.join(save_images_path, img_path.split(os.sep)[-1])
    if os.path.exists(path_copy_to) is False:
        shutil.copyfile(img_path, path_copy_to)

def main(): class_dict = {"b": 1, "t": 2} with open(train_txt_path, "r") as r: train_file_names = [i for i in r.read().splitlines() if len(i.strip()) > 0] translate_info(train_file_names, save_file_root, class_dict, "train") with open(val_txt_path, "r") as r: val_file_names = [i for i in r.read().splitlines() if len(i.strip()) > 0] translate_info(val_file_names, save_file_root, class_dict, "val")

if name == "main": main()

Reference:

Train Custom Data

相关标签
About Me
XD
Goals determine what you are going to be.
Category
标签云
Random ChatGPT TTS Shortcut Python Bitcoin RGB GoogLeNet FastAPI VPN Statistics Math Baidu XML 域名 CUDA NLTK Google Diagram BTC Tensor 关于博主 HaggingFace WAN Docker 多进程 财报 Base64 Heatmap Cloudreve FP32 TSV Datetime v2ray C++ PIP News Qwen2 ONNX FlashAttention Miniforge Mixtral API Conda Streamlit Knowledge SQL VGG-16 Review Input COCO Magnet llama.cpp 签证 Michelin scipy Data Web AI Qwen Qwen2.5 图形思考法 logger diffusers Django Numpy 图标 Color Quantize Search Llama LLM Land git Paddle PyCharm TensorFlow Pytorch Image2Text NameSilo Sklearn Breakpoint Template Ptyhon 证件照 Nginx DeepStream Attention Gemma Bert Vim 递归学习法 Ubuntu Bipartite FP8 CV 论文 公式 云服务器 OpenAI PDF 第一性原理 PDB Plotly 报税 QWEN Jupyter Crawler tqdm Vmess GPT4 Hungarian Agent Food DeepSeek Excel Bin UI RAR NLP Proxy BeautifulSoup Safetensors Windows 阿里云 Website Anaconda InvalidArgumentError FP64 PyTorch Markdown 顶会 继承 OCR Pickle 飞书 MD5 OpenCV Plate Password LoRA 论文速读 Domain 版权 SPIE Hotel Translation printf Zip Disk HuggingFace FP16 Use LaTeX icon TensorRT Video Interview Dataset CTC uWSGI Card EXCEL 净利润 CLAP Logo Linux ModelScope VSCode Clash WebCrawler GPTQ Hilton SAM YOLO 强化学习 音频 mmap uwsgi Permission 多线程 hf LLAMA Jetson GIT Tiktoken Transformers CAM Quantization LeetCode Rebuttal Tracking 搞笑 ResNet-50 Pandas UNIX SVR Algorithm transformers torchinfo 算法题 git-lfs tar v0.dev Augmentation Freesound CSV JSON Git XGBoost Firewall BF16 Github SQLite IndexTTS2 Paper 腾讯云 Pillow Claude Animate CEIR CC Distillation GGML
站点统计

本站现有博文328篇,共被浏览856384

本站已经建立2564天!

热门文章
文章归档
回到顶部