【论文精读】MAE

摘要

       将掩码重建任务从nlp引入到cv,提出非对称掩码自编码器。

框架

image

概述

       如上图,本文提出掩码自编码器,即将给定原始信号的部分观测值的情况下重建原始信号,编码器将观察到的部分信号(没有掩码标记)映射到潜在表示,采用轻量级的解码器从潜在表示重建原始信号,模型采用了非对称设计。

掩码

       类似ViT,将图像划分为规则的非重叠patch,按照均匀分布对无替换的随机patch进行采样,即随机抽样。随后屏蔽(删除patch)其余未被采样的patch。
image
image
       采用高屏蔽率(删除patch的比率)的随机抽样可以在很大程度消除了冗余,从而创建了一个不能通过可见的邻近patch外推而轻松解决的任务(如上几幅图)。而均匀分布可以防止中心归纳偏好(图像中心附近有更多的掩码块)。

MAE编码器

       编码器为原始ViT,且只应用未屏蔽的patch,并采用线性投影计算这些patch的patch embedding,并添加position embedding,然后通过一系列Transformer块处理结果集。

MAE解码器

       如图1,解码器的输入是完整的patch集,包括编码器输出的未屏蔽patch的特征token和mask tokens。其中,每个mask tokens都是一个共享的、可学习的向量,表示要预测的缺失patch。随后向这个完整patch集合添加position embedding。

       解码器仅在预训练任务中重建图像,而其余的下游任务形式多种多样,实际应用时不用解码器。所以解码器的设计和编码器是解耦的,解码器可以设计得简单、轻量(比编码器更窄、更浅。窄:对应通道数;浅:对应深度)。

目标重建

       MAE通过预测每个掩码patch的像素值来重建输入。解码器的最后一层为线性投影,其输出通道的数量等于patch中的像素值的数量,其输出代表输入patch的像素值向量,并将输出重塑以形成重建的图像。损失函数为计算像素空间中重建图像和原始图像之间的均方误差(MSE)。且仅在掩码patch上计算损失。

       本文还研究了一种变体,其重建目标是每个掩码 patch的归一化像素值。即计算一个掩码 patch中所有像素的均值和标准差,然后用来归一化这对应的掩码patch作为目标。实验中,使用归一化像素作为重建目标可以提高表示质量。

实现

  • 将输入图像划分为patches ( B , C , H , W ) → ( B , N , P × P × C ) (B,C,H,W)→(B,N,P \times P \times C) (B,C,H,W)(B,N,P×P×C)
  • 对所有patch计算patch embedding,生成tokens,并加入position embeddings,维度变换为 ( B , N , P × P × C ) → ( B , N , d i m ) (B,N,P \times P \times C)→(B,N,dim) (B,N,P×P×C)(B,N,dim)
  • 根据预设的掩码比例(75%),使用服从均匀分布的随机采样策略采样一部分前一步骤得到的tokens送给编码器,另一部分被mask掉
  • 将编码器编码后的tokens与masked tokens按照原先在patch形态时对应的次序拼在一起,输入给解码器
  • 解码器解码后取出masked tokens对应的部分送入到全连接层,对masked patches的像素值进行预测,最后将预测结果与masked patches进行比较,计算MSE loss

实验

ImageNet实验

       实验在ImageNet-1K(IN1K)训练集上采用ViT进行自监督预训练,然后进行监督训练,评估端到端微调或线性检测的表现。

实验配置

       ViT架构实验遵循标准的ViT架构。其有一个Transformer块的堆栈,其中每个块由一个多头自注意力块和一个MLP块组成,两者都具有LayerNorm(LN)。编码器以LN结尾。由于MAE编码器和解码器宽度不同,在编码器之后采用线性投影层对其进行调整匹配。MAE向编码器和解码器输入添加了位置嵌入,没有使用相对位置或层缩放。

       从编码器输出中提取特征以进行微调和线性探测。由于ViT有一个类标记,为了适应这种设计在MAE预训练中向编码器输入添加了一个辅助token。此token被视为在线性探测和微调中训练分类器的类token,实验证明MAE在没有这个token的情况下(使用平均池化)也同样表现得很好。
image
       上图为预训练配置。相对于ViT官方源码,没有使用color jittering、drop path、gradient clip。
image
       上图为微调及部分微调配置。微调使用layer-wise learning rate decay,部分微调只微调编码器的最后几个层。
image
       上图为线性检测配置。线性检测和微调有不同,regularization对线性检测可能会损失模型性能,因此舍弃了一些regularization strategies,例如mixup、cutmix、drop path、color jittering。并对输入执行normalization,同时在预训练特征层和线性分类层之间加上一个额外的BN,可以实现特征的标准化。

消融实验

