RTMW:实时多人2D和3D 全人体姿态估计

在这里插入图片描述
单位:上海AI实验室
代码:mmpose/tree/main/projects/rtmpose

系列文章目录

RTMO: 面向高性能单阶段的实时多人姿态估计


在这里插入图片描述

在这里插入图片描述

目录

  • 系列文章目录
  • 摘要
  • 一、背景
  • 二、相关工作
    • 2.1 自上而下的方法。
    • 2.2 坐标分类。
    • 2.3 3D Pose
  • 3 实验方法
    • 3.1.1 任务限制
    • 3.1.3训练技术


摘要

全身姿势估计是一项具有挑战性的任务,它需要同时预测身体、手、脸和脚的关键点。全身姿态估计旨在预测人体的细粒度姿态信息,包括面部、躯干、手和脚,这在以人为中心的感知和生成的研究以及各种应用中发挥着重要作用。
在这项工作中,我们提出了RTMW(实时多人全身姿态估计模型),一系列高性能的二维/三维全身姿态估计模型。我们将RTMPose模型架构与FPN和HEM(层次编码模块)相结合,以更好地捕获从不同尺度的不同身体部位的姿态信息。该模型使用丰富的开源人类关键点数据集进行训练,并使用手动对齐的注释,并通过两阶段蒸馏策略进一步增强。 RTMW在多个全身姿态估计基准上表现出了良好的性能,同时保持了高推理效率和部署友好性。


一、背景

全身姿态估计是推进以人为中心的人工智能系统能力的重要组成部分。它可用于人机交互、虚拟角色动画和电影产业。尝试在AIGC(AI生成的内容)应用程序中,全身姿态估计的结果也被用来控制角色的生成。

随着全身姿态估计支持的下游任务和工业应用的出现,设计一个高精度、低延迟、易于部署的模型是非常有价值的。在早期的人体姿态估计研究中,由于任务的复杂性和计算能力和数据的限制,研究人员将人体分成不同的部分进行独立的姿态估计研究。在前辈们的不懈努力下,在这些单独的、部分特定的二维姿态估计任务中取得了显著的成果。

之前的工作,如OpenPose [3],可以通过结合这些单独部分的结果来获得全身姿态估计结果。然而,这种简单的组合方法面临着很高的计算成本和显著的性能限制。虽然像MediaPipe [22]这样的轻量级工具提供了高实时性能和易于部署,但它们的准确性并不完全令人满意。我们的MMPose [5]团队去年发布了RTMPose [10]模型,它在准确性和实时性能之间取得了极好的平衡。随后,在此基础上,DWPose [40]通过集成一个两阶段蒸馏技术和集成一个新的数据集UBody [17],进一步提高了RTMPose在全身姿态估计任务中的性能。

RTMPose [10]的结构设计最初只考虑了身体姿势。然而,在全身姿态估计任务中,特征分辨率对面部、手和脚姿态估计的准确性至关重要。因此,我们引入了PAFPN(部分聚合特征金字塔网络)和HEM(高效多尺度特征融合)两种技术来提高特征分辨率。实验结果证实,这两个模块显著提高了细粒度体部位的定位精度。

与此同时,开源的全体姿态估计数据集的稀缺极大地限制了开源模型。为了充分利用聚焦于不同身体部位的数据集,我们手动对齐了14个开源数据集的关键点定义(3个全身关键点,6个身体关键点,4个面部关键点,1个手部关键点),这些数据集共同用于训练RTMW。在三维全身姿势估计领域,学术界主要采用了两种主要的方法:提升[26,29,42]方法和回归[28,32]方法。对基于SimCC [16]技术的方法的学术研究明显缺乏。我们的研究努力通过将RTMW架构应用到三维全身姿态估计任务中,冒险进入了未知的领域。我们的实验结果表明,SimCC [16]方法有自己的特性,并且在这一领域具有值得称赞的性能。

二、相关工作

2.1 自上而下的方法。

