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

引言

大规模预训练以及随后针对特定任务的语言建模微调取得了显著成功,已将这种方法确立为标准做法。同样, 计算机视觉方法正逐步采用大规模数据进行预训练。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 模型有可能成为众多下游任务的关键构建块,并为社区中更广泛的群体提供高质量视觉主干的访问权限。

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

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

相关文章

计算机毕业设计 健身房管理系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍:✌从事软件开发10年之余,专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ 🍅文末获取源码联系🍅 👇🏻 精…

Linux--守护进程与会话

进程组 概念 进程组就是一个或多个进程的集合。 一个进程组可以包含多个进程。 下面我们通过一句简单的命令行来展示: 为什么会有进程组? 批量操作:进程组允许将多个进程组织在一起,形成一个逻辑上的整体。当需要对多个进程…

Matlab如何配置小波工具(Wavelet Toolbox)

1、发现问题 因为实验要使用小波工具函数,运行时报错如下: 查看对应文件夹发现没有小波工具(也可在控制台输入ver),检查是否有该工具,输入后回车返回如下: 2、下载工具包 没有这个工具就要去下…

【浅水模型MATLAB】尝试复刻SCI论文中的溃坝流算例

【浅水模型MATLAB】尝试复刻SCI论文中的溃坝流算例 前言问题描述控制方程及数值方法浅水方程及其数值计算方法边界条件的实现 代码框架与关键代码模拟结果 更新于2024年9月17日 前言 这篇博客算是学习浅水方程,并利用MATLAB复刻Liang (2004)1中溃坝流算例的一个记录…

Gitee丝滑版本:成功在新电脑添加新文件

git 关键步骤 1.首先在新电脑建一个文件夹,然后打开这个文件夹里面右键打开OPEN BASH GIT HERE。 2.然后输入git init,会在文件夹生成一个git.文件,接着把复制的get clone命令克隆过去就可以下载了,如果遇到403问题&#xff0c…

循环神经网络RNN+长短期记忆网络LSTM 学习记录

循环神经网络(RNN) RNN的的基础单元是一个循环单元,前部序列的信息经处理后,作为输入信息传递到后部序列 x为输入向量,y为输出向量,a为上一隐藏层的a与x通过激活函数得到的值,简言之,每一层神…

从头开始学MyBatis—02基于xml和注解分别实现的增删改查

首先介绍此次使用的数据库结构,然后引出注意事项。 通过基于xml和基于注解的方式分别实现了增删改查,还有获取参数值、返回值的不同类型对比,帮助大家一次性掌握两种代码编写能力。 目录 数据库 数据库表 实体类 对应的实体类如下&#x…

Java项目: 基于SpringBoot+mybatis+maven洗衣店订单管理系统(含源码+数据库+开题报告+任务书+毕业论文)

一、项目简介 本项目是一套基于SpringBootmybatismaven洗衣店订单管理系统 包含:项目源码、数据库脚本等,该项目附带全部源码可作为毕设使用。 项目都经过严格调试,eclipse或者idea 确保可以运行! 该系统功能完善、界面美观、操作…

List<Map<String, Object>>汇总统计排序

开发环境&#xff1a;jdk 1.8 需求一&#xff1a; 1、统计每个小时(升序)不同事件的产品产量 2、统计不同事件&#xff08;OK 、NG&#xff09;的总产量 public static void main(String[] args) {//数据源List<Map<String, Object>> list new ArrayList<Map…

根据 IP 地址进行 VPN 分流(详细,亲测,通用)

根据 IP 地址进行 VPN 分流&#xff08;详细&#xff0c;亲测&#xff0c;通用&#xff09; 背景 不在学校的时候需要使用实验室的服务器&#xff0c;但是实验室的服务器只能在校园网内访问&#xff0c;因此在校外就需要使用学校的 VPN&#xff0c;但是打开 VPN 以后会默认将…

js 3个事件监听器 EventListeners

起因&#xff0c; 目的: 我有2个显示器。 某视频网站&#xff0c;我想一边播放视频&#xff0c;一边搞其他。但是&#xff0c;当我把鼠标移动到浏览器外面&#xff0c;点击一下别处&#xff0c; 视频就会自动暂停. 这个叫做 事件监听&#xff01; blur, 在元素或窗口失去焦点…

JSON对接发送短信验证码怎么获取状态报告

现在很多网站的用户注册都会加一个短信验证功能&#xff0c;也就是需要用户填写手机号&#xff0c;然后点击“获取短信验证码”&#xff0c;将收到的短信验证码输入验证通过后方能进行下一步完成注册&#xff0c;现在短信验证码被广泛应用于网站用户注册&#xff0c;还被广泛应…

linux 安装histomicstk

一直安装失败&#xff0c;源码编译也未成功 最后使用这个成功了 pip install histomicstk --find-links https://girder.github.io/large_image_wheels

零基础如何学会Appium自动化测试?

前言 appium是一款移动自动化测试工具&#xff0c;经常被用于实现UI自动化测试&#xff0c;其可支持安卓和IOS两大平台&#xff0c;还支持多种编程&#xff0c;因而得到了广泛的应用。此处便是立足于安卓平台&#xff0c;借助appium工具&#xff0c;使用python语言实现简单的自…

王者荣耀改重复名(java源码)

王者荣耀改重复名 项目简介 “王者荣耀改重复名”是一个基于 Spring Boot 的应用程序&#xff0c;用于生成王者荣耀游戏中的唯一名称。通过简单的接口和前端页面&#xff0c;用户可以输入旧名称并获得一个新的、不重复的名称。 功能特点 生成新名称&#xff1a;提供一个接口…

[mysql]mysql排序和分页

#排序和分页本身是两块内容,因为都比较简单,我们就把它分到通一个内容里. #1排序: SELECT * FROM employees #我们会发现,我们没有做排序操作,但是最后出来的107条结果还是会按顺序发出,而且是每次都一样.这我们就有一个疑惑了,现在我们的数据库是根据什么来排序的,在我们没有进…

【机器学习】--- 自然语言推理(NLI)

引言 随着自然语言处理&#xff08;NLP&#xff09;的迅速发展&#xff0c;**自然语言推理&#xff08;Natural Language Inference, NLI&#xff09;**已成为一项重要的研究任务。它的目标是判断两个文本片段之间的逻辑关系。这一任务广泛应用于机器阅读理解、问答系统、对话…

二叉搜索树(Java实现)

博主主页: 码农派大星. 数据结构专栏:Java数据结构 数据库专栏:MySQL数据库 JavaEE专栏:JavaEE 关注博主带你了解更多数据结构知识 目录 1.概念 2.实现二叉搜索树 定义节点 查找元素 插入元素 删除元素 1.概念 二叉搜索树又称二叉排序树,或者它是一棵空树,或者是具有…

数字IC设计\FPGA 职位经典笔试面试整理--语法篇 Verilog System Verilog(部分)

注&#xff1a; 资料都是基于网上一些博客分享和自己学习整理而成的 Verilog 1. 数据类型 Verilog一共有19种数据类型 基础四种数据类型&#xff1a;reg型&#xff0c;wire型&#xff0c;integer型&#xff0c;parameter型 reg型   reg类型是寄存器数据类型的关键字。寄存…

镀金引线---

一、沉金和镀金 沉金和镀金都是常见的PCB金手指处理方式&#xff0c;它们各有优劣势&#xff0c;选择哪种方式取决于具体的应用需求和预算。 沉金&#xff08;ENIG&#xff09;是一种常用的金手指处理方式&#xff0c;它通过在金手指表面沉积一层金层来提高接触性能和耐腐蚀性…