总结:ppm是以一种特殊的池化模型。通过由多到少的池化,可以有效增大感受野,增大全局信息的利用效率。
原文链接:https://blog.csdn.net/wd18508423052/article/details/93882113
Pyramid pooling 方法出自 2017CVPR,原文地址https://arxiv.org/pdf/1612.01105.pdf
该文的一大贡献就是Pyramid pooling module(简称PPM)
1. PPM有什么用
一般可以粗略地认为感受野就是使用上下文信息的大小。在很多网络中,我们都很重视全局信息的获取。在FCN中,就是没有充分的场景的上下文信息,导致在一些不同尺度的物体分割上处理不好。
没有充分利用好场景的上下文信息就会有这些问题(分别如上图所示):
(1)Mismatched Relationship
(2)Confusion Categories
(3)Inconspicuous Classes
总之,PPM就是一种相对较好的充分利用全局信息的方式。这种保留全局信息的思路其实与ASPP(Atrous Spatial Pyramid Pooling) 很相似。从直觉上来看,这种多尺度的pooling确实是可以在不同的尺度下来保留全局信息,比起普通的单一pooling更能保留全局上下文信息。
2 PPM的结构
下面描述下PPM的过程。
原文中采用4种不同金字塔尺度,金字塔池化模块的层数和每层的size是可以修改的。论文中金字塔池化模块是4层,每层的size分别是1×1,2×2,3×3,6×6。
首先,对特征图分别池化到目标size,然后对池化后的结果进行1×1卷积将channel减少到原来的1/N,这里N就为4。接着,对上一步的每一个特征图利用双线性插值上采样得到原特征图相同的size,然后将原特征图和上采样得到的特征图按channel维进行concatenate。得到的channel是原特征图的channel的两倍,最后再用1×1卷积将channel缩小到原来的channel。最终的特征图和原来的特征图size和channel是一样的。