SSD-tensorflow512训练自己的数据集

1.下载ssd-tensorflow工程压缩包

Github:https://github.com/balancap/SSD-Tensorflow

2.解压

checkpoints文件夹下ssd_300_vgg.ckpt压缩文件删除,将下载的ssd512模型放在此处。

链接:https://pan.baidu.com/s/13rXshm9s8D-7BjX0bNhpkg 提取码:f0k5 

3.准备训练数据

按照VOC2007格式制作自己的数据集,SegmentationObject & SegmentationClass保存的是物体分割后的数据,在物体识别中没有用到。

(1)Annotations存放xml格式的标签文件,每个xml对应JPEGImage中的一张图片。

(2)ImageSets里main文件夹中放入train.txt, val.txt, trainval.txt, test.txt四个文件,txt文件内容为图片的文件名(不带后缀),train.txt用于训练的图片文件的文件名列表;val.txt——训练过程用来验证的图片文件的文件名列表,一般保持和train中图片数量相近;trianval.txt——用来训练和验证的图片文件的文件名列表,数量为train和val中图片数量之和;test.txt——用来测试已训练的模型的文件名列表,数量一般和trainval中图片数量相近。

以下是生成.txt文件的代码:

import os  
import random   
  
xmlfilepath=r'/home/VOC2007/Annotations/'  
saveBasePath=r"/home/VOC2007/ImageSets/"  
  
trainval_percent=0.9
train_percent=0.9  
total_xml = os.listdir(xmlfilepath)  
num=len(total_xml)    
list=range(num)    
tv=int(num*trainval_percent)    
tr=int(tv*train_percent)    
trainval= random.sample(list,tv)    
train=random.sample(trainval,tr)    
  
print("train and val size",tv)  
print("traub suze",tr)  
ftrainval = open(os.path.join(saveBasePath,'Main/trainval.txt'), 'w')    
ftest = open(os.path.join(saveBasePath,'Main/test.txt'), 'w')    
ftrain = open(os.path.join(saveBasePath,'Main/train.txt'), 'w')    
fval = open(os.path.join(saveBasePath,'Main/val.txt'), 'w')    
  
for i  in list:    
    name=total_xml[i][:-4]+'\n'    
    if i in trainval:    
        ftrainval.write(name)    
        if i in train:    
            ftrain.write(name)    
        else:    
            fval.write(name)    
    else:    
        ftest.write(name)    
    
ftrainval.close()    
ftrain.close()    
fval.close()    
ftest .close()
  • 0
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 11
    评论
您好!对于使用SSD(Single Shot MultiBox Detector)训练自己的数据集,您可以按照以下步骤进行操作: 1. 数据集准备:收集并标注您自己的数据集,确保每个样本都有正确的边界框标注和相应的类别标签。您可以使用标注工具,如LabelImg,进行标注。 2. 数据集格式转换:将数据集转换为SSD所需的格式。SSD使用Pascal VOC或COCO等标准格式。您可以使用数据转换工具,如convert2ssd.py脚本,将数据集转换为SSD可接受的格式。 3. 配置网络模型:根据您的需求和数据集的类别数,选择合适的SSD网络模型。您可以在网络模型配置文件中进行相关设置,如设置输入图像大小、锚框尺寸和比例等。 4. 数据集划分:将数据集划分为训练集和验证集。通常,80%的数据用于训练,20%的数据用于验证。 5. 训练模型:使用标注好的数据集进行模型训练。您可以使用深度学习框架,如TensorFlow或PyTorch,加载SSD网络模型,并结合优化算法(如随机梯度下降)进行模型训练。 6. 模型评估和调优:在训练过程中,您可以定期评估模型在验证集上的性能,并进行相应的调优,如调整学习率、增加训练轮次等。 7. 模型推理:在完成模型训练后,您可以使用该模型进行目标检测任务。通过将输入图像传入SSD模型,您可以获取检测到的目标边界框和对应的类别标签。 请注意,这只是一个基本的概述,具体的实现细节可能因您使用的深度学习框架和数据集格式而有所不同。同时,由于SSD算法较为复杂,可能需要一定的计算资源和时间来完成训练过程。祝您成功训练自己的SSD模型!如果您有任何进一步的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值