image
       上图实验mask比例。观察到微调和线性检测时,mask比例逐渐升高,性能更好。 线性检测近似线性增涨,而微调则是mask比例在30%~40%时激增,而后就倾向于饱和。

       线性检测时为mask比例越高,预训练时得到的编码器越强,这部分在下游任务中不再被训练的了,所以其性能就随着mask比例的增加呈线性增涨的趋势。
image
       微调时,结果对mask比例不太敏感,大范围的屏蔽比率(40- 80%)都可以很好地工作。最优mask比例是75%。如上图可视化结果。
image
       上图a显示解码器深度对微调和线性探测任务的影响。观察到足够深的解码器对线性探测很重要,因为自编码器的最后几层更专注于重建,与识别不太相关,预训练与线性检测之间存在gap。故合理深度的解码器(8层)可以使潜在表示的语义信息更抽象,可以改进8%的线性探测精度。对于微调,解码器深度对改进微调的影响较小,故只使用单层解码器的MAE也可以在微调中表现良好(84.8%),这么小的解码器可以进一步加快训练速度。

       图b实验解码器宽度,也得出与a类似的结论,通道数为512时微调和线性探测精度最优。故编码器默认是8个blocks,通道数是512。
image
       图c实验编码器是否接受mask tokens。实验表明,encoder如果接收mask tokens,性能会降低(线性检测降低14%),因此编码器只接收visible tokens,既能提升性能,又能降低计算量,且加速训练。decoder越小/encoder越大,加速越明显,MAE的时间和存储效率使其适合训练大型模型。详细实验配置、结果如上图。

       图d实验重建目标方式。实验表明使用normalization(per patch)的效果比不使用更好。对patch执行PCA,然后将前96个主成分作为重构目标,效果并不好。使用BEiT的dVAE作为目标,效果也不太好。

       图e实验数据增强方法。实验表明,MAE只使用裁剪增强时就可以表现很好,添加颜色抖动会降低结果。同时发现不使用数据增强,MAE甚至性能更好。对MAE来说,每一个轮次masks的token都不同,随机masking扮演了类似于数据增强的角色。
image
       图f实验不同的掩码采样策略。观察到block掩码策略倾向于删除较大的块(上图中),基于block掩码的MAE在50%的比例下工作得相当好,但在75%的比例下退化。该任务比random采样更难,具有更高的训练损失,重建结果也比较模糊。 其次grid采样(上图右)是一个更容易的任务,具有更低的训练损失。然而,其重建更加尖锐。表示质量较低。故简单random采样最适合MAE,其允许更高的掩蔽率,这提供了更大的加速效益,同时也具有良好的准确性。
image
       上图为训练epoch数量对模型精度的影响。观察到,随着训练时间的延长准确率稳步提高。在1600个epoch训练后,线性检测精度依然没有达到饱和。

对比实验

image
       上图为与先前自监督方法比较了自监督ViT模型的微调结果。对于ViT-B,所有方法的性能都很好,对于ViT-L,方法之间的差距更大。此外,观察到MAE可以轻松扩展,并从更大的模型中显示出稳定的改进。使用ViT-H获得了86.9% 的准确率,将ViT-H微调为448大小,只使用IN1K数据就实现了87.8%的准确率。

       与BEiT相比,MAE具有更高的准确性、更简单、更快的计算速度。MAE重建像素,与预测token的BEiT形成对比。
image
       上图为与有监督预训练ViT的比较。

部分微调实验

       微调ViT最后几层,同时冻结其他层进行训练实验。
image
       上图显示结果。只微调一个Transformer块就可以将精度从73.5%提高到81.0%,如果只微调最后一个块的一半(其MLP子块),可以得到79.1%的精度。微调一部分块(4或6)可以实现接近完全微调的精度。

       与MoCo v3进行比较。MoCo v3具有更高的线性探测精度,但其所有的部分微调结果都比MAE差。当调优4个区块时,差距为2.6%。虽然MAE表示的线性可分性较差,但它们是更强的非线性特征。

迁移学习实验

image
       上图在COCO上对Mask RCNN端到端进行微调,ViT骨干经过调整用于FPN。这种方法应用于上图中的所有条目,指标为目标检测的box AP和实例分割的mask AP。

       与有监督的预训练相比,MAE在所有配置下的表现都更好。在较小的ViT-B下,MAE比有监督预训练高2.4个点。对于更大的ViT-L,MAE预训练比有监督预训练高出4.0个点。 基于像素的MAE优于或与基于token的BEiT相当,而MAE更简单、更快,MAE和BEiT都优于MoCo v3, MoCo v3与有监督预训练相当。
image
       上图使用UperNet在ADE20K实例分割任务上进行实验。观察到,MAE预训练比有监督预训练的结果提高了3.7个点。基于像素的MAE也优于基于token的BEiT。
