论文笔记:OpenPose(Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields)

1、主要成果

提出将人体部位与个体联系起来的非参数化方法—PAFsPAFs,实现自底向上的实时多人姿态估计,在性能和效率上均实现当时最优的结果。


2、算法细节

2.1、算法原理

首先预测一组图像中人体部位位置的 2D2D 置信图 SS,以及一组表示部位相似性的 2D2D 矢量场 LL,它们表示部位之间的关联程度。集合 S=(S1,S2,,SJ)S=\left(\mathbf{S}_{1}, \mathbf{S}_{2}, \ldots, \mathbf{S}_{J}\right)SjRw×h\mathbf{S}_{j} \in \mathbb{R}^{w \times h}j{1J}j \in\{1 \ldots J\}。集合 L=(L1,L2,,LC)\mathbf{L}=\left(\mathbf{L}_{1}, \mathbf{L}_{2}, \ldots, \mathbf{L}_{C}\right)CC 个矢量场,每个肢体一个。其中,LcRw×h×2\mathbf{L}_{c} \in \mathbb{R}^{w \times h \times 2}c{1C}c \in\{1 \ldots C\}Lc\mathbf{L}_c 中的每个图像位置编码一个 2D2D 向量。最后,通过贪婪推理解析置信度图和亲和场,以输出图像中所有人的 2D2D 关键点。
论文笔记:OpenPose(Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields)


2.2、实现细节

2.2.1、网络结构

论文笔记:OpenPose(Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields)

  1. 使用 VGG19VGG-191010 层提取图像特征 F\mathbf{F}
  2. F\mathbf{F} 输入到 stage1stage-1 置信图分支网络和亲和场分支网络,分别输出 S1=ρ1(F)\mathbf{S}^{1}=\rho^{1}(\mathbf{F})L1=ϕ1(F)\mathbf{L}^{1}=\phi^{1}(\mathbf{F})
  3. 重复 stage1stage-1,输入为前一阶段的 St\mathbf{S^t}Lt\mathbf{L^t} 以及图像特征 F\mathbf{F}ConcatenateConcatenate。即,St=ρt(F,St1,Lt1),t2Lt=ϕt(F,St1,Lt1),t2 \begin{aligned} \mathbf{S}^{t} &=\rho^{t}\left(\mathbf{F}, \mathbf{S}^{t-1}, \mathbf{L}^{t-1}\right), \forall t \geq 2 \\ \mathbf{L}^{t} &=\phi^{t}\left(\mathbf{F}, \mathbf{S}^{t-1}, \mathbf{L}^{t-1}\right), \forall t \geq 2 \end{aligned}

2.2.2、损失函数

为每一阶段的两个分支网络分别设计损失函数,对损失进行空间加权,来解决一些数据集不能完全标记所有人的问题。
fSt=j=1JpW(p)Sjt(p)Sj(p)22fLt=c=1CpW(p)Lct(p)Lc(p)22 \begin{aligned} f_{\mathrm{S}}^{t} &=\sum_{j=1}^{J} \sum_{\mathrm{p}} \mathbf{W}(\mathbf{p}) \cdot\left\|\mathbf{S}_{j}^{t}(\mathbf{p})-\mathbf{S}_{j}^{*}(\mathbf{p})\right\|_{2}^{2} \\ f_{\mathrm{L}}^{t} &=\sum_{c=1}^{C} \sum_{\mathbf{p}} \mathbf{W}(\mathbf{p}) \cdot\left\|\mathbf{L}_{c}^{t}(\mathbf{p})-\mathbf{L}_{c}^{*}(\mathbf{p})\right\|_{2}^{2} \end{aligned}
其中,W\mathbf{W} 为二进制 maskmask,当图像位置 pp 没有注释时,W(p)=0\mathbf{W(p)=0},避免训练时惩罚 TP\mathbf{TP} 预测。每个阶段的中间监督通过定期补充梯度来解决梯度消失问题。总损失为:
f=t=1T(fSt+fLt) f=\sum_{t=1}^{T}\left(f_{\mathrm{S}}^{t}+f_{\mathrm{L}}^{t}\right)


2.2.3、GT 置信图生成

