[从零开始]使用ImageNet数据集实验

2024-09-05 01:38

本文主要是介绍[从零开始]使用ImageNet数据集实验,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

记录一下最近开始的ImageNet学习,论文中虽然提到了很多,也开源了训练代码,但是多数情况用自己的代码在相同的Condition就是难以复现,记录一点点目前的。

ImageNet,yyds

数据

数据下载源于官网 http://image-net.org/download,需要注册edu邮箱,一些参考:
下载imagenet2012数据集,以及label说明

下载下来的标签有不对应的情况,参考网上说的重新下一份caffe版本的,地址如下

caffe_ilsvrc12.tar.gz http://dl.caffe.berkeleyvision.org/

数据解压,python版本和shell版本

import osn = 0
unzip = os.listdir('./images')
print(len(unzip))
for i in os.listdir('./tars'):if('.tar' in i):if(i[:-4] in unzip):continuepath = os.path.join(os.getcwd(), 'images', i[:-4])tar = os.path.join(os.getcwd(), 'tars', i)os.system('mkdir {}'.format(path))os.system('tar -xvf {} -C {}'.format(tar, path))print(path)n += 1
print(n)
base=/path/to/data
for i in `ls *.tar`
dopath=$base${i%.tar}mkdir $pathtar -xvf $i -C $pathecho $path
done

训练

ImageNet的准确率在不同的训练策略下结果差异还是挺大的,参考了几篇论文的训练策略尝试复现结果。
部分训练代码已开源@git。

以下准确率是基于验证集(Validation Set)的结果

1. 训练环境

  • GPU: 32GB Tesla V100 * 4
  • Lib: pytorch 1.6

2. Table

一些固定setting,没有特殊说明则follow以下:

数据预处理,采用的albumentation

import albumentations as A
from albumentations.pytorch import ToTensorV2
# train
A.Compose([A.RandomResizedCrop(height=224, width=224),A.HorizontalFlip(p=0.5),A.Normalize(mean=(0.485, 0.456, 0.406), std=(0.229, 0.224, 0.225)),ToTensorV2()])
# val
A.Compose([A.Resize(height=256, width=256),A.CenterCrop(height=224, width=224),A.Normalize(mean=(0.485, 0.456, 0.406), std=(0.229, 0.224, 0.225)),ToTensorV2()])

采用的主干模型为Resnet50,由于采用了batch_size=256,没有使用sync_bn,pytorch1.6提供了混合精度训练(AMP),几行代码就能转换,极大节省了显存和训练时间。

# 一些固定setting
batch_size: 256
init_lr: 0.1
schedule: cos
warm_up: 10
total_epoch: 120
optimizer: SGD
weight_decay: 5e-4
momentum: 0.9
model: resnet50
sync_bn: False
amp: True
2.1 混合精度训练(AMP)

首先比较了混合精度训练,发现差异不大所以后面就用AMP来节约时间,用了sync_bn

假装有个Table结果被删掉了,找不到了,但是精度差不多

2.2 Sync_BN

比较了一下sync_bn的影响,顺便跑了LabelSmoothing

LossSchedulesync_bnbest_accbest_epochtotal_epochtime_per_epoch
CEcos, warm 10w76.04120120~720s
CEcos, warm 10wo76.22120120~540s
LS(0.1)cos, warm 10wo76.35120120/
LS(0.2)cos, warm 10wo76.45120120/
2.3 数据增强

因为有一篇论文提到了ColorJitter(CJ),故比较了一下使用增强的效果。

# 在train中加入
A.ColorJitter(brightness=0.4, contrast=0.4, saturation=0.4, hue=0, always_apply=False, p=0.5)

提升没有很明显。(那篇论文里的Baseline有77.5)

LossScheduleCJbest_accbest_epochtotal_epochtime_per_epoch
CEcos, warm 10w76.14120120~550s
2.4 更长时间的训练

大多数的训练策略都是以100~120epoch来训练ImageNet,但是从前面的结果来看全都是在最后一轮取得的最佳准确率,这与cos学习率衰减也有一定关系,学习率总是在最后几轮降低很快,准确率也主要在最后几轮提升。那么采用更多轮次的训练是否会有所提升。以下比较了300epoch和250epoch不同的训练策略。

