Sapiens——人类视觉大模型的基础

news2024/11/13 14:36:32

引言

大规模预训练以及随后针对特定任务的语言建模微调取得了显著成功,已将这种方法确立为标准做法。同样, 计算机视觉方法正逐步采用大规模数据进行预训练。LAION5B、Instagram-3.5B、JFT-300M、LVD142M、Visual Genome 和 YFCC100M 等大型数据集的出现使得人们能够探索远远超出传统基准范围的数据语料库。该领域的突出工作包括 DINOv2、MAWS 和 AIM。DINOv2 通过在 LDV-142M 数据集上扩展对比 iBot 方法,在生成自监督特征方面实现了最先进的性能。MAWS 研究了十亿张图像上掩蔽自编码器 (MAE) 的扩展。AIM 探索了类似于 BERT 的自回归视觉预训练对于视觉转换器的可扩展性。与这些主要侧重于一般图像预训练或零样本图像分类的方法相比,Sapiens 采取了一种明显以人为本的方法:Sapiens 的模型利用大量人类图像进行预训练,随后针对一系列与人类相关的任务进行微调。追求大规模 3D 人体数字化仍然是计算机视觉领域的关键目标。

在受控或工作室环境中取得了重大进展,但将这些方法扩展到不受约束的环境仍然存在挑战。为了应对这些挑战,开发能够执行多项基本任务的多功能模型至关重要,例如关键点估计、身体部位分割、深度估计和从自然环境中的图像进行表面法线预测。在这项工作中,Sapiens 旨在为这些基本的人类视觉任务开发模型,这些模型可以推广到野外环境。目前,最大的公开语言模型包含超过 100 亿个参数,而更常用的语言模型包含大约 7 亿个参数。相比之下,Vision Transformers (ViT) 尽管共享类似的架构,但尚未成功扩展到这种程度。虽然在这方面做出了许多努力,包括开发针对文本和图像进行训练的密集 ViT-4B,以及制定稳定训练 ViT-22B 的技术,但常用的视觉主干仍然介于 300 亿到 600 亿个参数之间,并且主要在约 224 像素的图像分辨率下进行预训练。同样,现有的基于 Transformer 的图像生成模型(例如 DiT)使用不到 700 亿个参数,并在高度压缩的潜在空间上运行。为了弥补这一差距,Sapiens 推出了一系列大型高分辨率 ViT 模型,这些模型在数百万张人体图像上以 1024 像素的图像分辨率进行本地预训练。

Sapiens 针对四项以人为中心的基本视觉任务提出了一系列模型:2D 姿势估计、身体部位分割、深度估计和表面法线预测。Sapiens 模型原生支持 1K 高分辨率推理,并且非常容易通过对超过 300 亿张野生人类图像进行预训练的模型进行微调来适应单个任务。Sapiens 观察到,在给定相同计算预算的情况下,对精选的人类图像数据集进行自我监督预训练可显著提高以人为中心的各种任务的性能。即使在标记数据稀缺或完全合成的情况下,生成的模型也表现出对野生数据的出色泛化能力。简单的模型设计还带来了可扩展性——随着参数数量从 0.3 扩展到 2 亿,跨任务的模型性能得到提高。 Sapiens 在各种以人为本的基准中始终超越现有基线,与之前的最先进结果相比取得了显著的进步:Humans-7.6K(姿势)上 5 mAP,Humans-17.1K(部分分段)上 2 mIoU,Hi22.4D(深度)上 4% 相对 RMSE,以及 THuman53.5(正常)上 2% 相对角度误差。

人类视觉模型的突破

近年来,我们在 2D 和 3D 中生成照片级逼真的人类方面取得了显著进展。这些方法的成功很大程度上归功于对各种资产(例如 2D 关键点、细粒度身体部位分割、深度和表面法线)的稳健估计。然而,对这些资产进行稳健而准确的估计仍然是一个活跃的研究领域,而用于提高单个任务性能的复杂系统通常会阻碍更广泛的采用。此外,在野外获得准确的地面实况注释是出了名的难以扩展。Sapiens 的目标是提供一个统一的框架和模型来推断野外的这些资产,为每个人解锁广泛的以人为本的应用程序。