自顶向下的算法使用现成的探测器来提供边界盒,并将人体裁剪到一个统一的尺度,以进行姿态估计。自上而下范式的算法[2,18,31,37,39]已经主导了公共基准测试。两阶段推理范式允许人类检测器和姿态估计器使用相对较小的输入分辨率,允许它们在非极端场景下(即当图像中的人数不超过6人时),在速度和精度上优于自底而上的算法。此外,以前的大多数工作都集中在在公共数据集上实现最先进的性能。相比之下,我们的工作旨在设计具有更好的速度-精度权衡的模型,以满足工业应用的需求。

2.2 坐标分类。

以前的姿态估计方法通常将关键点定位视为坐标回归(如[14,25,33])或热图回归(如[8,37,39,41])。SimCC [16]引入了一种新的方案,将关键点预测分别从水平坐标和垂直坐标的亚像素箱中进行分类,这带来了几个优点。

首先,SimCC摆脱了对高分辨率热图的依赖,因此允许一个非常紧凑的架构,既不需要高分辨率的中间表示[31],也不需要昂贵的升级层[37]。其次,SimCC将最终的特征图扁平化以进行分类,而不是涉及全局池化[33],从而避免了空间信息的丢失。第三,通过在亚像素尺度上的坐标分类,可以有效地缓解量化误差,而不需要额外的细化后处理[41]。

这些特性使得SimCC在构建轻量级姿态估计模型方面具有吸引力。RTMO [21]将坐标分类方法引入到单阶段姿态估计中,取得了显著的性能提高,也证实了SimCC方法在姿态估计任务中的巨大潜力。在这项工作中,我们进一步利用坐标分类方案,优化模型架构和训练策略。

2.3 3D Pose

三维姿态估计是一个活跃的研究领域,具有广泛的工业应用。当代方法的景观主要由两种主要方法所主导:利用二维关键点的提升方法[26,29,42]和基于图像分析的回归方法。提升方法将二维坐标输入神经网络,直接预测其空间坐标,其计算速度快。然而,这种效率是以牺牲场景信息为代价的,因为这些算法缺乏图像输入,导致它们依赖于对训练数据的注释来确定其预测结果的范围。

相反,基于图像的回归方法[28,32]在结合丰富的视觉数据的同时,面临着推理速度缓慢和任务复杂性增加的挑战。这些因素导致了难以训练模型和实现高精度。我们提出的方法RTMW3D与传统方法不同,它采用了基于Simcc技术[16]的分类策略,通过后处理来细化最终的空间坐标。我们的实验结果强调了这种创新方法的有效性。

3 实验方法

虽然我们之前提出的RTMPose并没有针对全身关键点估计任务的特殊设计,但经过实验,我们发现它的性能可以与目前最先进的方法ZoomNas [38]相媲美。然而,在实验过程中,我们发现RTMPose在全身姿态估计任务中存在一定的性能瓶颈。随着参数规模的增加,模型的性能并不随着参数数量的增加而提高。另一方面,与其他研究团队的研究,如DWPose团队,虽然他们添加了新的数据集在训练RTMPose和采用更有效的两阶段蒸馏训练技术,有效地提高了RTMPose的准确性,他们仍然不能避免问题的固有性能瓶颈RTMPose参数数量的增加。

3.1.1 任务限制

我们首先分析了全身姿态估计任务中一些未解决的问题。RTMW旨在解决这些挑战。
第一个问题是局部区域的解决限制。 在图像中,人体的某些部分,如脸、手和脚,只占人体和图像的很小的比例。对于一个模型,这些区域的输入分辨率将直接影响模型对这些部分中的关键点的预测精度。
第二个问题是,从人体不同部位学习关键点的难度是不同的。例如,面部上的关键点可以看作是附着在面部上的一些关键点,一个刚体,由于面部的变形很小,模型会发现更容易学习预测这些面部关键点。相反,由于手指和手腕的旋转和运动,手的关键点具有更高的自由度,使它们更难以预测。
第三个问题在于损失函数。常用的损失函数,如KL散度和回归误差,都是逐点计算的。因此,它们往往是由具有更多关键点和更大的空间比例的身体部位所主导的,如躯干和面部,而不太关注小而复杂的部位,如手和脚。这通常导致了不平衡收敛,这意味着模型对较低的平均误差较低,但在复杂的身体部位表现出较差的准确性。最后一点是,开源的全身姿态估计数据集很少,这极大地限制了我们对该模型能力的研究。针对上述限制,我们为RTMPose设计了一套目标优化解决方案,并提出了我们的RTMW模型。

