使用Tensorflow Object Detection进行训练和推理
整体流程(以PASCAL VOC为例)
1.下载PASCAL VOC2012数据集,并将数据集转为tfrecord格式
2.选择并下载预训练模型
3.配置训练文件configuration(所有的训练参数都通过配置文件来配置)
4.训练模型
5.利用tensorboard查看训练过程中loss,accuracy等变化曲线
6.冻结模型参数
7.调用冻结pb文件进行预测
文件格式
首先建立一下文件结构,把models/research/object_detection/data下的label_map.pbtxt文件移动到自己建立的data下。
label_map.txt:定义了class id和class name的映射
文件结构如下:
.
├── data/
│ ├── eval-00000-of-00001.tfrecord # file
│ ├── label_map.txt # file
│ ├── train-00000-of-00002.tfrecord # file
│ └── train-00001-of-00002.tfrecord # file
└── models/
└── my_model_dir/
├── eval/ # Created by evaluation job.
├── my_model.config # pipeline config
└── model_ckpt-100-data@1 #
└── model_ckpt-100-index # Created by training job.
└── checkpoint #
把label_map.pbtxt移动过去(以PASCAL VOC2012为例):
cp /xxx/models/research/object_detection/data/pascal_label_map.pbtxt ./data/
准备输入数据
Tensorflow Object Detection API使用TFRecord格式的数据。提供了create_pascal_tf_record.py
和create_pet_tf_record.py
两个脚本来转换PASCAL VOC和Pet数据集到TFRecord格式。
产生PASCAL VOC的TFRecord文件
如果本地没有数据集的话,使用如下命令下载数据集(here):
wget http://host.robots.ox.ac.uk/pascal/VOC/voc2012/VOCtrainval_11-May-2012.tar
tar -xvf VOCtrainval_11-May-2012.tar
使用如下命令将PSACAL VOC转换成TFRecord格式:
Examples:data_dir改为自己的数据集路径
# From tensorflow/models/research/
python object_detection/dataset_tools/create_pascal_tf_record.py \
--label_map_path=/root/data/pascal_label_map.pbtxt \
--data_dir=/data2/VOC2007/VOCdevkit --year=VOC2007 --set=train \
--output_path=/root/data/pascal_train.record
python object_detection/dataset_tools/create_pascal_tf_record.py \
--label_map_path=/root/data/pascal_label_map.pbtxt \
--data_dir=/data2/VOC2007/VOCdevkit --year=VOC2007 --set=val \
--output_path=/root/data/pascal_val.record
- data_dir:PASCAL VOC的数据集的路径
- output_dir:想保存TFRecord的路径
执行完上述命令后可以在research文件夹下,看到pascal_train.record
和pascal_val.record
两个文件。
Generating the COCO TFRecord files.
COCO数据集的位置: here.
使用如下命令将COCO转换成TFRecord格式:
Examples:路径改为自己的路径
# From tensorflow/models/research/
python object_detection/dataset_tools/create_coco_tf_record.py --logtostderr \
--train_image_dir=/data2/datasets/coco/train2017 \
--val_image_dir=/data2/datasets/coco/val2017 \
--test_image_dir=/data2/datasets/coco/unlabeled2017 \
--train_annotations_file=/data2/datasets/coco/annotations/instances_train2017.json \
--val_annotations_file=/data2/datasets/coco/annotations/instances_val2017.json \
--testdev_annotations_file=/data2/datasets/coco/annotations/image_info_test-dev2017.json \
--output_dir=/root/data
执行完上述命令后可以在research文件夹下,可以看到coco开头的许多文件。
同时要把coco的pbtxt移动到output_dir
下。
使用Tensorflow1进行训练和推理
配置训练的Pipeline
Tensorflow Object Detection API使用protobuf文件来配置训练和推理流程。训练的Pipeline模板可以在object_detection/protos/pipeline.proto中找到。同时object_detection/samples/configs 文件夹中提供了简单的可以直接使用的配置。
下面主要介绍配置的具体内容。
整个配置文件可以分成五个部分:
- model:
- train_config
- eval_config
- train_input_config
- eval_input_config
整体结构如下:
model {
(... Add model config here...)
}
train_config : {
(... Add train_config here...)
}
train_input_reader: {
(... Add train_input configuration here...)
}
eval_config: {
}
eval_input_reader: {
(... Add eval_input configuration here...)
}
选择模型参数
需要注意修改 num_classes
的值去适配自己的任务。
定义输入
支持TFRecord格式的输入。需要指明training和evaluation的文件位置,label map的位置。traning和evaluation数据集的label map应该是相同的。
例子:
tf_record_input_reader {
input_path: "/usr/home/username/data/train.record"
}
label_map_path: "/usr/home/username/data/label_map.pbtxt"
配置Trainer
train_config
定义了三部分训练流程:
- 模型参数初始化
- 输入预处理:可选的
- SGD参数
例子:
batch_size: 1
optimizer {
momentum_optimizer: {
learning_rate: {
manual_step_learning_rate {
initial_learning_rate: 0.0002
schedule {
step: 0
learning_rate: .0002
}
schedule {
step: 900000
learning_rate: .00002
}
schedule {
step: 1200000
learning_rate: .000002
}
}
}
momentum_optimizer_value: 0.9
}
use_moving_average: false
}
fine_tune_checkpoint: "/usr/home/username/tmp/model.ckpt-#####"
from_detection_checkpoint: true
load_all_detection_checkpoint_vars: true
gradient_clipping_by_norm: 10.0
data_augmentation_options {
random_horizontal_flip {
}
}
配置Evaluator
eval_config
中主要的设置为num_examples
和metrics_set
。
num_examples
:batches的大小metrics_set
: 在evaluation的时候使用什么metrics
Model Parameter Initialization
关于checkpoint的使用。配置文件中的train_config
部分提供了两个已经存在的checkpoint:
fine_tune_checkpoint
:一个路径前缀(ie:"/usr/home/username/checkpoint/model.ckpt-#####").fine_tune_checkpoint_type
:classification/detection
A list of classification checkpoints can be found here.
A list of detection checkpoints can be found here.
Training
单机单卡
Template:
# From the tensorflow/models/research/ directory
PIPELINE_CONFIG_PATH={path to pipeline config file}
MODEL_DIR={path to model directory}
NUM_TRAIN_STEPS=50000
SAMPLE_1_OF_N_EVAL_EXAMPLES=1
python object_detection/model_main.py \
--pipeline_config_path=${PIPELINE_CONFIG_PATH} \
--model_dir=${MODEL_DIR} \
--num_train_steps=${NUM_TRAIN_STEPS} \
--sample_1_of_n_eval_examples=${SAMPLE_1_OF_N_EVAL_EXAMPLES} \
--alsologtostderr
Examples:
python object_detection/model_main.py \
--pipeline_config_path=/root/my_models/faster_rcnn_resnet101_voc07.config \
--model_dir=/root/my_models/checkpoint \
--num_train_steps=1 \
${PIPELINE_CONFIG_PATH}
:pipeline config的路径${MODEL_DIR}
:训练产生的checkpoint的保存文件路径num_train_steps
:train steps的数量num_worker
:= 1:MirroredStrategy
> 1:MultiWorkerMirroredStrategy.
单机多卡
单机多卡和单机单卡使用的不是用一个启动程序
Examples:
CUDA_VISIBLE_DEVICES=0,1 python object_detection/legacy/train.py \
--pipeline_config_path=/root/my_models/faster_rcnn_resnet101_voc07.config
--train_dir=/root/my_models/checkpoint \
--num_clones=2 \
--ps_tasks=1
train_dir
:训练产生的checkpoint的保存文件路径num_clones
:通常有几个gpu就是几ps_tasks
:parameter server的数量。Default:0,不使用ps
多机多卡
官方没有给出多机多卡的使用方式,google查到的一个是基于hadoop集群实现的分布式训练
Evaluation
单机单卡
Template:
# From the tensorflow/models/research/ directory
PIPELINE_CONFIG_PATH={path to pipeline config file}
MODEL_DIR={path to model directory}
CHECKPOINT_DIR=${MODEL_DIR}
MODEL_DIR={path to model directory}
python object_detection/model_main_tf2.py \
--pipeline_config_path=${PIPELINE_CONFIG_PATH} \
--model_dir=${MODEL_DIR} \
--checkpoint_dir=${CHECKPOINT_DIR} \
--alsologtostderr
Examples:
python object_detection/model_main_tf2.py \
--pipeline_config_path=/root/my_models/faster_rcnn_resnet101_voc07.config \
--model_dir=/root/my_models \
--checkpoint_dir=/root/my_models/checkpoint
${CHECKPOINT_DIR}
:训练产生的checkpoint的地址。如果使用了这个参数,就会是eval-only的模式,evaluation metrix会存在model_dir路径下。${MODEL_DIR/eval}
:推理产生的events的地址
单机多卡
Examples:
CUDA_VISIBLE_DEVICES=0,1 python object_detection/legacy/eval.py \
--checkpoint_dir=/root/my_models/checkpoint \
--eval_dir=/root/my_models/eval \
--pipeline_config_path=/root/my_models/faster_rcnn_resnet101_voc07.config
使用Tensorflow2进行训练和推理
Training
Template:
# From the tensorflow/models/research/ directory
PIPELINE_CONFIG_PATH={path to pipeline config file}
MODEL_DIR={path to model directory}
python object_detection/model_main_tf2.py \
--pipeline_config_path=${PIPELINE_CONFIG_PATH} \
--model_dir=${MODEL_DIR} \
--alsologtostderr
Examples:
python object_detection/model_main_tf2.py \
--pipeline_config_path=/root/my_models/faster_rcnn_resnet101_voc07.config \
--model_dir=/root/my_models/checkpoint
${PIPELINE_CONFIG_PATH}
:pipeline config的路径${MODEL_DIR}
:训练产生的checkpoint的保存文件路径
注:tf2下默认使用MirroredStrategy(),会直接使用当前机器上的全部GPU进行训练。如果只用一部分卡可以指定卡号,如strategy = tf.compat.v2.distribute.MirroredStrategy(devices=["/gpu:0", "/gpu:1"])
,使用了第0号和第1号卡。
Evaluation
Template:
# From the tensorflow/models/research/ directory
PIPELINE_CONFIG_PATH={path to pipeline config file}
MODEL_DIR={path to model directory}
CHECKPOINT_DIR=${MODEL_DIR}
MODEL_DIR={path to model directory}
python object_detection/model_main_tf2.py \
--pipeline_config_path=${PIPELINE_CONFIG_PATH} \
--model_dir=${MODEL_DIR} \
--checkpoint_dir=${CHECKPOINT_DIR} \
--alsologtostderr
Examples:
python object_detection/model_main_tf2.py \
--pipeline_config_path=/root/my_models/faster_rcnn_resnet101_voc07.config \
--model_dir=/root/my_models/checkpoint \
--checkpoint_dir=/root/my_models/checkpoint/eval
${CHECKPOINT_DIR}
:training产生的checkpoints的路径${MODEL_DIR/eval}
:evaluation events保存的路径
多机多卡
参考Tensorflow1.X的多机多卡部分
常见问题
单机多卡训练时报错:
ValueError: not enough values to unpack (expected 7, got 0)
配置文件中batchsize设置成了1。batchsize需要设置成和num_clones同样的大小。
Tensorflow2.X下使用Faster-RCNN模型报错:
RuntimeError: Groundtruth tensor boxes has not been provide
Tensorflow object detection api在2021/2之后的某次更新中新引入的bug,可以checkout到旧的commit id(31e86e8)。然后重新安装object detection api。
Reference
- https://blog.csdn.net/qq_37541097/article/details/101711261
- https://www.daimajiaoliu.com/daima/479a2cacf9003fc
使用Tensorflow Object Detection进行训练和推理的更多相关文章
- 使用TensorFlow Object Detection API+Google ML Engine训练自己的手掌识别器
上次使用Google ML Engine跑了一下TensorFlow Object Detection API中的Quick Start(http://www.cnblogs.com/take-fet ...
- 基于TensorFlow Object Detection API进行迁移学习训练自己的人脸检测模型(二)
前言 已完成数据预处理工作,具体参照: 基于TensorFlow Object Detection API进行迁移学习训练自己的人脸检测模型(一) 设置配置文件 新建目录face_faster_rcn ...
- 谷歌开源的TensorFlow Object Detection API视频物体识别系统实现教程
视频中的物体识别 摘要 物体识别(Object Recognition)在计算机视觉领域里指的是在一张图像或一组视频序列中找到给定的物体.本文主要是利用谷歌开源TensorFlow Object De ...
- TensorFlow object detection API
cloud执行:https://github.com/tensorflow/models/blob/master/research/object_detection/g3doc/running_pet ...
- Tensorflow object detection API 搭建属于自己的物体识别模型
一.下载Tensorflow object detection API工程源码 网址:https://github.com/tensorflow/models,可通过Git下载,打开Git Bash, ...
- Tensorflow object detection API 搭建物体识别模型(四)
四.模型测试 1)下载文件 在已经阅读并且实践过前3篇文章的情况下,读者会有一些文件夹.因为每个读者的实际操作不同,则文件夹中的内容不同.为了保持本篇文章的独立性,制作了可以独立运行的文件夹目标检测. ...
- Tensorflow object detection API 搭建物体识别模型(三)
三.模型训练 1)错误一: 在桌面的目标检测文件夹中打开cmd,即在路径中输入cmd后按Enter键运行.在cmd中运行命令: python /your_path/models-master/rese ...
- Tensorflow object detection API 搭建物体识别模型(二)
二.数据准备 1)下载图片 图片来源于ImageNet中的鲤鱼分类,下载地址:https://pan.baidu.com/s/1Ry0ywIXVInGxeHi3uu608g 提取码: wib3 在桌面 ...
- [Tensorflow] Object Detection API - predict through your exclusive model
开始预测 一.训练结果 From: Testing Custom Object Detector - TensorFlow Object Detection API Tutorial p.6 训练结果 ...
随机推荐
- 将VMware工作站最小化到托盘栏
目录 前言 将VMware最小化到托盘栏的方法 1.下载 Trayconizer 2.解压 trayconizerw.zip 3.创建 VMware 快捷方式 4.修改 VMware 快捷方式 5.运 ...
- 读懂一个中型的Django项目
转自https://www.cnblogs.com/huangfuyuan/p/Django.html [前言]中型的项目是比较多的APP,肯会涉及多数据表的操作.如果有人带那就最好了,自己要先了解基 ...
- Java编程开发之数据图表分析模型
数据统计分析 多曲线图表分析实现 基本需求分析 假设在怪兽出没的年岁,加上年关在即,需要统计分析各个道路卡口车流量出入统计,主要从车流量和车牌地角度出发.如图所示的业务需求: 道路卡口-车流量分析: ...
- 03.从0实现一个JVM语言系列之语法分析器-Parser-03月01日更新
从0实现JVM语言之语法分析器-Parser 相较于之前有较大更新, 老朋友们可以复盘或者针对bug留言, 我会看到之后答复您! 源码github仓库, 如果这个系列文章对你有帮助, 希望获得你的一个 ...
- kali 将家目录下的中文文件名修改成英文
修改vim ~/.config/user-dirs.dirs 打开`文件,删除那些中文目录 在目录下创建英文目录 重启 参考 https://elementaryos.stackexchange.co ...
- jQuery实现QQ简易聊天框
实现效果: html代码: <section id="chat"> <div class="chatBody"></div> ...
- 面试常备,字符串三剑客 String、StringBuffer、StringBuilder
尽人事,听天命.博主东南大学硕士在读,热爱健身和篮球,乐于分享技术相关的所见所得,关注公众号 @ 飞天小牛肉,第一时间获取文章更新,成长的路上我们一起进步 本文已收录于 「CS-Wiki」Gitee ...
- Keytool 工具使用
Keytool 管理私钥仓库(keystore)和与之相关的 X.509 证书链(用以验证与私钥对应的公钥),也可以用来管理其他信任实体 keytool 将密钥和证书存储在一个所谓的密钥仓库中,缺省的 ...
- 优秀的vue服务端渲染框架
目前国内优秀的基于vue的ssr框架有minissr,可以在服务端生成html代码,有利于搜索引擎爬取. https://www.wechatmini.com/vue/minissr 使用方法可以参考 ...
- FHRP - 网关冗余协议
通常情况下,在终端设备进入网络前,都会有一个 Router 充当网络,作为第一跳的网络地址.但假设路由器发生故障,此时终端设备就无法再接入互联网. 为了防止这样的问题,一般会再加入一台路由器充当备份. ...