加入极市专业CV交流群,与 10000+来自港科大、北大、清华、中科院、CMU、腾讯、百度 等名校名企视觉开发者互动交流!
同时提供每月大咖直播分享、真实项目需求对接、干货资讯汇总,行业技术交流。关注 极市平台 公众号 ,回复 加群,立刻申请入群~
导语:SimCLR将自监督学习推向了高潮,引起了学术界的大轰动。现在SimCLRv2来了,那么它有带来了哪些新的思想呢?又有哪些值得期待的点呢?我们先来对SimCLRv2进行一番简单的解读分析。文末附论文下载方式。
一种从少量带标签数据+大量无标签数据中进行学习的方案是:现在无标签数据集上采用无监督学习方案进行预训练,然后采用监督学习方式在少量带标签数据上进行微调。尽管方案中的无标签数据上的无监督学习是一种任务不可知方式(不同于其他CV中半监督学习),但是令人惊讶的是这种半监督学习的放在ImageNet上极为有效。
该方案的一个重要组成是预训练和微调阶段采用了“大模型”。作者发现:越少的标签数据,该方法越能从更大的模型中受益。经过微调后,大模型可以进一步得以改善并蒸馏更多信息到小模型中(注:蒸馏阶段会对无标签数据进行二次利用,此时该数据将以任务已知方式进行应用)。
总而言之,所提半监督方法可以总结为三步;(1)采用SimCLRv2方法在无标签数据上对一个Big ResNet
模型进行预训练;(2)在有标签数据上通过有监督方式进行微调;(3)在无标签数据上采用蒸馏方式进行进行知识迁移。
所提方法在仅仅采用1%有标签数据时,ResNet50取得了73.9%的top-1精度;当采用10%有标签数据时,ResNet50的精度达到了77.5%的top-1精度。这个精度超越了采用全部有标签数据时有监督训练的精度。
少量有标签数据+大量无标签数据的学习问题是机器学习中存在已有的问题。其中一种知名的方法是半监督学习,它包含无监督或自监督训练,后接有监督微调。在预训练阶段该方法以任务未知方式利用无标签数据,而有标签数据仅应用于微调阶段。尽管这类方法在CV领域受到的关注较少,但它已成为NLP领域的主流方案(比如首先在无标签文本数据上训练一个大的语言模型,然后在有标签数据上微调该模型)。在CV领域,常用的一种方案是:直接在以监督方式利用无标签数据(起正则作用)。这时的无标签数据是以任务已知方式进行利用,即:要求多个不同模型在无标签数据上的预测类标签具有一致性;或者在不同数据增广方式下输出的类别标签相一致。
受启发于视觉表达领域自监督学习的进展,该文首次对ImageNet上“无监督预训练、有监督微调”的半监督学习进行了系统研究。在自监督预训练阶段,图像以任务不可知方式进行应用,也就是说通过这种方式学习到的表达方式不会存在对特定分类任务的倾向性。作者发现:对于无监督数据的这种任务不可知的应用而言,模型的大小至关重要。在自监督预训练阶段采用更大的模型,那么微调后的性能也会更高。除此之外,作者还描绘了对比学习中几个重要的设计选项。
一旦卷积网络完成预训练和微调,作者发现:模型的任务已知预测属性可以进一步改善并蒸馏到一个更小的网络中。为此,作者对无标签数据进行了二次利用以促使学生网络尽可能的模拟老师网络的标签预测性能。所提方法的蒸馏阶段采用伪标签方式且不会造成额外的更多复杂度。
总而言之,所提半监督方法可以总结为三步;(1)采用SimCLRv2方法在无标签数据上对一个Big ResNet
模型进行预训练;(2)在有标签数据上通过有监督方式进行微调;(3)在无标签数据上采用蒸馏方式进行进行知识迁移。整个流程见下图。
针对ResNet的无监督预训练,作者在SimCLR基础上进行了改进并称之为SimCLRv2.在仅仅采用1%和10%有标签数据时评估了所提方案的有效性,该方案主要包含下面三个贡献:
组合上述发现得到了ImageNet上的半监督学习的SOTA性能,见上图2.SimCLRv2取得了79.8%的top-1精度,以4.3%绝对优势超过了此前SOTA方法。当仅仅采用1%和10%有标签数据进行微调并蒸馏到相同模型后,模型的指标分别为76.6%和80.9%,分别以21.6%和8.7%的绝对优势超越了已有SOTA方法。通过蒸馏,上述性能改进可以迁移到更小的ResNet50网络并取得了73.9%和77.5%的top1精度。相比较而言,ImageNet上有监督训练得到的ResNet50的精度为76.6%top精度。
受启发于无标检数据的成功学习,所提半监督学习方案以任务未知和任务已知两种方式利用无标签数据。首先,采用任务未知方式利用无标签数据进行无监督预训练以学习广义视觉特征表达;然后;所学习的广义特征表达通过有监督微调进行方式;最后;采用任务已知方式利用无标签数据进行模型蒸馏。为达到该目的,作者提出在无标签数据集上训练一个学生模型,而标签则来自微调后的老师模型。该方案可以总结为:pretrain
, fine-tune
, distill
.见下图。
为更好的从无标签数据上学习广义视觉特征表达,作者对SimCLR进行了改进。SimCLR通过最大化不同增广数据之前的一致性进行学习。给定输入图像 ,它将被增广两次,构建关于同一数据两次增广 ,这两个图像通过编码网络 进行编码得到更易特征表达 。这些特征表达然后经过非线性变换网络 进行变换得到 并用于对比学习。对比损失定义如下:
其中 表示余弦相似性, 表示温标参数。
在这里,作者基于SimCLR提出了三个主要改进得到了SimCLRv2,总结如下:
微调是将任务未知预训练模型迁移到任务已知中常用技巧。在SimCLR的微调阶段,非线性网络 会被直接完整丢弃而仅仅保留编码器部分 进行微调。而在SimCLRv2中则是集成非线性网络的一部分(第一层)进行微调。
作者精心构建了一个三层projection head ,其中 表示ReLU激活函数,为简单起见这里忽略了偏置项。在微调阶段,SimCLR采用 进行微调;而SimCLRv2则是采用 进行微调。这一点点的改进是不是看上去非常简单?能想到并去做才是难的!
为进一步改善网络在特定任务上的性能,作者提出直接采用无标签数据进行特定任务学习。那么标签从何而来呢?伪标签咯。将签署微调模型作为老师模型并给出无标签数据对应的伪标签用于蒸馏学生模型。蒸馏阶段采用KL散度就可以了,有没有觉得很简单,方法都是现成的。
这个方法感觉跟Google之前提出的Noisy Student
有异曲同工之妙,感兴趣的小伙伴可以去看一下谷歌的Noisy Student
(https://arxiv.org/pdf/1911.04252v1.pdf)一文。
沿着无监督学习的设置方式,作者在ImageNet数据集上进行了实验分析。注:作者采用的优化器是LARS。
在预训练阶段,batch=4096,硬件平台128CloudTPU,同时采用了全局BatchNorm,训练了800epoch。学习率在前5%epoch线性提升到6.4然后按照余弦方式衰减,权值衰减因子为0.0001。非线性网路 为三层感知器。记忆buffer设置为64K,同时采用了EMA技术。增广技术类似于SimCLR,即随机裁剪、颜色都懂以及高斯模糊。
在微调阶段,作者对非线性网络的第一层进行了微调。采用了全局BatchNorm,但移除了权值衰减、学习率warmup,而是采用了更小的学习率0.16和0.064用于标准ResNet和更大ResNet。batch=1024,在1%数据上微调60epoch,在10%数据上微调30epoch。
在蒸馏阶段,作者提出仅仅采用无标签数据进行蒸馏。作者采用了两种类型的蒸馏:自蒸馏与Big-to-small
蒸馏。采用了与预训练相同的学习率机制、权值衰减以及batch。合计训练400epoch,此时仅仅采用随机裁剪、随机镜像数据增广。
下表给出了自监督、有监督在不同模型大小下的性能评估。可以看到:提升模型宽度、深度以及添加SK可以取得更好的性能。
下图给出了不同模型大小不同标签数据时的性能对比。
下图给出了非线性网络部分改善前后的性能对比。
最后,下图给出了蒸馏阶段的性能对比。更多实验对比分析建议查看原文。
这篇比较详细的描述了如何在SimCLR基础上改进得到SimCLRv2的过程,整个思路的转换非常清晰自然。通篇看下来,最大的感觉就是它和Noisy Student相同之处真的非常多,流程与思想都非常的相似。
论文与代码链接
paper:https://arxiv.org/abs/2006.10029
code:https://github.com/google-research/simclr
推荐阅读
添加极市小助手微信(ID : cv-mart),备注:研究方向-姓名-学校/公司-城市(如:目标检测-小极-北大-深圳),即可申请加入极市技术交流群,更有每月大咖直播分享、真实项目需求对接、求职内推、算法竞赛、干货资讯汇总、行业技术交流,一起来让思想之光照的更远吧~
△长按添加极市小助手
△长按关注极市平台,获取最新CV干货
觉得有用麻烦给个在看啦~