LossSchedulebest_accbest_epochtotal_epoch
CEcos, warm 576.79299300
CEstep [75, 150, 225]76.01248250
2.5 Debug
  • batch_size和weight_decay调整
    前面说batch_size 256实际上是单卡256,而用了4张卡,因此实际上的batch_size计算应该为4 * 256,因此重新用了单卡batch_size 256来训练,时间从2天变成了5天,跑了250epoch,另外weight_decay 从5e-4变成了1e-4,结果上来看相比前面的有一点提升,但是具体是因为batch_size的变化还是weight_decay也不好说明,从跑的另一个实验来说提升是很明显的。单卡训练也避免了sync_bn的问题。结果基本与目前的论文结果能对应上。
LossSchedulebest_accbest_epochtotal_epoch
CEstep [75, 150, 225]76.32161250

Conclusion

以上尝试了几种ImageNet的训练策略,参考了一些论文的Setting,Baseline结果与大多数的论文的Baseline差不多(76.3)。但是从2.4可以看出不同的策略下结果差异很大,由于硬件条件有限,没有尝试的bags of tricks。训练次数小的时候(epoch in [90, 120]),似乎采用step衰减更有效。更长的时间cos衰减可能收敛效果更好。没有得到理想的结果,慢慢踩坑。

实验并不充分,还有一些问题需要解决,等有新的再补充。

Continue…

Code:https://github.com/Kurumi233/OnlineLabelSmoothing

这篇关于[从零开始]使用ImageNet数据集实验的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1137612

相关文章

C++类和对象之默认成员函数的使用解读

《C++类和对象之默认成员函数的使用解读》:本文主要介绍C++类和对象之默认成员函数的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、默认成员函数有哪些二、各默认成员函数详解默认构造函数析构函数拷贝构造函数拷贝赋值运算符三、默认成员函数的注意事项总结一

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可

Linux基础命令@grep、wc、管道符的使用详解

《Linux基础命令@grep、wc、管道符的使用详解》:本文主要介绍Linux基础命令@grep、wc、管道符的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录grep概念语法作用演示一演示二演示三,带选项 -nwc概念语法作用wc,不带选项-c,统计字节数-

SpringCloud中的@FeignClient注解使用详解

《SpringCloud中的@FeignClient注解使用详解》在SpringCloud中使用Feign进行服务间的调用时,通常会使用@FeignClient注解来标记Feign客户端接口,这篇文章... 在Spring Cloud中使用Feign进行服务间的调用时,通常会使用@FeignClient注解

MySQL的ALTER TABLE命令的使用解读

《MySQL的ALTERTABLE命令的使用解读》:本文主要介绍MySQL的ALTERTABLE命令的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、查看所建表的编China编程码格式2、修改表的编码格式3、修改列队数据类型4、添加列5、修改列的位置5.1、把列

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

SpringBoot使用ffmpeg实现视频压缩

《SpringBoot使用ffmpeg实现视频压缩》FFmpeg是一个开源的跨平台多媒体处理工具集,用于录制,转换,编辑和流式传输音频和视频,本文将使用ffmpeg实现视频压缩功能,有需要的可以参考... 目录核心功能1.格式转换2.编解码3.音视频处理4.流媒体支持5.滤镜(Filter)安装配置linu

Redis中的Lettuce使用详解

《Redis中的Lettuce使用详解》Lettuce是一个高级的、线程安全的Redis客户端,用于与Redis数据库交互,Lettuce是一个功能强大、使用方便的Redis客户端,适用于各种规模的J... 目录简介特点连接池连接池特点连接池管理连接池优势连接池配置参数监控常用监控工具通过JMX监控通过Pr

解决mysql插入数据锁等待超时报错:Lock wait timeout exceeded;try restarting transaction

《解决mysql插入数据锁等待超时报错:Lockwaittimeoutexceeded;tryrestartingtransaction》:本文主要介绍解决mysql插入数据锁等待超时报... 目录报错信息解决办法1、数据库中执行如下sql2、再到 INNODB_TRX 事务表中查看总结报错信息Lock