Sapiens 认为,这种以人为中心的模型应该满足三个标准:泛化、广泛适用性和高保真度。泛化确保了对未知条件的鲁棒性,使模型能够在不同的环境中始终如一地执行。广泛适用性表示模型的多功能性,使其适用于各种任务,只需进行最少的修改。高保真度表示模型能够产生精确、高分辨率的输出,这对于忠实的人类生成任务至关重要。本文详细介绍了体现这些属性的模型的开发,统称为 Sapiens。

根据洞察,Sapiens 利用大型数据集和可扩展的模型架构,这是泛化的关键。为了扩大适用范围,Sapiens 采用了先预训练再微调的方法,使预训练后能够以最少的调整适应特定任务。这种方法提出了一个关键问题:哪种类型的数据对预训练最有效?考虑到计算限制,应该重点收集尽可能多的人体图像,还是最好在较少的整理集合上进行预训练以更好地反映现实世界的变化?现有方法通常会忽略下游任务背景下的预训练数据分布。为了研究预训练数据分布对人类特定任务的影响,Sapiens 收集了 Humans-300M 数据集,其中包含 300 亿张不同的人体图像。这些未标记的图像用于从头开始预训练一系列视觉转换器,参数数量从 300 亿到 2 亿不等。

在从大型数据集中学习通用视觉特征的各种自监督方法中,Sapiens 选择了 掩蔽自编码器 (MAE)方法以其简单和高效的预训练而闻名。与对比或多推理策略相比,MAE 具有单次推理模型,允许使用相同的计算资源处理大量图像。为了获得更高的保真度,与之前的方法相比,Sapiens 将其预训练的原始输入分辨率提高到 1024 像素,与现有最大的视觉主干相比,FLOP 增加了约 4 倍。每个模型都在 1.2 万亿个标记上进行预训练。对于以人为本的任务进行微调,Sapiens 使用一致的编码器-解码器架构。编码器使用预训练中的权重初始化,而解码器(轻量级且特定于任务的头部)则随机初始化。然后对两个组件进行端到端微调。Sapiens 专注于四个关键任务:2D 姿势估计、身体部位分割、深度和法线估计,如下图所示。

在这里插入图片描述
与之前的研究一致,Sapiens 肯定了标签质量对模型实际性能的关键影响。公共基准通常包含嘈杂的标签,在模型微调期间提供不一致的监督信号。同时,利用细粒度和精确的注释与 Sapiens 的 3D 人体数字化主要目标紧密结合非常重要。为此,Sapiens 提出了一组密度大大提高的 2D 全身关键点用于姿势估计,以及一组详细的类别词汇用于身体部位分割,超越了以前数据集的范围。具体来说,Sapiens 引入了 308 个关键点的综合集合,涵盖身体、手、脚、表面和面部。此外,Sapiens 将分割类别词汇扩展到 28 个类别,涵盖头发、舌头、牙齿、上/下唇和躯干等身体部位。为了保证注释的质量和一致性以及高度自动化,Sapiens 使用多视图捕获设置来收集姿势和分割注释。Sapiens 还利用以人为中心的合成数据进行深度和法线估计,利用来自 RenderPeople 的 600 个详细扫描来生成高分辨率深度图和表面法线。Sapiens 表明,特定领域的大规模预训练与有限但高质量的注释相结合可实现强大的野外泛化。总体而言,Sapiens 的方法展示了一种有效的策略,可以开发能够在现实世界场景中执行的高精度判别模型,而无需收集昂贵且多样化的注释集。

在这里插入图片描述

方法与建筑

Sapiens 采用掩码自动编码器 (MAE) 方法进行预训练。该模型经过训练,可以根据部分观察结果重建原始人体图像。与所有自动编码器一样,Sapiens 的模型有一个编码器,可将可见图像映射到潜在表示,还有一个解码器,可根据该潜在表示重建原始图像。预训练数据集由单人和多人图像组成,每张图像都调整为具有正方形长宽比的固定大小。类似于 维生素,将图像划分为具有固定块大小的规则不重叠块。这些块的子集被随机选择并屏蔽,其余部分可见。屏蔽块与可见块的比例(称为屏蔽率)在整个训练过程中保持不变。