GTGT 置信图根据标注的人体关键点位置生成,以多人为例,第 kk 个人的第 jj 个可见部位的置信图表示为 Sj,k\mathbf{S}_{j, k}^{*}
Sj,k(p)=exp(pxj,k22σ2) \mathbf{S}_{j, k}^{*}(\mathbf{p})=\exp \left(-\frac{\left\|\mathbf{p}-\mathbf{x}_{j, k}\right\|_{2}^{2}}{\sigma^{2}}\right)
其中,pR2\mathbf{p} \in \mathbb{R}^{2}xj,k\mathbf{x}_{j, k} 为关键点标注位置。则,
Sj(p)=maxkSj,k(p) \mathbf{S}_{j}^{*}(\mathbf{p})=\max _{k} \mathbf{S}_{j, k}^{*}(\mathbf{p})


2.2.4、PAFs 生成

论文笔记:OpenPose(Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields)
论文笔记:OpenPose(Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields)
Lc,k(p)={v if p on limb c,k0 otherwise  \mathbf{L}_{c, k}^{*}(\mathbf{p})=\left\{\begin{array}{ll}{\mathbf{v}} & {\text { if } \mathbf{p} \text { on limb } c, k} \\ {0} & {\text { otherwise }}\end{array}\right.
当点 ppkk 的肢体 cc 上时,Lc,k(p)\mathbf{L}_{c, k}^{*}(\mathbf{p}) 等于从关键点 j1j_1 指向关键点 j2j_2 的单位向量。否则为零向量。肢体上的点必须满足以下条件:
0v(pxj1,k)lc,k and v(pxj1,k)σl 0 \leq \mathbf{v} \cdot\left(\mathbf{p}-\mathbf{x}_{j_{1}, k}\right) \leq l_{c, k} \text { and }\left|\mathbf{v}_{\perp} \cdot\left(\mathbf{p}-\mathbf{x}_{j_{1}, k}\right)\right| \leq \sigma_{l}
其中肢体长度:lc,k=xj2,kxj1,k2l_{c, k}=\left\|\mathbf{x}_{j_{2}, k}-\mathbf{x}_{j_{1}, k}\right\|_{2}
肢体宽度:σl\sigma_{l} 为像素距离
最终 PAFsPAFs 为图像中所有人的平均亲和场:
Lc(p)=1nc(p)kLc,k(p) \mathbf{L}_{c}^{*}(\mathbf{p})=\frac{1}{n_{c}(\mathbf{p})} \sum_{k} \mathbf{L}_{c, k}^{*}(\mathbf{p})
其中,nc(p)n_c(\mathbf{p}) 为点 p\mathbf{p} 处所有人产生的非零向量个数。

测试阶段,通过沿着连接候选部位位置的线段,计算相应 PAFPAF 上的线积分来测量候选部位检测之间的关联。
E=u=0u=1Lc(p(u))dj2dj1dj2dj12du E=\int_{u=0}^{u=1} \mathbf{L}_{c}(\mathbf{p}(u)) \cdot \frac{\mathbf{d}_{j_{2}}-\mathbf{d}_{j_{1}}}{\left\|\mathbf{d}_{j_{2}}-\mathbf{d}_{j_{1}}\right\|_{2}} d u
p(u)\mathbf{p}(u) 为两个人体部位 dj1d_{j1}dj2d_{j2} 的位置插值。
p(u)=(1u)dj1+udj2 \mathbf{p}(u)=(1-u) \mathbf{d}_{j_{1}}+u \mathbf{d}_{j_{2}}
实际中通过对 uu 均匀采样,然后求和来近似积分


2.2.5、PAFs 多人分析

通过对检测置信度图执行非最大值抑制,以获得一组离散的部位候选位置。每个部位可能生成多个候选,经过组合生成大量的候选肢体。通过在 PAFPAF 上计算线积分来对每个候选肢体打分。找到最优解的问题对应于一个已知为 NPNP 难的 KK 维匹配问题。
论文笔记:OpenPose(Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields)
在这篇文章中,作者提出了一种贪婪的简化方法,能够始终产生高质量的匹配。推测原因是成对关联分数隐含地编码了全局上下文,这是由于 PAFPAF 网络的感受野很大。
DJ={djm:j{1J},m{1Nj}} \mathcal{D}_{\mathcal{J}}=\left\{\mathbf{d}_{j}^{m} :\right.j \in\{1 \ldots J\}, m \in\left\{1 \ldots N_{j}\right\} \}
djm\mathbf{d}_{j}^{m} 表示部位 jj 的第 mm 个候选。接下来需要确定部位对构成的肢体。zj1j2mn{0,1}z_{j_{1} j_{2}}^{m n} \in\{0,1\}表示 dj1m\mathbf{d}_{j1}^{m}dj2n\mathbf{d}_{j2}^{n} 是否相连。目标是找到最优分配方案:
Z={zj1j2mn:j1,j2{1J},m{1Nj1},n{1Nj2}} \mathcal{Z}=\left\{z_{j_{1} j_{2}}^{m n} :\right.j_{1}, j_{2} \in\{1 \ldots J\}, m \in\left\{1 \ldots N_{j_{1}}\right\}, n \in\left\{1 \ldots N_{j_{2}}\right\} \}
寻找最佳关联简化为最大权重二部图匹配问题。该问题中,结点为 Dj1D_{j1}Dj2D_{j2},边是两组结点间所有可能的连接。每条边的权重为之前计算的线积分 EE二部图中的匹配是以没有两条边共享一个结点的方式选择的边的子集优化的目标是为选定的边找到最大权重的匹配
maxZcEc=maxZcmDj1nDj2Emnzj1j2mn \max _{\mathcal{Z}_{c}} E_{c}=\max _{\mathcal{Z}_{c}} \sum_{m \in \mathcal{D}_{j_{1}}} \sum_{n \in \mathcal{D}_{j_{2}}} E_{m n} \cdot z_{j_{1} j_{2}}^{m n}
 s.t. mDj1,nDj2zj1j2mn1nDj2,mDj1zj1j2mn1 \begin{aligned} {\text { s.t. } \quad \forall m \in \mathcal{D}_{j_{1}}, \sum_{n \in \mathcal{D}_{j_{2}}} z_{j_{1} j_{2}}^{m n} \leq 1} \\ {\forall n \in \mathcal{D}_{j_{2}}, \sum_{m \in \mathcal{D}_{j_{1}}} z_{j_{1} j_{2}}^{m n} \leq 1} \end{aligned}
通过 HungarianHungarian 算法获取最优匹配。

当涉及到寻找多人的全身姿态时,确定 ZZ 是一个 KK 维匹配问题。这个问题是 NPNP 难并且有许多松弛存在。作者为优化添加两个松弛。

  1. 选择最小数量的边来获得人体姿态的生成树骨架,而不是使用完整的图,如图 6c6c 所示。
  2. 进一步将匹配问题分解成一组二部匹配子问题,并独立地确定相邻树节点中的匹配,如图 6d6d 所示。

结果表明最小贪婪推理很好地近似了全局解,只需要计算成本的一小部分。原因是相邻树节点之间的关系是由 PAFsPAFs 显式建模的,但在内部,不相邻树节点之间的关系是由 CNNCNN 隐式建模的。这一特性的出现是因为 CNNCNN 有一个大的感受野,并且来自非相邻树节点的 PAFsPAFs 也影响预测的 PAFPAF 。因此,优化可以被简化为:
maxZE=c=1CmaxZcEc \max _{\mathcal{Z}} E=\sum_{c=1}^{C} \max _{\mathcal{Z}_{c}} E_{c}
因此,可以独立地获得每种肢体类型的肢体连接候选对于所有肢体连接候选,可以将共享相同部位检测候选的连接,组合成多人的全身姿势在树结构上的优化方案比在全连接图上的优化快几个数量级


2.2.6、结果

论文笔记:OpenPose(Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields)
论文笔记:OpenPose(Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields)
论文笔记:OpenPose(Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields)
论文笔记:OpenPose(Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields)
论文笔记:OpenPose(Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields)
论文笔记:OpenPose(Realtime Multi-Person 2D Pose Estimation using Part Affinity Fields)

3、总结

主要贡献——PAFsPAFs:

  1. 部位置信图生成对图像中所有人的同一类部位的高斯分布置信图取上限得到
  2. 亲和场生成对图像中所有人的同一类肢体的亲和场求平均得到
  3. 预测结果生成
    1. 将所有部位全连接图简化为树状图(类似传统方法的姿态树)
    2. 树形图也嫌麻烦,再拆分为二部图优化,每次解决一类肢体的生成问题
    3. 通过匈牙利算法求解,获得最大权重匹配的节点分配策略
  4. 边权重的确定沿着部位位置连接成的线段,计算 PAFPAF 上的线积分即为权重

4、感想

主要是贡献—PAFsPAFs,论文中涉及的具体的深度学习的实现细节不多,感觉这一块有一些提升的空间,可以尝试结合深度学习网络设计、损失函数设计方面的一些新的方法。