1.ResNet出现的意义 随着网络的加深,因为存在梯度消失和梯度爆炸问题,容易出现训练集准确率下降的现象,我们可以确定这不是由于Overfit过拟合造成的(过拟合的情况训练集应该准确率很高);所以作者针对这个问题提出了一种全新的网络,叫深度残差。 2.残差指的是什么?其中ResNet提出了两种mapping:一种是identity mapping,指的就是图1中”弯弯的曲线”,另一种residual mapping,指的就是除了”弯弯的曲线“那部分,所以最后的输出是 y=F(x)+x
identity mapping顾名思义,就是指本身,也就是公式中的x,而residual mapping指的是“差”,也就是y−x,所以残差指的就是F(x)部分。 3.为什么ResNet可以解决“随着网络加深,准确率不下降”的问题?1.实验证明
2.理论上,对于“随着网络加深,准确率下降”的问题,Resnet提供了两种选择方式,也就是identity mapping和residual mapping,如果网络已经到达最优,继续加深网络,residual mapping将被push为0,只剩下identity mapping,这样理论上网络一直处于最优状态了,网络的性能也就不会随着深度增加而降低了。 4.ResNet的结构它使用了一种连接方式叫做“shortcut connection”,顾名思义,shortcut就是“抄近道”的意思,主要有两种结果:
这两种结构分别针对ResNet34(左图)和ResNet50/101/152(右图),一般称整个结构为一个”building block“。其中右图又称为”bottleneck design”,目的一目了然,就是为了降低参数的数目,第一个1x1的卷积把256维channel降到64维,然后在最后通过1x1卷积恢复,整体上用的参数数目:1x1x256x64 + 3x3x64x64 + 1x1x64x256 = 69632,而不使用bottleneck的话就是两个3x3x256的卷积,参数数目: 3x3x256x256x2 = 1179648,差了16.94倍。 对于常规ResNet,可以用于34层或者更少的网络中,对于Bottleneck Design的ResNet通常用于更深的如101这样的网络中,目的是减少计算和参数量(实用目的)。 5.ResNet结构是怎么相加的?F(x)和x通道相同是按照channel维度相加的,channel不同怎么相加呢?针对channel个数是否相同,要分成两种情况考虑,如下图:
如图所示,我们可以清楚的”实线“和”虚线“两种连接方式,
实线的的Connection部分,他们的channel个数一致,所以采用计算方式:
y=F(x)+x
虚线的的Connection部分。他们的channel个数不同(64和128),所以采用计算方式:
y=F(x)+Wx
其中W是卷积操作,用来调整x的channel维度的;或者,用零来补全相加。 6.4.基于ResNet101的Faster RCNN文章中把ResNet101应用在Faster RCNN上取得了更好的结果,结果如下:
图展示了基于ResNet101的Faster RCNN 的架构,其中蓝色的部分为ResNet101,可以发现conv4_x的最后的输出为RPN和RoI Pooling共享的部分,而conv5_x(共9层网络)都作用于RoI Pooling之后的一堆特征图(14 x 14 x 1024),特征图的大小维度也刚好符合原本的ResNet101中conv5_x的输入;
最后大家一定要记得最后要接一个average pooling,得到2048维特征,分别用于分类和框回归。
|