交通指示牌识别

涉及单分类,多分类问题,共计5W多样本,43个类,包括一个注释的标签数据源:German Traffic Sign Benchmarks
摘要由CSDN通过智能技术生成

1. 背景说明

涉及单分类,多分类问题,共计5W多样本,43个类,以及一个标注文件(包括文件名、宽、高以及坐标)。其中每类图片数量不均等,图片尺寸也不尽相同。

数据源:German Traffic Sign Benchmarks

下载训练与测试数据目录如下:

这里只识别“STOP”、“禁止通行”、“直行”、“环岛行驶”四个类别。对应训练目录下的类别文件夹分别为00014, 00017, 00035, 00040。

2. 数据集切分

1. 将Final_training 目录按7:2:1切分为训练集、验证集、测试集三个文件夹,每个文件夹又分为“STOP”、“禁止通行”、“直行”、“环岛行驶”四个子目录。

11

import shutil
from pathlib import Path
from glob import glob
import numpy as np

def split_train_val_test_dataset(data_dir, data_sets, class_names, class_indices, train_folder):
    # 1. 创建对应目录
    for dt in data_sets:
        for cls in class_names:
            # exist_ok=True时,在目录已存在的情况下,不会触发FileExistsError异常
            (data_dir/dt/cls).mkdir(parents=True, exist_ok=True)

    # 2. 将原始数据集进行切分,并拷贝图片到目标文件夹
    for i, cls_index in enumerate(class_indices):
        img_paths = np.array(glob(f'{train_folder[int(cls_index)]}/*.ppm'))
        class_name = class_names[i]  # 标签
        print(f'{class_name}: {len(img_paths)}')
        np.random.shuffle(img_paths)   # 打乱图片路径
        # 对img_paths进行切分,本质上是索引切分,indices_or_sections定义切分点(0.7和0.9)
        ds_split = np.split(
            img_paths,
            indices_or_sections=[int(0.7*len(img_paths)), int(0.9*len(img_paths))]
        )
        dataset = zip
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
告知:需要学习YOLOv4进行TT100K数据集上中国交通标志识别的学员请前往(1) Ubuntu系统《YOLOv4目标检测实战:中国交通标志识别》课程链接:https://edu.csdn.net/course/detail/29362(2)《Windows版YOLOv4目标检测实战:中国交通标志识别》课程链接:https://edu.csdn.net/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、付费专栏及课程。

余额充值