3.1.3训练技术

由于缺乏开源的全身姿态估计数据集,我们手动对齐了14个开源数据集,其中包括全身、躯干、手和面部的姿态估计关键点。我们使用这14个数据集进行联合训练。同时,为了使模型的性能最大化,我们采用了DWPose在模型训练过程中使用的两阶段蒸馏技术来进一步提高模型的性能。


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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[Visual studio] 性能探测器

最近发现VS的profile还是很好用的, 可以找到项目代码的瓶颈,比如发现CPU的每一个函数的时间占比,分析代码耗时分布,和火焰图一样的效果 如何使用 1. 打开你的项目,调整成release状态 2. 点击调试->性能探测器 3…

04软件测试需求分析案例-用户登录

通读文档,提取信息,提出问题,整理为需求。 从需求规格说明、设计说明、配置说明等文档获取原始需求,通读原始需求,分析有哪些功能,每种功能要完成什么业务,业务该如何实现,业务逻辑…

【Linux】:线程安全 + 死锁问题

📃个人主页:island1314 🔥个人专栏:Linux—登神长阶 ⛺️ 欢迎关注:👍点赞 👂🏽留言 😍收藏 💞 💞 💞 1. 线程安全和重入问题&…

前端下载后端文件流,文件可以下载,但是打不开,显示“文件已损坏”的问题分析与解决方案

目录 场景还原 相关代码开发者工具 - 网络请求记录 问题排查 定位改bug 总结 场景还原 我在前端使用axios接收后端xlsx表格文件流并下载,xlsx文件能够下载成功,但是打开却显示文件无法打开 相关代码 请求API封装:Content–Type以及responseType经核…

Docker Run使用方法及参数详细说明

Docker Run使用方法及参数详细说明 基本语法常用参数使用示例总结Docker Run是Docker中最基本的命令之一,用于创建并启动一个新的容器。通过Docker Run,用户可以基于指定的镜像创建一个容器实例,并且可以配置容器的各种参数,如网络设置、存储选项等。下面将详细介绍Docker …

嵌入式科普(25)Home Assistant米家集成意味着IOT的核心是智能设备

目录 一、概述 二、一张图说尽HA 三、HA的相关资料 四、米家集成划重点 五、总结 一、概述 小米Home Assistant 米家集成开源一周star近15k,迭代4个版本,12个贡献者 本文科普一下Home Assistant(简称HA)、米家集成&#xff…

每日小题打卡

目录 幂次方 手机键盘 简单排序 校庆 性感素数 幂次方 题目描述 对任意正整数 N,计算 X^Nmod233333 的值。 输入格式 共一行,两个整数 X 和 N。 输出格式 共一行,一个整数,表示 X^Nmod233333 的值。 数据范围 1≤…

费舍尔信息矩阵全面讲述

费舍尔信息矩阵(Fisher Information Matrix) 费舍尔信息矩阵是统计学中一个非常重要的概念,尤其在参数估计、最大似然估计(MLE)和贝叶斯推断中具有广泛的应用。它反映了参数估计的不确定性程度,也可以用来…

网络智能服务

