Windows+Yolo3-darknet训练自己数据集并测试

本文指导如何在Windows7系统上配置VS2015、OpenCV3.4.2等环境,利用Yolo3和CUDA进行数据集制作、网络模型预训练,并详细说明了修改配置文件以适应特定类别和训练过程。
摘要由CSDN通过智能技术生成

Windows+Yolo3-darknet训练自己的数据集并测试

一、首要条件
Windows 7下配置好VS2015+OPENCV3.4.2+YOLO3+CUDA10.0+CUDNN7.5生成darknet.exe。具体配置可参考我的博客:https://blog.csdn.net/wszswllnzn_/article/details/100760477
二.制作数据集
1、方法1
使用软件labelImg制作数据集,生成.mxl文件或直接将VOC格式改为Yolo格式,保存时自动生成.txt文件。
在这里插入图片描述
2、方法2
为了简化工作,直接下载VOC-Yolo数据集,将该数据集的VOCdevkit文件夹拷贝到…\darknet-mastexunlianr\build\darknet目录下。将…\darknet-masterxunlian\scripts目录下的voc_label.py文件拷贝到…\darknet-master\build\darknet\VOCdevkit目录下,并重命名为voclabel_xunlian.py,打开进行如下修改。

# 第7行修改所需sets
sets=[('2007', 'train'), ('2007', 'val'),  ('2007', 'test')]
 
# 第9行修改为自己的类别
classes = ["a", "b", "c", "d"]
 
# 第26、27行修改路径,可改为绝对路径
    in_file = open('VOC%s/Annotations/%s.xml'%(year, image_id))
    out_file = open('VOC%s/labels/%s.txt'%(year, image_id), 'w')
 
# 第48、49、50行修改路径,可改为绝对路径
    if not os.path.exists('VOC%s/labels/'%(year)):
        os.makedirs('VOC%s/labels/'%(year))
    image_ids = open('VOC%s/ImageSets/Main/%s.txt'%(year, image_set)).read().strip().split()
 
# 第53行修改路径,可改为绝对路径
        list_file.write('%s/VOC%s/JPEGImages/%s.jpg\n'%(wd, year, image_id))

完成后在VOCdevkit文件夹中生成如下文件:
在这里插入图片描述
在VOC2007文件夹中生成labels文件:
在这里插入图片描述
三、下载网络模型预训练权重
下载后保存在:.\darknet-masterxunlian\build\darknet\x64目录下新建的weights_pr文件夹中。下载链接如下:http://pjreddie.com/media/files/darknet53.conv.74
四、修改参数
1、修改网络配置文件,.\darknet-masterxunlian中的Makefile,使用什么就设置什么为1。我使用的是GPU版本训练。
在这里插入图片描述
2、打开…\darknet-masterxunlian\build\darknet\x64\data中的voc.data

classes=2 
train  = D:\darknet-masterxunlian\build\darknet\VOCdevkit\2007_train.txt 
valid  = D:\darknet-masterxunlian\build\darknet\VOCdevkit\2007_val.txt 
#difficult = data/difficult_2007_test.txt
names = data/voc.names
backup = D:\darknet-masterxunlian\build\darknet\VOCdevkit\results_mine

3、打开.\darknet-masterxunlian\build\darknet\x64\data中的voc.names(修改为自己的类别)

bird
car

4、打开…\darknet-masterxunlian\build\darknet\x64中的yolov3-voc.cfg

# 第1-7行
[net]
# Testing
# batch=1
# subdivisions=1
# Training
batch=64            # 可修改参数,控制训练时的batchsize
subdivisions=32
 
# 第20行修改迭代次数
max_batches = 50200
 
# 第605、689、773行
filters=27  # 修改为3×(5+类别数)
 
# 第611、695、779行
classes=2   # 修改为类别数
 
# 第616、700、784行
random=1    # 多尺度输出为1,显存小时改为0关闭

五、训练

打开cmd,cd到…\darknet-masterxunlian\build\darknet\x64目录下,在此目录下新建results_xunlian文件夹,输入命令:darknet.exe detector train .\data\voc.data yolov3-voc.cfg .\weights_pr\darknet53.conv.74 .\results_xunlian 每迭代1000次在results_xunlian中就会生成一个权重文件。

  • 6
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
YOLO-Segment是基于YOLOv3目标检测的语义分割模型。通过训练自己的数据集,我们可以让模型具有特定的目标检测和语义分割能力。 首先,需要准备自己的数据集数据集应包括训练集、验证集和测试集。训练集应包括足够多的样本,以覆盖我们感兴趣的目标。每个样本应包含标注的图像,即我们需要标注方框来框出目标,并用分割掩码圈出目标区域。验证集和测试集应该包括各种场景和角度,用于评估模型的泛化能力。 其次,需要修改YOLO-Segment的代码来适应自己的数据集。我们需要修改数据预处理、模型配置、损失函数和反向传播等步骤,以适应我们的数据集。还需要修改加载自己数据集的操作,并修改自己数据集的类别数量和名称。 接下来,使用修改后的代码进行训练训练过程应该包括多次迭代,每次迭代应该包括前向传播、损失计算和反向传播等步骤。在训练时,我们应该监控模型训练损失和验证损失,以确定模型是否过拟合或欠拟合。 最后,使用训练好的模型来进行预测。我们可以用训练好的模型在自己的数据集上进行测试,以验证模型准确度。预测的结果应该是目标检测的框和分割掩码,用于表征目标的形状和大小。 总之,训练自己的数据集需要准备数据、修改代码、进行训练和进行预测等步骤。需要持久耐心和技术,才能让模型具有准确可靠的分割和检测能力。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值