Sapiens 的模型在各种图像特征上都表现出了泛化能力,包括尺度、裁剪、受试者的年龄和种族以及受试者的数量。模型中的每个补丁标记占图像面积的 0.02%,而标准 ViT 中为 0.4%,减少了 16 倍,为模型提供了细粒度的标记间推理。即使掩码率增加到 95%,Sapiens 的模型也能在保留的样本上实现人体解剖结构的合理重建。下图展示了 Sapien 的预训练模型在未见过的人体图像上的重建。

在这里插入图片描述
此外,Sapiens 利用大型专有数据集进行预训练,该数据集由大约 1 亿张自然图像组成,专注于人类图像。预处理包括丢弃带有水印、文本、艺术描绘或非自然元素的图像。然后,Sapiens 使用现成的人体边界框检测器来过滤图像,保留检测分数高于 0.9 且边界框尺寸超过 300 像素的图像。数据集中有超过 248 亿张图像包含多个主体。

2D 姿态估计

Sapien 框架在多个骨架上对 P 中的编码器和解码器进行微调,其中包括 K = 17 [67]、K = 133 [55] 和一个新的高度详细骨架,其中 K = 308,如下图所示。

在这里插入图片描述
与最多 68 个面部关键点的现有格式相比,Sapien 的注释包含 243 个面部关键点,包括眼睛、嘴唇、鼻子和耳朵周围的代表点。这种设计旨在细致地捕捉现实世界中面部表情的细微细节。利用这些关键点,Sapien 框架手动注释了来自室内捕捉设置的 1 万张 4K 分辨率图像。与之前的任务类似,我们将法线估计器 N 的解码器输出通道设置为 3,对应于每个像素的法线向量的 xyz 分量。生成的合成数据也用作表面法线估计的监督。

在这里插入图片描述

实验与结果

Sapiens-2B 使用 1024 个 A100 GPU 通过 PyTorch 进行了 18 天的预训练。Sapiens 在所有实验中均使用 AdamW 优化器。学习计划包括简短的线性预热,然后进行余弦退火进行预训练,再进行线性衰减进行微调。所有模型均从头开始进行预训练,分辨率为 1024 × 1024,块大小为 16。为了进行微调,输入图像的大小被调整为 4:3 的比例,即 1024 × 768。Sapiens 应用了标准增强功能,例如裁剪、缩放、翻转和光度失真。添加了来自非人类 COCO 图像的随机背景以用于分割、深度和正常预测任务。重要的是,Sapiens 使用差异学习率来保持泛化,初始层的学习率较低,后续层的学习率逐渐升高。逐层学习率衰减设置为 0.85,编码器的权重衰减设置为 0.1。

下表详细列出了 Sapiens 的设计规格。Sapiens 遵循特定方法,优先按宽度而非深度扩展模型。值得注意的是,Sapiens-0.3B 模型虽然在架构上与传统的 ViT-Large 相似,但由于分辨率更高,其 FLOP 数量是后者的 XNUMX 倍。

在这里插入图片描述
Sapiens 使用高保真注释对面部、身体、脚和手 (K = 308) 姿势估计进行了微调。对于训练,Sapiens 使用包含 1M 幅图像的训练集,对于评估,它使用包含 5K 幅图像的测试集 Humans5K。评估采用自上而下的方法,其中 Sapiens 使用现成的边界框检测器并进行单个人体姿势推理。表 3 显示了 Sapiens 模型与现有全身姿势估计方法的比较。所有方法均在 Sapiens 的 114 个关键点词汇表和 COCO-WholeBody 的 308 个关键点词汇表之间的 133 个共同关键点上进行评估。Sapiens-0.6B 比目前最先进的 DWPose-l 高出 +2.8 AP。与 DWPose 不同,Sapiens 采用通用的编码器-解码器架构,并进行大量以人为本的预训练,而 DWPose 采用复杂的学生-老师框架,并针对任务量身定制特征提炼。

