voc2007数据集_Windows下SSD训练VOC2007

本文介绍了如何在Windows 10环境下使用Python 3.6和CUDA 9.0搭建TensorFlow-GPU 1.5.0环境,包括从GitHub克隆SSD-Tensorflow库、数据预处理(将VOC2007数据转为TFRecord)、训练过程中遇到的GPU资源限制及解决方法。重点讲述了修改代码以简化命令行参数和优化内存使用以避免OOM错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

52da8a296c1cdb2dbaba472985fe452a.png

环境

  • Windows10
  • Python == 3.6
  • cuda == 9.0
  • tensorflow-gpu == 1.5.0

-----------------------分割线------------------------------

仓库

https://github.com/balancap/SSD-Tensorflow​github.com
git clone https://github.com/balancap/SSD-Tensorflow.git
cd SSD-Tensorflow

数据集

http://host.robots.ox.ac.uk/pascal/VOC/voc2007/​host.robots.ox.ac.uk

解压模型

将SSD-Tensorflow/checkpoints下的ssd_300_vgg.ckpt.zip解压到当前文件夹下:

b0826b1b3aa3d30553dd93b5ae615f0b.png

-----------------------分割线------------------------------

踩坑过程

将数据和标签文件序列化为tfrecord

修改SSD-Tensorflow/datasets/pascalvoc_to_tfrecords.py中187行

# 修改前
def run(dataset_dir, output_dir, name='voc_train', shuffling=False):
#修改后
def run(dataset_dir, output_dir, name='voc_2007_train', shuffling=False):

并在SSD-Tensorflow目录下新建文件夹tfrecords文件夹, 在SSD-Tensorflow/datasets/pascalvoc_to_tfrecords.py最后添加:

if __name__ == '__main__':
    dataset = '你的数据集路径VOC2007'
    output = '../tfrecords/'
    run(dataset, output)

运行pascalvoc_to_tfrecords.py, 在SSD-Tensorflow/tfrecords下看到:

22a1643b46dcbae6d3fe17f5831bcd8a.png

序列化成功。

训练

修改SSD-Tensorflow/train_ssd_network.py文件,

# 修改前
            sync_optimizer=None)


if __name__ == '__main__':
    tf.app.run()

# 修改后:
            sync_optimizer=None)


def run():
    FLAGS.train_dir = './logs/'
    FLAGS.dataset_dir = './tfrecords'
    FLAGS.dataset_name = 'pascalvoc_2007'
    FLAGS.dataset_split_name = 'train'
    FLAGS.model_name = 'ssd_300_vgg'
    FLAGS.checkpoint_path = './checkpoints/ssd_300_vgg.ckpt'
    FLAGS.save_summaries_secs = 60
    FLAGS.save_interval_secs = 600
    FLAGS.weight_decay = 0.0005
    FLAGS.optimizer = 'adam'
    FLAGS.learning_rate = 0.001
    FLAGS.batch_size = 16
    tf.app.run()


if __name__ == '__main__':
    # tf.app.run()
    run()

这样修改的目的是不用在cmd中输入一堆参数。

修改后运行,如果遇到下列错误:

F tensorflow/core/kernels/conv_ops.cc:459] Check failed: stream->parent()->GetConvolveAlgorithms(&algorithms)
Aborted (core dumped)

修改SSD-Tensorflow/train_ssd_network.py文件第368行后面增加:

config.gpu_options.allow_growth = True

再次运行,如果遇到下面错误:

ResourceExhaustedError (see above for traceback): OOM when allocating tensor with shape

请将batch_size改小一些。

训练过程

955a4516b57001cdc94e5cee91532896.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值