image
       上图为在iNaturalists和Places实验分类任务。在iNat上,MAE方法下随着ViT模型的扩大,精度有了很大的提高,大大超过了之前的最佳结果。在Places上,MAE的性能超过了之前的最佳结果,之前的这些结果通过对数十亿张图像进行预训练获得。
image
       上图实验比较像素和dVAE作为MAE重建目标的结果。虽然使用dVAE token比使用非归一化像素要好,但其在统计上与使用归一化像素相似。表明token化对MAE是不必要的。

鲁棒性评估

image
       上图评估了模型在不同变体的ImageNet验证集上的鲁棒性。使用在原始ImageNet上进行微调的相同模型(表3),并仅在不同的验证集上运行推理。

       观察到除IN-C外,MAE在增加模型大小后具有显著的收益。增大图像大小在所有集合中都有帮助,也大大超过了以前的最佳结果。 相比之下,有监督训练的表现要差得多。例如使用ViT-H,MAE预训练在IN-A上比有监督的对应模型好35%。

可视化

image
image
       上图显示了在imagenet和COCO上的随机样本重建可视化结果三元组,其中左为掩码图像、中为MAE重建、右为真实值。掩码率为75%。

reference

He, K. , Chen, X. , Xie, S. , Li, Y. , Dollár, Piotr, & Girshick, R. . (2021). Masked autoencoders are scalable vision learners.

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

电大考试哪个搜题软件好用?分享6个可以搜答案的软件 #经验分享#其他#微信

当今社会,技术的发展给我们带来了许多便利,包括了许多实用的学习工具。 1.三羊搜题 这是一个公众号 它支持文本搜索、扫码搜书、拍照搜索,不会的题目直接对准书书本,或手打文字搜索题目,找到的后的题目都有详细的解…

【JVM篇】什么是运行时数据区

文章目录 🍔什么是运行时数据区⭐程序计数器⭐栈🔎Java虚拟机栈🎈栈帧的内容 🔎本地方法栈 ⭐堆⭐方法区 🍔什么是运行时数据区 运行时数据区指的是jvm所管理的内存区域,其中分为两大类 线程共享&#xf…

w29pikachu-ssrf实例

实验环境 php:7.3.4nts apache:2.4.39 浏览器:谷歌实验步骤 ssrf(curl) 打开ssrf(curl) 点击文字,跳转404页面,从反馈信息来看是找不到对应的页面。 查看源码,发现有个RD变量影…

sentinel的资源数据指标是如何采集

资源数据采集 之前的NodeSelectorSlot和ClusterBuilderSlot已经完成了对资源调用树的构建, 现在则是要对资源进行收集, 核心点就是这些资源数据是如何统计 LogSlot 作用: 记录异常请求日志, 用于故障排查 public class LogSlot extends AbstractLinkedProcessorSlot<Def…

使用 Docker 安装 Kibana 8.4.3

使用 Docker 安装 Kibana 8.4.3 一. 安装启动 Kibana 8.4.3二. 简单使用2.1 向 Elasticsearch 发送请求2.2 搜索2.3 整体页面 前言 这是我在这个网站整理的笔记,有错误的地方请指出&#xff0c;关注我&#xff0c;接下来还会持续更新。 作者&#xff1a;神的孩子都在歌唱 安装k…

十五、Object 类

文章目录 Object 类6.1 public Object()6.2 toString方法6.3 hashCode和equals(Object)6.4 getClass方法6.5 clone方法6.6 finalize方法 Object 类 本文为书籍《Java编程的逻辑》1和《剑指Java&#xff1a;核心原理与应用实践》2阅读笔记 java.lang.Object类是类层次结构的根…

医卫医学试题及答案,分享几个实用搜题和学习工具 #笔记#笔记#微信

收录了大量考试类型的题库&#xff0c;大到考公&#xff0c;小到知识竞赛&#xff0c;题库资源算是比较丰富的了。操作起来也不难&#xff0c;我们只需输入题目内容&#xff0c;即可快速搜索出答案&#xff0c;而且它在给出答案的同时还会附带解析。最重要的是&#xff0c;搜题…

软件工具安装遇到bug、报错不知道怎么解决?看这里!

前言 本文举例了几个常见的软件工具使用问题&#xff0c;文末会提供一些我自己整理和使用的工具资料 。 "在追逐零 Bug 的路上&#xff0c;我们不断学习、改进&#xff0c;更加坚定自己的技术信念。让我们相信&#xff0c;每一个 Bug 都是我们成长的机会。" 一、VM…

09MARL深度强化学习policy gradient