有趣的是,即使参数数量相同,Sapiens 模型也表现出比同类模型更出色的性能。例如,Sapiens-0.3B 比 VitPose±L 高出 +5.6 AP,而 Sapiens-0.6B 比 VitPose±H 高出 +7.9 AP。在 Sapiens 系列中,结果表明模型大小与性能之间存在直接相关性。Sapiens-2B 以 61.1 AP 创下了新的最先进水平,比现有技术显著提高了 +7.6 AP。尽管使用室内捕捉工作室的注释进行了微调,但 Sapiens 仍表现出对现实世界场景的强大泛化能力,如下图所示。

在这里插入图片描述
Sapiens 使用 28 个类别的分割词汇进行微调和评估。训练集包含 100K 张图像,而测试集 Humans-2K 包含 2K 张图像。将 Sapiens 与在同一训练集上微调的现有身体部位分割方法进行比较,使用每种方法建议的预训练检查点作为初始化。与姿势估计类似,Sapiens 在分割方面表现出了泛化能力,如下表所示。

在这里插入图片描述
有趣的是,最小的模型 Sapiens-0.3B 凭借更高的分辨率和大量以人为中心的预训练,比现有的最先进的分割方法(如 Mask2Former 和 DeepLabV3+)高出 12.6 mIoU。此外,增加模型大小可进一步提高分割性能。Sapiens-2B 的性能最佳,在测试集上达到 81.2 mIoU 和 89.4 mAcc,下图显示了 Sapiens 模型的定性结果。
在这里插入图片描述

结论

Sapiens 代表着将以人为本的视觉模型推进到基础模型领域的重要一步。Sapiens 模型在各种以人为本的任务中展示了强大的泛化能力。最先进的性能归功于:(i) 在专门为理解人类而定制的精选数据集上进行大规模预训练,(ii) 可扩展的高分辨率和高容量视觉转换器主干,以及 (iii) 在增强工作室和合成数据上进行高质量注释。Sapiens 模型有可能成为众多下游任务的关键构建块,并为社区中更广泛的群体提供高质量视觉主干的访问权限。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Python 实现Excel XLS和XLSX格式相互转换

在日常工作中,我们经常需要处理和转换不同格式的Excel文件,以适应不同的需求和软件兼容性。Excel文件的两种常见格式是XLS(Excel 97-2003)和XLSX(Excel 2007及以上版本)。本文将详细介绍如何使用Python在XL…

【SQLite数据库常规使用命令】

之前在做围绕数据库相关的一些小工具的时候,想找一款数据库作为小工具的资料库。需求是:不用复杂的安装,支持简单SQL,空间占用小,操作简单等等。 结合着之前接触到的一些研发同事做的产品的使用经验,我想到…

递归7小题

