EfficientDet

注:第一次写博客,记录一下
1.下载作者大神的代码:
pytorch
2.下载EfficicentNet的预训练模型,最好是使用,我下载的是efficientdet-d2.pth
3.数据集放的位置
datasets
coco
annotations
train2017
val2017

4.在projects/coco.yml里面替换自己训练的名字:
mean和std替换自己的
5.在efficientdet/config.py 把类别进行修改:COCO_CLASSES

6.开始训练
注:可以加上数据增强,提高它的泛化能力
在这里插入图片描述
python train.py -c 2 --batch_size 12 --lr 1e-4 --num_epochs 20 --load_weights logs/coco/efficientdet-d2.pth

![在这里插入图片描述](https://img-blog.csdnimg.cn/20200415123553630.png?x-oss-process=image/watermark,type_ZmxXzQyNjgwMzIx,size_16,color_F在这里插入图片描述

7.进行评估:
如果不出结果:把 label + 1即可
在这里插入图片描述
python coco_eval.py -p coco -c 2 -w /logs/coco/efficientdet-d2_6_35973.pth

8.进行测试
注:最好使用d0,d1,d2预训练模型进行训练,d5一块显卡跑不动
python efficientdet_test.py
在这里插入图片描述

注:训练、评估和测试需要修改一些自己的名称
注:如有侵权还忘告知

EfficientDet是一种高效的目标检测算法,旨在提高目标检测的准确性和效率。它基于EfficientNet模型,通过在不同尺度的特征层上进行多尺度特征融合和级联特征筛选,有效地提高了检测性能。 要复现EfficientDetPyTorch版本,首先需要准备相关的代码和数据集。可以从GitHub上找到官方提供的EfficientDet代码库,并下载相应的预训练权重和示例数据集。 在复现过程中,需要了解EfficientDet的网络结构和训练策略。EfficientDet主要由骨干网络、特征网络和目标检测头组成。骨干网络通常采用EfficientNet作为特征提取器,特征网络基于FPN和BiFPN来融合不同尺度的特征,而检测头则负责预测目标的位置和类别。 在编写代码时,需要按照EfficientDet的网络结构构建PyTorch模型,并加载预训练权重。可以使用PyTorch提供的各种库和函数来实现网络的构建和训练过程。训练过程通常涉及数据加载、前向传播、损失计算和反向传播等步骤。 为了复现EfficientDet,还需要选择适当的损失函数和优化器。常用的目标检测损失函数包括交叉熵损失和IoU损失。优化器可以选择Adam或SGD等常用的优化器。 在训练过程中,通常需要设置适当的学习率、批量大小和训练轮数等超参数,并进行调优以提高模型的性能。可以通过监控训练过程中的验证集性能来选择最佳的模型。 在复现EfficientDet时,还可以根据具体需求进行一些改进和优化。例如,可以尝试使用更大的图像分辨率、调整多尺度训练策略、增加数据增强方法等来提高模型的性能。 总之,复现EfficientDetPyTorch版本需要理解其网络结构和训练策略,并按照这些原理进行代码实现和相关参数的设置。通过合理调整超参数和优化方法,可以达到和原论文相近甚至更好的目标检测性能。
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值