网络智能服务(Network Intelligence Services)是指通过应用先进的技术、算法和数据分析能力来提升网络管理、优化网络性能、增强安全性和提供个性化服务的技术集合。网络智能服务通常结合人工智能(AI)、机器学习(ML&am…

【Three.js基础学习】33.Halftone Shading shaders

前言 半色调是一种用于印刷的技术, 通过使用相同颜色但大小不同 的点网格来创建看起来像渐变 色的颜色变化。从远处看,各 种半色调的组合会产生令人愉 悦的色调。 我们将重现这种效果,为我们的3D物体添加阴影和反射。 基本着色器已经在:src/s…

McDonald‘s Event-Driven Architecture 麦当劳事件驱动架构

原文链接 1 mcdonalds-technical-blog/ 原文链接 2 mcdonalds-technical-blog/ 麦当劳在异步、事务性和分析性处理用例中使用跨技术栈的事件,包括移动订单进度跟踪和向客户发送营销通信(交易和促销)。 统一事件平台(unified eve…

菜鸟带新鸟——基于EPlan2022的部件库制作(3D)

设备逻辑的概念: 可在布局空间 中和其它对象上放置对象。可将其它对象放置在 3D 对象上。已放置的对象分到组件的逻辑结构中。 将此属性的整体标识为设备逻辑。可使用不同的功能创建和编辑设备逻辑。 设备的逻辑定义 定义 / 旋转 / 移动 / 翻转:组…

『大模型笔记』评估大型语言模型的指标:ELO评分,BLEU,困惑度和交叉熵介绍以及举例解释

评估大型语言模型的指标:ELO评分,BLEU,困惑度和交叉熵介绍以及举例解释 文章目录 一. ELO Rating大模型的elo得分如何理解1. Elo评分的基本原理2. 示例说明3. 大模型中的Elo得分总结3个模型之间如何比较计算,给出示例进行解释1. 基本原理扩展到三方2. 示例计算第一场: A A…

MySQL基础-常见的增删改查操作语句总结

1.数据库操作 查看所有数据库 show databases;创建数据库 create database db_stu; --如果数据库已经存在就不创建 create database if not exists db_stu; --添加默认字符集 create database db_stu default charset utf8mb4;删除数据库 drop database db_stu; --如果存在…

模拟——郑益慧_笔记1_绪论

B站视频链接 模电是数电的基础;参考书: 模拟电子技术基础(第四版)华成英、童诗白主编,高等教育出版社;电子技术基础 模拟部分 康华光主编,高等教育出版社; 电子技术的发展史 电子…

【Ubuntu 20.4安装截图软件 flameshot 】

步骤一: 安装命令: sudo apt-get install flameshot 步骤二: 设置快捷方式: Ubuntu20.4 设置菜单,点击 号 步骤三: 输入软件名称, 软件快捷命令(flameshot gui)&am…

WordPress源码解析-数据库表结构

WordPress是一个功能强大的内容管理系统,它使用MySQL数据库来存储和管理网站的内容、用户和配置信息。作为WordPress开发者,了解WordPress数据库的结构和各表的作用至关重要,因为这将帮助您更好地开发插件和主题,以及执行高级数据…

Java中使用四叶天动态代理IP构建ip代理池,实现httpClient和Jsoup代理ip爬虫

在本次爬虫项目中,关于应用IP代理池方面,具体完成以下功能: 从指定API地址提取IP到ip池中(一次提取的IP数量可以自定义更改) 每次开始爬虫前(多条爬虫线程并发执行),从ip池中获取一…

Python机器学习笔记(十三、k均值聚类)

聚类(clustering)是将数据集划分成组的任务,这些组叫作簇(cluster)。其目标是划分数据,使得一个簇内的数据点非常相似且不同簇内的数据点非常不同。与分类算法类似,聚类算法为每个数据点分配&am…

KNN分类算法 HNUST【数据分析技术】(2025)

1.理论知识 KNN(K-Nearest Neighbor)算法是机器学习算法中最基础、最简单的算法之一。它既能用于分类,也能用于回归。KNN通过测量不同特征值之间的距离来进行分类。 KNN算法的思想: 对于任意n维输入向量,分别对应于特征…