[ 注意:前6道题均是使用递归完成的,需要数组、指针、链表相关知识,第7道题是求水仙花数的加强版,也是使用递归完成的,3位数的水仙花数我们很熟悉,那5位数的呢?7位数的呢?9位数的呢&a…

【pycharm】如何两个窗口打开同一代码

文章目录 前言解决方案结果 前言 在 编辑长代码,要看上下离得较远的变量 时遇到的问题 解决方案 “window” → “Editor Tabs” → “Split right" 结果

CleanClip vs 传统剪贴板:究竟谁更胜一筹?

在日常工作和生活中,复制粘贴可以说是我们使用最频繁的操作之一。传统的剪贴板功能虽然简单易用,但在功能性和效率上还有很大的提升空间。今天,我们就来比较一下新兴的剪贴板增强工具CleanClip与传统剪贴板,看看到底谁更胜一筹。 1. 剪贴历史管理 传统剪贴板只能存储最后一次…

动态线程池实战(一)

动态线程池 对项目的认知 为什么需要动态线程池 DynamicTp简介 接入步骤 功能介绍 模块划分 代码结构介绍

设计模式学习[6]---代理模式

文章目录 前言1.原理阐述2.举例2.1 例子与类图2.2 代码 总结 前言 代理这个词,从小到大听过不少。比如什么代理服务器,代理商,代理人之类的。通俗来说,代理无非无非就是我代表你处理事务的意思。 那么在设计模式中,针…

Android WebView H5 Hybrid 混和开发

对于故乡,我忽然有了新的理解:人的故乡,并不止于一块特定的土地,而是一种辽阔无比的心情,不受空间和时间的限制;这心情一经唤起,就是你已经回到了故乡。——《记忆与印象》 前言 移动互联网发展…

智能车镜头组入门(三)巡线

镜头组的特点是通过摄像头来获取赛道的信息,从而达到前瞻的效果,完成转向和速度决策。 我们的方案,带上元素识别,大概在TC264上5ms一帧,所以我们开了100hz的图象。 之前我看别的博客上有人说,他们组的50帧…

MyBatis框架SqlSession浅析

1、SqlSessionFactory作用 MyBatis框架SqlSessionFactory是线程安全的,负责创建SqlSession。 DefaultSqlSessionFactory是线程安全的,属性Final。 2、SqlSessionFactoryBuilder SqlSessionFactoryBuilder负责创建SqlSessionFactory。SqlSessionFactory…

C++伟大发明--模版

C起初是不受外界关注的,别人觉得他和C语言没有本质上的区别,只是方便些,直到祖师爷发明了模版,开始和C语言有了根本的区别。 我们通过一个小小的例子来搞清楚什么是模版,模版的作用到底有多大,平时我们想要…

UAC2.0 麦克风——类特殊请求

UAC2.0 麦克风枚举过程参考 UAC2.0 麦克风——单声道 USB 麦克风(16bit) 文章目录 set interfaceget device status类特殊请求get curget rangevolume rangesample rangeset interface USB 请求代码 typedef enum {USB_REQ_GET_STATUS = 0 ,USB_REQ_CLEAR_FEATURE …

自动化中验证码的操作笔记,懂的赶紧收藏!

在自动化测试的过程中,验证码一直被视为一个“拦路虎”。很多测试人员在做接口或UI自动化时都会遇到验证码的阻碍,导致测试无法继续进行。今天,我们就来讨论如何在自动化过程中破解验证码,快速绕过这道关卡,轻松完成自…

【C51】独立按键控制LED灯

1.简介 在单片机应用系统中,常常使用轻触按键组成键盘。轻触按键具有自动回弹的特点,即按下按键,两个触点接通,放开按键,两个触点断开。轻触按键的外形及电路符号如图,通常轻触按键有4个引脚,4个…

Redis - 深入理解Redis事务

目录 Redis是如何实现事务的?事务中执行的命令出现错误,会回滚事务吗?同一个连接可以重复开启事务吗?多个客户端同时开启事务会怎样?使用Redis事务只用MULTI和EXEC吗?Redis中的WATCH机制是怎么实现的&#…

GAMES104:13 引擎工具链基础-学习笔记

文章目录 一,工具链二,复杂的工具2.1 界面GUI2.2 设计模式Design Pattern2.3 数据的加载和存储2.4 资产引用 三,资产加载Deserialization3.1 资产解析Parse3.2 资产版本兼容性(Compatibility) 四, 如何制作…

搞安全必看——IPS和IDS到底有啥区别?

号主:老杨丨11年资深网络工程师,更多网工提升干货,请关注公众号:网络工程师俱乐部 下午好,我的网工朋友。 随着数字化转型的加速推进,网络安全已成为各行业不可或缺的一环。对于现代企业和组织而言&#x…

【JavaEE初阶】多线程6(线程池\定时器)

欢迎关注个人主页:逸狼 创造不易,可以点点赞吗~ 如有错误,欢迎指出~ 目录 实例3:线程池 参数解释 核心线程数, 最大线程数 允许空闲的最大时间 ,时间单位 任务队列(阻塞队列) 线程工厂>工厂设计模式 拒绝策略 使用举例 模拟实现一个线…

从零开始讲DDR(0)——DDR的前世今生

一、计算机组成 计算机组成结构(Computer Architecture)是计算机系统的核心,它定义了计算机的基本工作原理和设计模式。计算机的组成可以分成以下3大类:中央处理器(CPU)、存储器和输入/输出子系统。 1.1 中…

Linux文件IO-基础知识了解及文件描述符

1、简介 本章给大家介绍 Linux 应用编程中最基础的知识,即文件 I/O(Input、Outout),文件 I/O 指的是对文件的输入/输出操作,说白了就是对文件的读写操作;Linux 下一切皆文件,文件作为 Linux 系…