深度学习目标检测算法SSD300 训练自己的数据与测试(基于Keras WIN10 Python3.6)数据集制作、代码详细介绍 (源代码、相关软件及权值下载)

本文主要是介绍深度学习目标检测算法SSD300 训练自己的数据与测试(基于Keras WIN10 Python3.6)数据集制作、代码详细介绍 (源代码、相关软件及权值下载),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基于Keras搭建的SSD300目标检测神经网络

先看看效果(图片来源:视觉中国 www.vcg.com,这里只做演示使用,我也不获利,请视觉中国不要告我,实在不让我用就联系我删了吧,感恩
在这里插入图片描述

1. 运行需要的模块

代码运行需要部分必须的Python模块包括:(部分依赖模块未列出)

  • Keras >= 2.0.0
  • TensorFlow >= 1.7.0
  • Tensorboard >= 1.7.0
  • numpy >= 1.9.0
  • opencv >= 3.3.1

2. 测试代码运行情况

下载好的代码及权值文件(源代码及权值文件免费下载见文章尾
最终你的项目文件夹应该是这样的
在这里插入图片描述

将下载好的权值文件放在 SSD300_Train/weights 文件夹中
运行 SSD_test.py 即可得到上图的效果 ~ ~
如果没报错就说明的Python环境配置正确了,恭喜进入下一阶段

3. SSD_test.py 讲解

项目自带的权值文件是以VOC数据集训练的,能够检测20种目标。详细内部实现不作详细讲解,主要介绍下面的主要部分。

在这里插入图片描述

4. 训练自己的数据集

4.1 创建自己的数据集

代码的数据集使用的VOC的数据格式(不知道的请自行百度一下,这里不细说),使用ImgLabel软件标注,软件下载可以去GitHub搜索imglabel源代码copy下来,使用方法请自行百度。文章尾部也给出了已经编译好了的exe版本下载地址(免费),嫌麻烦的也可以直接下载我上传到CSDN上的版本

重点!!!!!!
  • 在进行标计前建议将拍摄的原始图像进行一定的缩放,保证图片的大小在200k左右,要不训练超级慢。
  • 标记前请一定先确定好自己数据集存放的位置,一旦确定就不要变了,要不会很麻烦。
    具体原因:代码中图片的具体读取是通过 读取标记文件(.xml)中的图片路径来读取图片的(如下图中红线的部分),如果数据集位置变了但文件中有没改这里,就会读取不到图片。
    使用我上传到CSDN上的imglabel软件标注的同学可能会注意到路径中缺少文件后缀,请不要担心,继续往下看
    在这里插入图片描述
  • 标注时同一类目标的名称一定要完全一样(包括大小写),要不就不是同一类了不是?
  • 标注完毕后在数据集文件夹中创建一个name.txt,将数据集中的类别名称填入文件中,每个类名一行(例如下图),一定要和数据集中的类名完全一样。

5. 开始训练

训练包括两部,第一步生成标记数据文件(文件夹中的my_new_data.pkl);第二步配置训练参数开始训练。

5.1 生成标记数据文件

注意:每次更改训练集内的图片都应该重新生成标记数据文件!!!!
生成标记数据文件主要用到 TransData.py
使用时主要修改main函数
在这里插入图片描述
4.1中提到的.xml文件中的图片路径中缺少文件后缀同学请执行下一步,如果没有出现文件后缀丢失,请忽略。
在这里插入图片描述
没有后缀的在这里添加上后缀(包括后缀中的点), 如果数据集中的图片后缀不统一的话还是写个脚本将.xml文件中的后缀添加上,有需要的同学请评论联系我。
生成成功后应该会有一个.pkl文件产生(或者更新覆盖原来的)。

5.2 配置训练参数开始训练

主要修改TrainSSD.py文件
修改参数主要包括以下几个:

  • 设置训练集的比例
    此处设置训练集的个数占总的数据集的0.8,剩下的0.2为测试集在这里插入图片描述

  • 设置训练的batch_size
    此处设置batch_size为每个batch 16张在这里插入图片描述

  • 设置冻结层
    这里涉及到迁移学习的一点概念思想,感兴趣的同学建议自己查查。这里我们将产生特征层的网络部分冻结起来,只训练类别预测和位置回归的部分,这样即使训练集很小也可以获得不错的训练效果。当然如果你的训练集比较大还是重头训练的好。
    在这里插入图片描述

  • 设置基础学习率
    训练时学习率采用指数下降方式,每训练一个epoch,梯度都会改变,这里设置的是基础学习率
    在这里插入图片描述

  • 设置训练回合数
    这里设置训练100回合在这里插入图片描述

5.3 开始训练

按实际情况更改下列变量的值
在这里插入图片描述
修改完成后,开始训练,每训练一个回合后,权值文件会自动保存,同时代码中设置了Tensorboard的回调函数,可以调用tensorboard可视化训练信息。

调用tensorboard

打开cmd cd 到项目文件夹中 输入 tensorboard --logdir logs
将返回的连接复制到浏览器中打开即可

下载源代码

为了保障所有人能免费下载到源代码,同时推广一下自己建立的公众号(主要分享一些教程),请扫描下方二维码关注公众号回复相应的关键字获取下载链接

  • 源代码及权值下载地址:回复“SSD训练”。

  • imglabel标注工具下载地址:回复“标注工具

  • 有需要rely源码的直接回复“rely下载”,就不一一发邮箱了。

在这里插入图片描述

这篇关于深度学习目标检测算法SSD300 训练自己的数据与测试(基于Keras WIN10 Python3.6)数据集制作、代码详细介绍 (源代码、相关软件及权值下载)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/935537

相关文章

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

zookeeper端口说明及介绍

《zookeeper端口说明及介绍》:本文主要介绍zookeeper端口说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、zookeeper有三个端口(可以修改)aVNMqvZ二、3个端口的作用三、部署时注意总China编程结一、zookeeper有三个端口(可以

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核