本文主要是介绍PaddleX实现交通标志识别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 一、PaddleX介绍
- 二、数据集准备
- 三、Faster RCNN目标检测
一、PaddleX介绍
PaddleX简介:PaddleX是飞桨全流程开发工具,集飞桨核心框架、模型库、工具及组件等深度学习开发所需全部能力于一身,打通深度学习开发全流程,并提供简明易懂的Python API,方便用户根据实际生产需求进行直接调用或二次开发,为开发者提供飞桨全流程开发的最佳实践。目前,该工具代码已开源于GitHub,同时可访问PaddleX在线使用文档,快速查阅读使用教程和API文档说明。
PaddleX代码GitHub链接:https://github.com/PaddlePaddle/PaddleX/tree/develop
PaddleX文档链接:https://paddlex.readthedocs.io/zh_CN/latest/index.html
PaddleX官网链接:https://www.paddlepaddle.org.cn/paddle/paddlex
- PaddleX安装
PaddleX有桌面版和集成库,这里面我们使用库进行开发
pip install paddlex -i https://mirror.baidu.com/pypi/simple
二、数据集准备
数据集我们采用VOC格式的,如果换成其他的,我们的数据接口格式就得修改。这个是目录
hk_det.zip
│ labels.txt
│ test_list.txt
│ train_list.txt
│ val_list.txt
│
├─Annotations
│ (存放.xml文件)
│
└─JPEGImages
(存放图片)
三、Faster RCNN目标检测
import os
# 选择使用0号卡
os.environ['CUDA_VISIBLE_DEVICES'] = '0'from paddlex.det import transforms
import paddlex as pdx# 下载和解压昆虫检测数据集
insect_dataset = 'https://bj.bcebos.com/paddlex/datasets/insect_det.tar.gz'
pdx.utils.download_and_decompress(insect_dataset, path='./')# 定义训练和验证时的transforms
train_transforms = transforms.Compose([transforms.MixupImage(mixup_epoch=250),transforms.RandomDistort(),transforms.RandomExpand(),transforms.RandomCrop(),transforms.Resize(target_size=608, interp='RANDOM'),transforms.RandomHorizontalFlip(),transforms.Normalize(),
])eval_transforms = transforms.Compose([transforms.Resize(target_size=608, interp='CUBIC'),transforms.Normalize(),
])# 定义训练和验证所用的数据集
train_dataset = pdx.datasets.VOCDetection(data_dir='insect_det',file_list='insect_det/train_list.txt',label_list='insect_det/labels.txt',transforms=train_transforms,shuffle=True)
eval_dataset = pdx.datasets.VOCDetection(data_dir='insect_det',file_list='insect_det/val_list.txt',label_list='insect_det/labels.txt',transforms=eval_transforms)# 初始化模型,并进行训练
# 可使用VisualDL查看训练指标
# VisualDL启动方式: visualdl --logdir output/yolov3_darknet/vdl_log --port 8001
# 浏览器打开 https://0.0.0.0:8001即可
# 其中0.0.0.0为本机访问,如为远程服务, 改成相应机器IP
num_classes = len(train_dataset.labels)
model = pdx.det.YOLOv3(num_classes=num_classes, backbone='DarkNet53')
model.train(num_epochs=270,train_dataset=train_dataset,train_batch_size=8,eval_dataset=eval_dataset,learning_rate=0.000125,lr_decay_epochs=[210, 240],save_dir='output/yolov3_darknet53',use_vdl=True)
实验结果
这篇关于PaddleX实现交通标志识别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!