DINOv2:无需微调,填补 SAM 的空白,支持多个下游任务
本文入选【技术写作训练营】优秀结营作品,作者:王悦天
前段时间,Meta AI 高调发布了 Segment Anything(SAM),SAM 以交互式方式快速生成 Mask,并可以对从未训练过的图片进行精准分割,可以根据文字提示或使用者点击进而圈出图像中的特定物体,其灵活性在图像分割领域内属首创。
但是,归根到底 SAM 是一个 promptable segmentation system,主要应用于各种分割任务,对其他的视觉任务(e.g. Classification, Retrieval,VQA...)的帮助没有那么直接。
于是,继【分割一切】之后,Meta AI 再次发布重量级开源项目——DINOv2,DINOv2 可以抽取到强大的图像特征,且在下游任务上不需要微调,这使得它适合作为许多不同的应用中新的 BackBone。
与之前发布的 Segment Anything 相比,DINOv2 在应用领域和适用范围上更加广泛,文中的实验也涵盖了多个 CV 中经典的下游任务。
Paper:
https://arxiv.org/abs/2304.07193
Code:
https://github.com/facebookresearch/dinov2
Demo:
https://dinov2.metademolab.com/
MMPreTrain 已经支持了 DINOv2 backbone 的推理,欢迎使用:
https://github.com/open-mmlab/mmpretrain/tree/main/configs/dinov2
主要特性
在 Meta AI 官方的Blog中,将 DINOv2 的特性总结如下:
DINOv2 是一种训练高性能计算机视觉模型的新方法。
DINOv2 提供了强大的性能,并且不需要微调。
由于是自监督( self-supervision),DINOv2 可以从任何图像集合中学习。同时,它还可以学习到当现有方法无法学习的某些特征,例如深度估计。
DINOv2 是一种新的高性能计算机视觉模型训练方法,使用自监督学习来实现与该领域中使用的标准方法相匹配或超越结果。与其他自监督系统一样,使用 DINOv2 方法的模型可以在不需要任何相关元数据的情况下对任何图像集合进行训练。这意味着它可以从它所接收到的所有图像中学习,而不仅仅是那些包含特定一组标签或 alt 文本或标题的图像。DINOv2 提供了可直接用作简单线性分类器输入的高性能特征。这种灵活性意味着 DINOv2 可用于创建许多不同计算机视觉任务的多用途骨干。
文中的实验展示了 DINOv2 在下游任务上的出色能力,例如分类、分割和图像检索等应用领域。其中,最令人惊讶的是,在深度估计方面,DINOv2 的结果明显优于 in-domain 与 out-of-domain 的 SOTA 的 pipeline。作者认为这种强大的域外表现是自监督特征学习和轻量级任务特定模块(例如线性分类器)相结合的结果。
最后,由于不采用 fine-tuning,骨干保持通用,同一特征可以同时用于许多不同任务。
研究内容
这里,我们不展开 DINOv2 的具体算法细节,只简要介绍一下 DINOv2 主要干了些什么(个人看法,欢迎讨论)。
创建了一个新的高质量数据集
Building a large, curated, and diverse dataset to train the models
在如今的大模型时代,为了进一步提高性能,往往更大的模型需要更多的数据进行训练。由于没有足够大的高质量数据集来满足 DINOv2 的训练需求,Meta AI 通过从大量未经整理的数据池中检索与几个经过整理的数据集中的图像相近的图像,来组建一个新的数据集。具体流程如下所示:
This approach enabled us to produce a pretraining dataset totaling 142 million images out of the 1.2 billion source images.
下面我们来具体看一看数据集构建的 pipeline,主要有数据源(Data sources.),去重(Deduplication.)与自监督图像检索(Self-supervised image retrieval.)三个部分。
▶ 数据源(Data sources.)
首先,LVD-142M 数据集的来源共包含两部分,即公开数据集和网络数据集。
公开数据集
如下表所示,包含 ImageNet-22k、ImageNet-1k、Google Landmarks 和几个细粒度数据集的训练拆分:
网络数据集网络数据集简单理解就是通过从公开可用的爬取网络数据存储库中收集原始未过滤的图像数据集,再对这些数据分三步清洗:
首先,针对每个感兴趣的网页,从标签中提取出图像的 URL 链接;
其次,排除掉具有安全问题或受限于域名的 URL 链接;
最后,对下载的图像进行后处理,包括 PCA 哈希去重、NSFW 过滤和模糊可识别的人脸。
由此就得到了 1.2 亿张独一无二的图像。
▶ 去重(Deduplication.)
为了进一步减少冗余并增加图像之间的多样性,DINOv2 使用了《A self-supervised descriptor for image copy detection》论文提出的 copy detection pipeline 进行图像查重。这个方法基于深度学习计算图像之间的相似度。
论文链接:https://arxiv.org/abs/2202.10261
另外,DINOv2 还删除了使用任何基准的测试或验证集中包含的重复图像,以确保数据集的纯净度。
▶ 自监督图像检索(Self-supervised image retrieval.)
接下来是自监督图像检索的过程。为了从大量未标注的数据中检索出与经过精心整理的数据集中存在相似度很高的图像,首先需要对这些未筛选图像进行聚类,以便在检索时能快速找到与查询图像相似的图像。聚类算法会将视觉上非常相似的图像分组到同一组内。
为了顺利进行聚类过程,需要先计算每个图像的嵌入(Embeddings)。DINOv2 使用了在 ImageNet-22k上 进行预训练过的 ViT-H/16 自监督神经网络来计算每个图像的嵌入。
计算出每个图像的嵌入向量后,DINOv2 采用了 k-means 聚类算法将嵌入向量相似的图像放到同一聚类中。接下来,给定一个查询图像,DINOv2 从与查询图像所在的聚类中检索 N(通常为 4)个最相似的图像。如果查询图像所在的聚类太小,DINOv2 会从聚类中抽样 M 张图像(M 是由视觉检查结果后决定的)。最后,将这些相似的图像和查询图像一起用于预训练,以获得一个更优质、精心筛选过的大规模预训练数据集。
▶ LVD-142M
通过上述流程,Meta AI 从 12 亿张图片中得到了经过整理的 1.42 亿张图像,命名为 LVD-142M 数据集。这一过程中,通过采用自监督图像检索技术,大大提高了数据集的质量和多样性,为后面 DINOv2 的训练提供了更加丰富的数据资源。
训练方法与技术的改进
▶ 训练方法:Discriminative Self-supervised Pre-training
DINOv2 采用了一种区分性自监督方法(Discriminative Self-supervised Pre-training)来学习特征,这种方法可以看作是 DINO 和 iBOT 损失以及 SwAV 中心化的组合)。
简单来说,DINOv2 使用了两种目标函数来训练网络。第一种是 Image-level 的目标函数,其使用 ViT 的 cls token 的特征,通过比较从同一图像的不同部分得到的学生网络和教师网络的 cls token 输出来计算交叉熵损失。第二种是 Patch-level 的目标函数,它通过随机屏蔽学生网络输入的一些 patch(不是教师网络),并对每个被屏蔽的 patch 的特征进行交叉熵损失的计算。这两种目标函数的权重需要单独调整,以便在不同尺度上获得更好的性能。
同时,为了更好地训练网络,作者还采用了一些技巧。例如,解除两个目标函数之间的权重绑定,以解决模型在不同尺度下的欠拟合和过拟合问题。此外,作者使用了 Sinkhorn-Knopp centering 来规范化数据,并使用 KoLeo regularizer 鼓励批次内特征的均匀分布。最后,为了提高像素级下游任务(如分割或检测)的准确性,作者采用了逐步增加图像分辨率的技术,进一步提高了模型的表现。
具体而言,作者们实现了以下几种方法:
Image-level objective:利用一种交叉熵损失函数来比较从学生和教师网络中提取出的特征。这些特征都来自于ViT的cls token,通过对同一图像的不同裁剪图像进行提取得到。作者们使用指数移动平均法(EMA)来构建教师模型,学生模型的参数则通过训练得到。
Patch-level objective:随机遮盖一些输入patch,然后对学生网络和教师网络在遮盖的 patch上的特征进行交叉熵损失函数的比较。这种损失函数与图像级别的损失函数相结合。
Untying head weights between both objectives:作者们发现,将两种目标的权重绑定在一起会导致模型在 Patch-level 欠拟合,在 Image-level 过拟合。分离这些权重可以解决这个问题,并提高两种尺度上的性能。
Sinkhorn-Knopp centering: 这个方法是对 DINO 和 iBOT 两种方法中的一些步骤进行改进,具体可见这篇论文:Unsupervised Learning of Visual Features by Contrasting Cluster Assignments (arxiv.org)
KoLeo regularizer:KoLeo regularizer 是一种正则化方法,它通过计算特征向量之间的差异来确保它们在批次内均匀分布,其源自于 Kozachenko-Leonenko 微分熵估计器,并鼓励批次内特征的均匀跨度。具体见:Spreading vectors for similarity search (arxiv.org)
Adapting the resolution:这一步主要是涉及在预训练的最后一段时间内,将图像的分辨率提高到 518×518 ,便在下游任务中更好地处理像素级别的信息,例如分割或检测任务。高分辨率的图像通常需要更多的计算资源和存储空间,因此只在预训练的最后阶段使用这种方法,以减少时间和资源成本。
▶ 训练技术的工程改进
同时,DINOv2 也利用了一系列的工程化改进,以便在更大的范围内训练模型。通过利用最新的 Pytorch 2.0 的数据并行、分布式训练、混合精度训练与 variable-length memory-efficient attention 等技术,在同等硬件的情况下,新的代码运行速度大约是之前的两倍,而内存使用量只有原来的三分之一,这可以帮助 DINOv2 在数据、模型大小和硬件方面进行更加高效的扩展。
▶ 蒸馏得到好的轻量模型
我们也要注意到,大模型虽好,但其硬件和算力的要求太高,我们总是希望着出现门槛没那么高的 Strong, lightweight models 的出现。
因此,Meta AI 通过模型蒸馏的方法,将大模型的知识压缩到较小的模型中,使后续跟进的研究者只需付出最小的准确性代价,就能大大降低推理成本。同时,得到的 ViT-Small、ViT-Base 和 ViT-Large 模型也在下游任务上展现出不错的泛化性能,具体可见后面的实验结果。
预训练模型的评估结果
首先是必须要有的 ImageNet-1k 上的结果,可以看到 DINOv2 在 linear evaluation 上比以前的 SOTA(在 ImageNet-22k 上训练的 iBOT ViT-L/16)有非常明显的改进(+4.2%)。
其次是图像和视频分类与细粒度分类的结果:
作为经典的 Downsteam task,分割必不可少:
还有不太常见的,单目深度估计的结果:
发布了一系列高性能的预训练模型
Releasing a family of high-performance pretrained models
看完上面展示的实验结果,不知道有没有同学想试一试 DINOv2 作为 backbone 在自己的任务上的性能呐?Meta AI 也向社区发布了一系列 DINOv2 预训练模型。
DINOv2 作为特征提取器可以开箱即用,无需微调就能在多个下游任务上取得相当好的结果(在 ImageNet-1k 上,linear evaluation 比 Fine-tuning 只有 2% 内的差距),如下图所示:
玩玩 Demo
同时,Meta 在官网上放出了深度估计、语义分割和实例检索的网页 Demo,无需注册可以直接尝试(这才是「Open」AI)。
链接:https://dinov2.metademolab.com/
这里,也分享一下我的试玩结果:
深度估计(Depth Estimation)
一般很少有预训练模型展示自己在深度估计方面的能力,这也说明了 DINOv2 模型表现出强大的分布外泛化能力(strong out-of-distribution performance)。
这里,我特意选取了一直非自然光照条件下的夜景作为测试,得到的结果还是非常惊艳的!
语义分割(Semantic Segmentation)
DINOv2 的冻结特征(frozen features)可以很容易地用于语义分割任务。
这里就是简单的语义分割,没有 SAM 在分割任务上的可玩性那么强。
实例检索(Instance Retrieval)
这是我认为很有意思的一个Demo,它是从大量的艺术图片集合中找到与给定图片相似的艺术作品。这里我上传了一张黄鹤楼的图片作为 Query:
这是 Dinov2 给出的结果,感觉在语义上还是十分接近的(都有一个高耸的塔或楼😂)
未来方向
Meta AI 也给出了团队的未来研究方向。总的来说,就是和大语言模型(LLMs, Large Language Models)结合,向通用人工智能与复杂系统(Complex AI systems)前进。
结语
DINOv2 作为一种无需 fine-tuning 的自监督方法,在提取图像特征方面表现出色,适用于许多不同的视觉任务。它的开源也为广大研究者和工程师提供了一种新的选择,有望为计算机视觉领域带来更多的突破,可以期待更多基于 DINOv2 的研究工作出现。
MMPreTrain
如果你对和 DINOv2 相关的预训练 foundation models 感兴趣,推荐你关注一下 OpenMMLab 的开源深度学习预训练工具箱 MMPreTrain,目前 MMPreTrain 已经支持了 DINOv2 backbone 的推理。
GitHub 链接:
https://github.com/open-mmlab/mmpretrain
(欢迎使用)
MMPreTrain 涵盖了多样的主干网络与预训练模型,并支持多种训练策略(有监督学习,无监督学习等),其中收录的自监督算法如下,都是近两年最新的经典方法😊。
参考
https://www.facebook.com/login/?next=https%3A%2F%2Fwww.facebook.com%2Fzuck%2Fposts%2Fpfbid02f3chCYQphfYnzRaDXeJxsT5EmyhbrFsjqLaU31KuTG63Ca4yMXFcDXQcukYPbWUMl
https://ai.facebook.com/blog/dino-v2-computer-vision-self-supervised-learning/
2023-06-12
2023-06-09
点击下方“阅读原文”直达 MMPreTrain