文章目录 前言1、Multi-Agent Policy Gradient Theorem2、Centralised State-Value Critics2、Centralised Action-Value Critics 前言 Independent learning算法当中每个智能体看待其他智能体为环境的一部分&#xff0c;加剧了环境非平稳性&#xff0c;而CTDE框架的算法能够降…

防火墙——计算机网络

前述基于密码的安全机制不能有效解决以下安全问题&#xff1a; 用户入侵&#xff1a; 利用系统漏洞进行未授权登录&#xff1b; 授权用户非法获取更高级别权限等。 软件入侵&#xff1a; 通过网络传播病毒、蠕虫和特洛伊木马。 拒绝服务攻击等。 解决方法&#xff1a; 防火墙&a…

Camera2 setRepeatingRequest源码分析

当createCaptureSession流程执行完成后&#xff0c;应用在回调方法onConfigured就可以获得创建的CameraCaptureSession&#xff0c;接下来就可以调用CameraCaptureSession#setRepeatingRequest来下发camera stream命令获取camera数据。在CameraCaptureSession#setRepeatingRequ…

离线升级esp32开发板升级包esp32-2.0.14(最新版已经3.0alpha了)

1.Arduino IDE 2.3.2最新 2024.2.20升级安装:https://www.arduino.cc/en/software 2.开发板地址 地址&#xff08;esp8266,esp32&#xff09; http://arduino.esp8266.com/stable/package_esp8266com_index.json,https://raw.githubusercontent.com/espressif/arduino-esp32…

【Redis高手修炼之路】④主从复制

主从复制 就是 redis集群的策略配从&#xff08;库&#xff09;不配主&#xff08;库&#xff09;&#xff1a;小弟可以选择谁是大哥&#xff0c;但大哥没有权利去选择小弟读写分离&#xff1a;主机写&#xff0c;从机读 一主二仆 准备三台服务器&#xff0c;并修改redis.co…

HTTP 与HTTPS笔记

HTTP 80 HTTP是一个在计算机世界里专门在【两点】之间【传输】文字、图片、音频、视频等【超文本】数据的约定和规范。 HTTP状态码 1xx 提示信息&#xff0c;表示目前是协议处理的中间状态&#xff0c;还需要后续的操作&#xff1b;2xx 200 204 026 成功3xx 重定向&#xff…

MySQL篇之覆盖索引

一、定义 覆盖索引是指查询使用了索引&#xff0c;并且需要返回的列&#xff0c;在该索引中已经全部能够找到。 二、例子 1. id为主键&#xff0c;默认是主键索引。 2. name字段为普通索引。 select * from tb_user where id 1 覆盖索引 select id&#xff0c;na…

OPPO公布全新AI战略,AI 手机时代再提速

2024年2月20日&#xff0c;深圳——今日OPPO 举办 AI 战略发布会&#xff0c;分享新一代 AI 手机的四大能力特征&#xff0c;展望由AI驱动的手机全栈革新和生态重构的趋势&#xff0c;并发布由OPPO AI 超级智能体和 AI Pro 智能体开发平台组成的OPPO 1N 智能体生态战略&#xf…

提升网络灵活性,SD-WAN助您快速应对备用线路需求

随着企业规模不断扩大&#xff0c;传统网络架构在面对快速扩张的业务需求时显得力不从心&#xff0c;如同狭窄的道路难以容纳日益增多的车流和人群&#xff0c;访问流量的激增可能导致网络拥堵和延误&#xff0c;极大地影响业务正常访问。本文将详细介绍SD-WAN如何快速调整备用…

【MySQL】Navicat/SQLyog连接Ubuntu中的数据库(MySQL)

&#x1f3e1;浩泽学编程&#xff1a;个人主页 &#x1f525; 推荐专栏&#xff1a;《深入浅出SpringBoot》《java对AI的调用开发》 《RabbitMQ》《Spring》《SpringMVC》 &#x1f6f8;学无止境&#xff0c;不骄不躁&#xff0c;知行合一 文章目录 前言一、安装…

C++结合Lambda表达式在函数内部实现递归

529. 扫雷游戏 已解答 中等 相关标签 相关企业 让我们一起来玩扫雷游戏&#xff01; 给你一个大小为 m x n 二维字符矩阵 board &#xff0c;表示扫雷游戏的盘面&#xff0c;其中&#xff1a; M 代表一个 未挖出的 地雷&#xff0c;E 代表一个 未挖出的 空方块&#xff…

【贪心算法】代码随想录算法训练营第三十七天 |738.单调递增的数字,968.监控二叉树,总结(待补充)

738.单调递增的数字 1、题目链接&#xff1a;力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 2、文章讲解&#xff1a;代码随想录 3、题目&#xff1a; 给定一个非负整数 N&#xff0c;找出小于或等于 N 的最大的整数&#xff0c;同时这个整数需要…