【论文翻译】Deep Residual Learning for Image Recognition

论文题目:Deep Residual Learning for Image Recognition
论文来源:Deep Residual Learning for Image Recognition
翻译人:BDML@CQUT实验室

Deep Residual Learning forImage Recognition

Kaiming He Xiangyu Zhang Shaoqing Ren Jian Sun Microsoft Research {kahe, v-xiangz, v-shren, jiansun}@microsoft.com

基于深度残差学习的图像识别

Kaiming He Xiangyu Zhang Shaoqing Ren Jian Sun Microsoft Research {kahe, v-xiangz, v-shren, jiansun}@microsoft.com

Abstract

Deeper neural networks are more difficult to train. We present a residual learning framework to ease the training of networks that are substantially deeper than those used previously. We explicitly reformulate the layers as learning residual functions with reference to the layer inputs, instead of learning unreferenced functions. We provide comprehensive empirical evidence showing that these residual networks are easier to optimize,and can gain accuracy from considerably increased depth. On the ImageNet dataset we evaluate residualnets with adepth of up to152 layers—8× deeper than VGG nets but still having lower complexity. Anensembleoftheseresidualnetsachieves3.57%error on the ImageNet testset. This result won the1st place on the ILSVRC 2015 classification task. We also present analysis on CIFAR-10 with 100 and 1000 layers.
The depth of representations is of central importance for many visual recognition tasks. Solely due to our extremely deep representations, we obtain a 28% relative improvement on the COCO object detection dataset. Deep residualnets are foundations of our submissions to ILSVRC & COCO 2015 competitions1, where we also won the 1st places on the tasks of ImageNet detection, ImageNet localization, COCO detection, and COCO segmentation.

更深层次的神经网络更难训练。我们提出了一个剩余学习框架,以便于对比以前使用的网络更深入的培训。我们明确地将层重新定义为参考层输入的学习剩余函数,而不是学习未引用的函数。我们提供了全面的经验证据,表明这些残差网络更容易优化,并且可以从显著增加的深度中获得精度。在ImageNet数据集上,我们评估深度高达152层的剩余网络,比VGG网络深8倍,但复杂性仍然较低。这些残差网的集合在ImageNet测试集上达到了3.57%的误差。该结果在ILSVRC 2015分类任务中获得第一名。我们还对100层和1000层的CIF-AR-10进行了分析。

在许多视觉识别任务中,表征的深度是至关重要的。仅仅由于我们非常深入的表示,我们获得了28%的相对改善的COCO对象检测数据集。深度残差网是我们提交ILSVRC和COCO 2015竞赛1的基础,我们在ImageNet检测、ImageNet定位、COCO检测和COCO分割任务中也获得了第一名。

1.Introduction

Deep convolutional neural networks have led to a series of breakthroughs for image classification . Deep networks naturally integrate low/mid/highlevel features and classifiers in an end-to-end multilayer fashion, and the “levels” of features can be enriched by the number of stacked layers (depth). Recent evidence revealsthatnetworkdepthisofcrucialimportance, and the leading results on the challenging ImageNet dataset all exploit “very deep” models, with a depth of sixteen to thirty . Many other nontrivial visual recognition tasks have also greatly benefited from very deep models.
深卷积神经网络为图像分类带来了一系列突破。深层网络自然地以端到端的多层方式集成低/中/高层特征和分类器,并且特征的“层次”可以通过层叠层数(深度)来丰富。最近的证据揭示了网络深度是至关重要的,具有挑战性的ImageNet数据集的主要结果都采用了“非常深”模型,深度为16到30。许多其他非平凡的视觉识别任务也有从非常深入的模型中受益匪浅。

Driven by the significance of depth, a question arises: Is learning better networks as easy as stacking more layers? An obstacle to answering this question was the notorious problem of vanishing/exploding gradients , which hamper convergence from the beginning. This problem, however, has been largely addressed by normalized initialization and intermediate normalization layers ,which enable networks with tens of layers to start converging for stochastic gradient descent (SGD) with backpropagation .
在深度的重要性的驱使下,一个问题出现了:学习更好的网络是否像堆叠更多层一样容易?回答这个问题的一个障碍是众所周知的梯度消失/爆炸问题,它从一开始就阻碍了收敛。然而,这个问题在很大程度上已经通过规范化初始化和中间规范化层来解决,这使得具有数十层的网络能够开始收敛,以进行反向传播的随机梯度下降(SGD)。

When deeper networks are able to start converging, a degradation problem has been exposed: with the network depth increasing, accuracy gets saturated (which might be unsurprising) and then degrades rapidly. Unexpectedly, such degradation is not caused by overfitting, and adding more layers to a suitably deep model leads to higher training error, asreportedin and thoroughly verified by our experiments. Fig. 1 shows a typical example.
当更深层的网络能够开始收敛时,一个退化的问题就暴露出来了:随着网络深度的增加,精度达到饱和(这可能并不奇怪),然后迅速下降。出乎意料的是,这种退化并不是由过度拟合引起的,而且在适当的深度模型中添加更多的层会导致更高的训练误差,如中所述,并通过我们的实验得到了充分的验证。图1示出了一个典型示例。
在这里插入图片描述
The degradation (of training accuracy) indicates that not all systems are similarly easy to optimize. Let us considera shallower architecture and its deeper counterpart that adds more layers onto it. There exists a solution by construction to the deeper model: the added layers are identity mapping, and the other layers are copied from the learned shallower model. The existence of this constructed solution indicates that adeeper model should produce no higher training error than its shallower counterpart. But experiments show that our current solvers on hand are unable to find solutions that are comparably good or better than the constructed solution (or unable to do so in feasible time).
(训练精度的)下降表明并非所有的系统都同样容易优化。让我们考虑一个较浅的架构和它的深层对应物,为它添加了更多的层。对于更深层次的模型,存在一种构造解决方案:添加的层是身份映射,其他层是从学习的浅层模型复制的。此构造解的存在性表明,较深的模型不应比较浅的模型产生更高的训练误差。但实验表明,我们现有的解决方案无法找到与构建的解决方案相当好或更好(或在可行的时间内无法做到)。

In this paper, we address the degradation problem by introducing a deep residual learning framework. Instead of hoping each few stacked layers directly fit a desired underlying mapping, we explicitly let these layers fit a residual mapping. Formally, denoting the desired underlying mapping as H ( x ) H(x) H(x), we let the stacked nonlinear layers fit an other mapping of F ( x ) : = H ( x ) − x F(x) :=H(x)−x F(x):=H(x)x. The original mapping is recastin to F ( x ) + x F(x)+x F(x)+x. We hypothesize that it is easier to optimize the residual mapping than to optimize the original, unreferenced mapping. To the extreme, if an identity mapping were optimal, it would be easier to push the residual to zero than to fit an identity mapping by as tack of nonlinear layers.
在本文中,我们通过引入深度剩余学习框架来解决退化问题。我们不希望每一个层叠的层都直接适合一个期望的底层映射,而是显式地让这些层适合一个剩余映射。形式上,将期望的底层映射表示为 H ( x ) H(x) H(x),我们让堆叠的非线性层拟合 F ( x ) F(x) F(x)的另一个映射: F ( x ) = H ( x ) − x F(x)=H(x)−x F(x)=H(x)x。原始映射被重新转换为 F ( x ) + x F(x)+x F(x)+x。我们假设优化剩余映射比优化原始未引用映射更容易。在极端情况下,如果一个身份映射是最优的,那么将残差推到零比通过一堆非线性层来拟合身份映射更容易。

The formulation of F ( x ) + x F(x)+x F(x)+x can be realized by feedforward neural networks with “shortcut connections” (Fig. 2). Shortcut connections are those skipping one or more layers. In our case, the shortcut connections simply perform identity mapping, and their outputs are added to the outputs of the stacked layers (Fig. 2). Identity shortcut connections add neither extra parameter nor computational complexity. The entire network can still be trained end-to-end by SGD with backpropagation, and can be easily implemented using common libraries (e.g., Caffe [19]) without modifying the solvers.
F ( x ) + x F(x)+x F(x)+x的公式可以通过具有“捷径连接”的前馈神经网络实现(图2)。快捷连接是指跳过一个或多个层的连接。在我们的例子中,快捷连接只执行标识映射,它们的输出被添加到堆叠层的输出中(图2)。标识快捷连接既不会增加额外的参数,也不会增加计算复杂性。整个网络仍然可以通过反向传播的SGD进行端到端的训练,并且可以使用公共库(例如Caffe)轻松实现,而无需修改解算器。

在这里插入图片描述
We present comprehensive experiments on ImageNet to show the degradation problem and evaluate our method. Weshowthat: 1)Ourextremelydeepresidualnets are easy to optimize, but the counterpart “plain” nets (that simply stack layers) exhibit higher training error when the depth increases; 2) Our deep residual nets can easily enjoy accuracy gains from greatly increased depth, producing results substantially better than previous networks.
我们在ImageNet上进行了综合实验,以说明退化问题并评估了我们的方法。我们的研究表明:1)我们的极深残差网易于优化,但当深度增加时,对应的“普通”网(即简单的叠加层)表现出更高的训练误差;2)我们的深残差网可以很容易地享受深度大幅增加带来的精度提高,产生的结果比以前的网络好得多。

Similar phenomena are also shown on the CIFAR-10 set [20], suggesting that the optimization difficulties and the effects of our method are not just akin to a particular dataset. We present successfully trained models on this dataset with over 100 layers, and explore models with over 1000 layers.
在CIFAR-10集合上也显示了类似的现象,这表明我们的方法的优化困难和效果不仅仅类似于特定的数据集。我们在这个数据集中展示了100多个层次的成功训练模型,并探索了1000多个层次的模型。

On the ImageNet classification dataset , we obtain excellent results by extremely deep residual nets. Our 152 layer residual net is the deepest network ever presented on ImageNet, while still having lower complexity than VGG nets . Our ensemble has 3.57% top-5 error on the ImageNet test set, and won the 1st place in the ILSVRC 2015 classification competition. The extremely deep representations also have excellent generalization performance on other recognition tasks, and lead us to further win the 1st places on: ImageNet detection, ImageNet localization, COCO detection, and COCO segmentation in ILSVRC & COCO2015 competitions. This strong evidence shows that the residual learning principle is generic, and we expect that it is applicable in other vision and non-vision problems.
在ImageNet分类数据集上,我们利用极深残差网得到了很好的结果。我们的152层剩余网络是ImageNet上有史以来最深的网络,但其复杂性仍然低于VGG网络。我们的组合有3.57%的前5名错误ImageNet测试集,并在ILSVRC 2015分类竞赛中获得第一名。在其他识别任务中,极深的表征也具有优异的泛化性能,使我们在ILSVRC&COCO 2015竞赛中进一步获得ImageNet检测、ImageNet定位、COCO检测和COCO分割的第一名。这有力的证据表明,剩余学习原理是通用的,我们期望它适用于其他视觉和非视觉问题。

2.RelatedWork

Residual Representations. In image recognition, VLAD is a representation that encodes by the residual vectors with respect to a dictionary, and Fisher Vector can be formulated as a probabilistic version of VLAD. Both of them are powerful shallow representations for image retrieval and classification . For vector quantization, encoding residual vectors is shown to be more effective than encoding original vectors.
剩余表示。 在图像识别中,VLAD是相对于字典的残差向量进行编码的表示,而Fisher Vector可以表示为VLAD的概率版本。它们都是图像检索和分类的有力的浅层表示。对于矢量量化,编码残余向量比编码原始向量更有效。

In low-level vision and computer graphics, for solving Partial Differential Equations (PDEs), the widely used Multigrid method reformulates the system as subproblems at multiple scales, where each subproblem is responsible for the residual solution between a coarser and a finer scale. An alternative to Multigrid is hierarchical basis preconditioning , which relies on variables that represen tresidual vectors between two scales. It has been shown that these solvers converge much faster than standard solvers that are unaware of the residual nature of the solutions. Thesemethodssuggestthatagoodreformulation or preconditioning can simplify the optimization.
在低层视觉和计算机图形学中,为了求解偏微分方程(PDEs),广泛使用的多重网格方法将系统重新定义为多个尺度的子问题,其中每个子问题负责粗尺度和细尺度之间的剩余解。多重网格的另一种选择是分层基础预处理,它依赖于表示两个尺度之间的残差向量的变量。已经证明这些解算器比不知道解的剩余性质的标准解算器收敛得快得多。这些方法表明,一个好的重组或预处理可以简化优化。

Shortcut Connections. Practices and theories that lead to short cut connections have been studied for along time. An early practice of training multi-layer perceptrons (MLPs) is to add a linear layer connected from the network input to the output . In, a few intermediate layers are directly connected to auxiliary classifiers for addressing vanishing/exploding gradients. The papers of propose methods for centering layer responses, gradients, and propagated errors, implemented by shortcut connections. In , an “inception” layer is composed of a shortcut branch and a few deeper branches.
快捷连接。导致捷径连接的实践和理论已经被研究了很长时间。训练多层感知器(mlp)的早期实践是添加一个从网络输入连接到输出的线性层。一些中间层直接连接到辅助分类器,用于处理消失/爆炸梯度。的论文提出了用快捷连接实现的对中层响应、梯度和传播误差的方法。“初始”层由一个快捷分支和几个更深的分支组成。

Concurrent with our work, “highway networks” present shortcut connections with gating functions . These gates are data-dependent and have parameters, in contrast to our identity shortcuts that are parameter-free. When a gated shortcut is “closed” (approaching zero), the layers in highway networks represent nonresidual functions. On the contrary, our formulation always learns residual functions; our identity shortcuts are never closed, and all information is always passed through, with additional residual functions to be learned. In addition, high-way networks have not demonstrated accuracy gains with extremely increased depth (e.g., over 100 layers).
与我们的工作同时,“公路网”提供了具有门控功能的快捷连接。这些门依赖于数据并且有参数,而我们的身份快捷方式是无参数的。当封闭的快捷方式“关闭”(接近零)时,公路网中的图层表示非残差函数。相反,我们的公式总是学习残差函数;我们的身份捷径从不封闭,所有的信息总是通过,还有其他剩余函数需要学习。此外,高速网络还没有显示出深度的极大增加会带来精度的提高

3.DeepResidualLearning

3.1.ResidualLearning

Let us consider H ( x ) H(x) H(x) as an underlying mapping to be fit by a few stacked layers (not necessarily the entire net), with x x x denoting the inputs to the first of these layers. If one hypothesizes that multiple nonlinear layers can asymptotically approximate complicated functions 2, then it is equivalent to hypothesize that they can asymptotically approximate the residual functions, i.e., H ( x ) − x H(x)−x H(x)x (assuming that the input and output are of the same dimensions). So rather than expect stacked layers to approximate H ( x ) H(x) H(x), we explicitly let these layers approximate a residual function F ( x ) : = H ( x ) − x F(x) :=H(x) − x F(x):=H(x)x. The original function thus becomes F ( x ) + x F(x)+x F(x)+x. Althoughbothformsshouldbeabletoasymptotically approximate the desired functions (as hypothesized), the ease of learning might be different.
让我们把 H ( x ) H(x) H(x)看作是一个底层映射,它由几个堆叠层(不一定是整个网络)拟合,x表示这些层中第一个层的输入。如果假设多个非线性层可以渐近逼近复杂函数2,那么就相当于假设它们可以渐近逼近剩余函数,即 H ( x ) − x H(x)−x H(x)x(假设输入和输出具有相同的维数)。因此,我们不希望堆叠层近似 H ( x ) H(x) H(x),而是明确地让这些层近似于一个剩余函数 F ( x ) : = H ( x ) − x F(x):=H(x)−x F(x)=H(x)x。因此,原始函数变成 F ( x ) + x F(x)+x F(x)+x。尽管这两种形式都应该能够渐进地近似所需的函数(如假设的那样),但是学习的容易程度可能不同。

This reformulation is motivated by the counterintuitive phenomena about the degradation problem(Fig.1,left). As we discussed in the introduction, if the added layers can b econstructed asidentity mappings,adeeper model should have training error no greater than its shallower counterpart. The degradation problem suggests that the solvers might have difficulties in approximating identity mappings by multiple nonlinear layers. With the residual learning reformulation, if identity mappings are optimal, the solvers may simply drive the weights of the multiple nonlinear layers toward zero to approach identity mappings.
这种重新表述的动机是关于退化问题的反直觉现象(图1,左图)。正如我们在引言中所讨论的,如果添加的层可以被构造为身份映射,那么一个更深层次的模型的训练误差应该不大于它的浅层模型。退化问题表明,解算器在用多个非线性层逼近同一映射时可能存在困难。在残差学习重构中,如果身份映射是最优的,则解算器可以简单地将多个非线性层的权值趋近于零来逼近同一映射。

Inrealcases,it is unlikely that identity mappings are optimal, but our reformulation may help to precondition the problem. If the optimal function is closer to an identity mapping than to a zero mapping, it should be easier for the solver to find the perturbations with reference to an identity mapping, than to learn the function as a new one. We show byexperiments(Fig.7) that the learn edresidual functionsin general have small responses, suggesting that identity mappings provide reasonable preconditioning.
在实际情况下,身份映射不太可能是最优的,但我们的重新表述可能有助于解决问题。如果最优函数更接近于一个单位映射而不是一个零映射,那么解算器应该比学习一个新函数更容易找到与单位映射有关的扰动。我们通过实验(图7)表明,学习的残差函数通常具有较小的响应,这表明身份映射提供了合理的预处理。

3.2.IdentityMappingbyShortcuts

We adopt residual learning to every few stacked layers. A building block is shown in Fig. 2. Formally, in this paper we consider a building block defined as: y = F ( x , W i ) + x . y = F(x,{W_{i}})+x. y=F(x,Wi)+x.
Here x x x and y y y are the input and output vectors of the layers considered. The function F ( x , W i F(x,{W_{i}} F(x,Wi) represents the residual mapping to be learned. For the example in Fig. 2 that has two layers, F = W 2 σ ( W 1 x ) F = W_{2σ}(W_{1x}) F=W2σ(W1x) in which σ denotes ReLU [29] and the biases are omitted for simplifying notations. The operation F + x F + x F+x is performed by a shortcut connection and element-wise addition. We adopt the second nonlinearity after the addition (i.e., σ(y), see Fig. 2).
我们对每几层进行剩余学习。图2示出了构建块。形式上,在本文中,我们考虑将构建块定义为: y = F ( x , W i ) + x . y = F(x,{W_{i}})+x. y=F(x,Wi)+x.
这里 x x x y y y 是所考虑层的输入和输出向量。函数 F ( x , W i F(x,{W_{i}} F(xWi)表示要学习的剩余映射。对于图2中有两层的示例, F = W 2 σ ( W 1 x ) F=W_{2σ}(W_{1x}) F=W2σ(W1x),其中 σ σ σ表示ReLU和偏差被省略以简化符号。操作 F + x F+x F+x是通过一个快捷连接和元素级加法来执行的。我们采用加法后的第二非线性(即 σ ( y ) σ(y) σ(y),见图2)。

The short cut connection sinEqn.(1)introduce neither extra parameter nor computation complexity. This is not only attractive in practice but also important in our comparisons between plain and residual networks. We can fairly compare plain/residual networks that simultaneously have the same number of parameters, depth, width, and computationalcost(except for the negligible element-wiseaddition).
式中的快捷连接:(1)既不引入额外参数,也不引入计算复杂度。这不仅在实践中很有吸引力,而且在我们比较平面网络和残差网络时也很重要。我们可以比较同时具有相同参数数量、深度、宽度和计算成本的平面/残差网络(除了可忽略的元素加法)。

The dimensions of x x x and F F F must be equal in Eqn.(1). If this is not the case (e.g., when changing the input/output channels), we can perform a linear projection Ws by the shortcut connections to match the dimensions: y = F ( x , W i ) + W s x . y = F(x,{W_{i}})+W_{s}x. y=F(x,Wi)+Wsx.
We can also use asquare matrix Ws inEqn.(1). Butwewill show by experiments that the identity mapping is sufficient for addressing the degradation problem and is economical, and thus Ws is only used when matching dimensions.
x x x F F F的尺寸在等式(1)中必须相等。如果不是这样(例如,在更改输入/输出通道时),我们可以通过快捷连接执行线性投影,以匹配尺寸: y = F ( x , W i ) + W s x . y = F(x,{W_{i}})+W_{s}x. y=F(x,Wi)+Wsx.

我们也可以用一个平方矩阵来表示。但是我们将通过实验证明,身份映射对于解决退化问题是足够的,并且是经济的,因此Ws是只在匹配维度时使用。

The form of the residual function F is flexible. Experiments in this paper involve a function F that has two or three layers (Fig. 5), while more layers are possible. But if F hasonlyasinglelayer,Eqn.(1)issimilartoalinearlayer: y = W 1 x + x y = W_{1}x+x y=W1x+x,forwhichwehavenotobservedadvantages.
剩余函数F的形式是灵活的。本文中的实验涉及一个具有两个或三个层的函数 F F F(图5),而更多的层是可能的。但如果 F F F只有一个单层,则式(1)类似于线性层: y = W 1 x + x y=W_{1}x+x y=W1x+x,我们没有观察到它的优点。

We also note that although the above notations are about fully-connected layers for simplicity, they are applicable to convolutional layers. The function F ( x , W i F(x,{W_{i}} F(x,Wi) can represent multiple convolutional layers. The element-wise addition is performed on two feature maps, channel by channel.
我们还注意到,尽管为了简单起见,上述符号是关于全连接层的,但它们适用于卷积层。函数 F ( x , W i F(x,{W_{i}} F(xWi)可以表示多个卷积层。在两个特征映射上逐个通道地执行元素级加法。

3.3.NetworkArchitectures

We have tested various plain/residual nets, and have observed consistent phenomena. To provide instances for discussion, we describe two models for ImageNet as follows.
我们测试了各种平面网/残差网,并观察到了一致的现象。为了提供讨论的实例,我们描述了ImageNet的两个模型。

Plain Network. Our plain baselines (Fig. 3, middle) are mainlyinspiredbythephilosophyofVGGnets(Fig.3, left). The convolutional layers mostly have 3×3 filters and follow two simple design rules: (i) for the same output feature map size, the layers have the same number of filters; and (ii) if the feature map size is halved, the number of filters is doubled so as to preserve the time complexity per layer. We perform downsampling directly by convolutional layers that have a stride of 2. The network ends with a global average pooling layer and a 1000-way fully-connected layer with softmax. The total number of weighted layers is 34 in Fig. 3 (middle).
普通网络。我们的简单基线(图3,中间)主要受VGG网络的哲学启发(图3,左)。卷积层通常有3×3个滤波器,遵循两个简单的设计规则:(i)对于相同的输出特征映射大小,各层具有相同数量的滤波器;(ii)如果特征映射大小减半,则滤波器数量加倍,以保持每层的时间复杂度。我们直接通过2步的卷积层进行下采样。该网络以一个全局平均池层和一个1000路全连接层和soft max结束。图3(中间)中加权层的总数为34。
在这里插入图片描述

Figure 3. Example network architectures for ImageNet. Left: the VGG-19 model [40] (19.6 billion FLOPs) as a reference. Middle: a plain network with 34 parameter layers (3.6 billion FLOPs).Right: a residual network with 34 parameter layers (3.6 billion FLOPs). The dotted shortcuts increase dimensions. Table 1 show smore details and other variants.
图3。ImageNet的网络体系结构示例。左图:VGG-19模型[40](196亿次失败)作为参考。中间层:一个有34个参数层(36亿次浮点运算)的普通网络。右图:一个有34个参数层(36亿次浮点运算)的剩余网络。虚线快捷方式增加尺寸。表1显示了更多细节和其他变体。

It is worth noticing that our model has fewer filters and lower complexity than VGGnets (Fig.3,left). Our 34 layer base line has 3.6 billion FLOPs(multiply-adds), which is only 18% of VGG-19 (19.6 billion FLOPs)
值得注意的是,我们的模型比VGG网络具有更少的滤波器和更低的复杂性(图3,左图)。我们的34层基线有36亿次失败(乘法相加),仅为VGG-19(196亿次)的18%。

Residual Network. Based on the above plain network, we insert shortcut connections (Fig. 3, right) which turn the network into its counterpart residual version. The identity shortcuts (Eqn.(1)) can be directly used when the input and output are of the same dimensions (solid line shortcuts in Fig.3). When the dimension sincrease(dottedlineshortcuts in Fig. 3), we consider two options: (A) The shortcut still performs identity mapping, with extra zero entries padded for increasing dimensions. This option introduces no extra parameter; (B) The projection shortcut in Eqn.(2) is used to match dimensions (done by 1×1 convolutions). For both options, when the shortcuts go across feature maps of two sizes, they are performed with a stride of 2.
剩余网络。基于上述平面网络,我们插入快捷连接(图3,右图),将网络转换为对应的残差版本。当输入和输出具有相同的尺寸(图3中的实线快捷方式)时,可以直接使用标识快捷方式(Eqn.(1))。当维度增加时(图3中的虚线快捷方式),我们考虑两个选项:(A)快捷方式仍然执行身份映射,并为增加维度填充额外的零条目。此选项不引入额外参数;(B)公式(2)中的投影快捷方式用于匹配尺寸(通过1×1卷积完成)。对于这两个选项,当快捷方式跨越两个尺寸的要素地图时,它们的执行步幅为2。

3.4.Implementation

Our implementation for ImageNet follows the practice in [21, 40]. The image is resized with its shorter side randomly sampled in [256,480] for scale augmentation [40]. A 224×224 crop is randomly sampled from an image or its horizontal flip,withtheper-pixel mean subtracted[21]. The standard coloraugment ationin [21] is used. We adoptbatch normalization (BN) [16] right after each convolution and before activation, following [16]. We initialize the weights as in [12] and train all plain/residual nets from scratch. We use SGD with a mini-batch size of 256. The learning rate starts from 0.1 and is divided by10 when the error plateaus, and the models are trained for up to 60×104 it erations. We use a weight decay of 0.0001 and a momentum of 0.9. We do not use dropout [13], following the practice in [16].
我们对ImageNet的实现遵循了中的实践。在[256,480]中随机对图像的短边进行采样,以进行缩放。从图像或其水平翻转中随机抽取224×224的裁剪,并减去每像素的平均值。使用了[21]中的标准增色。我们在每次卷积后和激活前采用批处理标准化(BN),后面是。我们按照中的方法初始化权重,并从头开始训练所有的普通网/残差网。我们使用SGD,最小批量为256。学习率从0.1开始,当误差趋于平稳时除以10,模型训练到60×104次迭代。我们使用0.0001的重量衰减和0.9的动量。我们不使用辍学,遵循[16]中的做法。

In testing, for comparison studies we adopt the standard 10-crop testing [21]. For best results, we adopt the fullyconvolutional form as in [40, 12], and average the scores at multiple scales (images are resized such that the shorter side is in{224,256,384,480,640}).
在试验中,我们采用标准10作物试验[21]。为了获得最佳结果,我们采用了[40,12]中的完全进化形式,并在多个尺度上对分数进行平均(调整图像大小,使短边位于{224256384480640})。

4.Experiments

4.1.ImageNetClassification

We evaluate our method on the ImageNet 2012 classification data set[35] that consists of 1000 classes. The models are trained on the 1.28 million training images, and evaluated on the 50k validation images. We also obtain a final result on the 100k test images, reported by the test server. We evaluate both top-1 and top-5 error rates.
我们在包含1000个类的ImageNet 2012分类数据集上评估我们的方法。模型在128万张训练图像上进行训练,并在50k个验证图像上进行评估。我们还获得了由测试服务器报告的100k个测试图像的最终结果。我们评估前1名和前5名的错误率。

Plain Networks. We first evaluate 18-layer and 34-layer plain nets. The 34-layer plain net is in Fig. 3 (middle). The 18-layer plain net is of a similar form. See Table 1 for detailed architectures.
普通网络。我们首先评估18层和34层平面网。图3(中)为34层平面网。18层平网形式相似。具体架构见表1。

The results inTable 2 show that the deeper 34-layer plain net has higher validation error than the shallower 18-layer plain net. To reveal the reasons, in Fig. 4 (left) we compare their training/validation errors during the training procedure. We have observed the degradation problem - the 34-layer plain net has higher training error throughout the whole training procedure, even though the solution space of the 18-layer plain network is a subspace of that of the 34-layer one.
表2中的结果表明,较深的34层平面网比浅层的18层平面网具有更高的验证误差。为了揭示原因,在图4(左)中,我们比较了他们在培训过程中的培训/验证错误。我们观察到退化问题
在这里插入图片描述

We argue that this optimization difficulty is unlikely to be caused by vanishing gradients. These plain networks are trained with BN [16], which ensures forward propagated signals to have non-zero variances. We also verify that the backward propagated gradients exhibit healthy norms with BN. So neither forward nor backward signals vanish. In fact, the 34-layer plain net is still able to achieve competitive accuracy (Table 3), suggesting that the solver works to some extent. We conjecture that the deep plain nets may have exponentially low convergence rates,which impac tthe reducing of the training error3. The reason for such optimization difficulties will be studied in the future.
我们认为这种优化困难不太可能是由梯度消失引起的。这些平面网络用BN训练,以确保前向传播的信号具有非零方差。我们还验证了反向传播的梯度与BN具有良好的规范性。所以前进和后退的信号都不会消失。事实上,34层平面网仍然能够达到竞争的精度(表3),这表明求解器在一定程度上起作用。我们推测深平面网可能具有指数级的低收敛速度,这影响了训练误差的降低。这种优化困难的原因将在未来进行研究。

Residual Networks. Next we evaluate 18-layer and 34layer residual nets (ResNets). The baseline architectures are the same as the above plain nets, expect that a shortcut connection is added to each pair of 3×3 filters as in Fig. 3 (right). In the first comparison (Table 2 and Fig. 4 right), we use identity mapping for all shortcuts and zero-padding for increasing dimensions (optionA).So they have no extra parameter compared to the plain counterparts.
剩余网络。接下来我们评估18层和34层残差网(ResNets)。基线架构与上述普通网络相同,只是在每对3×3滤波器上增加了一个快捷连接,如图3(右图)所示。在第一个比较中(表2和图4右图),我们对所有快捷方式使用标识映射,对增加维度使用零填充(选项A)。因此,与普通的对应物相比,它们没有额外的参数。

We have three major observations from Table 2 and Fig. 4. First, the situation is reversed with residual learning–the34-layerResNetisbetterthanthe18-layerResNet (by 2.8%). More importantly, the 34-layer ResNet exhibits considerably lower training error and is generalizable to the validationdata. This indicates that the degradation problem is well addressed in this setting and we manage to obtain accuracy gains from increased depth.
从表2和图4中我们有三个主要的观察结果。首先,通过剩余学习扭转了这种情况——34层ResNet比18层ResNet好(2.8%)。更重要的是,34层ResNet显示出相当低的训练误差,并且可以推广到验证数据中。这表明,在这种情况下,退化问题得到了很好的解决,我们设法从增加深度中获得精度增益。

在这里插入图片描述
Second, compared to its plain counterpart, the 34-layer ResNet reduces the top-1 error by 3.5% (Table 2), resulting from the successfully reduced training error (Fig. 4 right vs. left). This comparison verifies the effectiveness of residual learning on extremely deep systems.
第二,与普通的34层相比ResNet将top-1错误减少了3.5%(表2),这是由于成功地减少了训练误差(图4右与左)。这种比较验证了剩余学习在极深系统上的有效性。

Last, we also note that the 18-layer plain/residual nets are comparably accurate (Table 2), but the 18-layer ResNet converges faster (Fig. 4 right vs. left). When the net is “not overly deep” (18 layers here), the current SGD solver is still able to find good solutions to the plain net. In this case, the ResNet eases the optimization by providing faster convergence at the early stage.
最后,我们还注意到18层平面网/残差网相对准确(表2),但18层ResNet收敛更快(图4右对左)。当网络“不太深”(这里是18层)时,当前的SGD解算器仍然能够找到普通网络的良好解决方案。在这种情况下,ResNet通过在早期阶段提供更快的收敛来简化优化。

Identity vs. Projection Shortcuts. We have shown that parameter-free, identity shortcuts help with training. Next we investigate projection shortcuts (Eqn.(2)). In Table 3 we compare three options: (A) zero-padding shortcuts are used for increasing dimensions, and all shortcuts are parameter-free (the same as Table 2 and Fig. 4 right); (B) projection shortcuts are used for increasing dimensions, and other shortcuts are identity; and © all shortcuts are projections.
身份与投影快捷方式。我们已经证明了这点无参数,身份快捷方式有助于训练。接下来我们研究投影快捷方式(Eqn.(2))。在表3中,我们比较了三个选项:(A)零填充快捷键用于增加维度,并且所有快捷键都是无参数的(与表2和图4右相同);(B)投影快捷键用于增加维度,其他快捷方式是标识;(C)所有快捷方式都是投影。
在这里插入图片描述

Table 3
shows that all three options are considerably better than the plain counterpart. B is slightly better than A. We argue that this is because the zero-padded dimensions in A indeed have no residual learning. C is marginally better than B, and we attribute this to the extra parameters introduced by many (thirteen) projection shortcuts. But the small differences among A/B/C indicate that projection shortcuts are not essential for addressing the degradation problem. So we do not use option C in the rest of this paper, to reduce memory/time complexity and model sizes. Identity shortcuts are particularly important for not increasing the complexity of the bottleneck architectures that are introduced below.
表3显示,这三种方案都比普通方案好得多。我们认为这是因为A中的零填充维数确实没有剩余学习。C略优于B,我们将其归因于许多(十三)个投影快捷方式引入的额外参数。但是A/B/C之间的细微差别表明,投影快捷方式对于解决退化问题不是必需的。因此,在本文的其余部分中,我们不使用选项C来降低内存/时间复杂性和模型大小。身份快捷方式对于不增加下面介绍的瓶颈体系结构的复杂性特别重要。

Deeper Bottleneck Architectures. Next we describe our deeper nets for ImageNet. Because of concerns on the training time that we can afford, we modify the building block as a bottleneck design4. For each residual function F, we use a stack of 3 layers instead of 2 (Fig. 5). The three layers are 1×1, 3×3, and 1×1 convolutions, where the 1×1 layers are responsible for reducing and then increasing (restoring) dimensions, leaving the 3×3 layer a bottleneck with smaller input/output dimensions. Fig. 5 shows an example, where both designs have similar time complexity.
更深层次的瓶颈架构。接下来,我们将描述ImageNet的深层网络。出于对培训时间的考虑,我们将构建块修改为瓶颈设计4。对于每个剩余函数F,我们使用3层而不是2层的堆栈(图5)。这三个层分别是1×1、3×3和1×1卷积,其中1×1层负责减少然后增加(恢复)维数,使3×3层成为输入/输出维数较小的瓶颈。图5示出了两个设计具有相似的时间复杂度的示例。

The parameter-free identity shortcuts are particularly important for the bottleneck architectures. If the identity short-cut in Fig. 5 (right) is replaced with projection, one can show that the time complexity and model size are doubled, as the shortcut is connected to the two high-dimensional ends. So identity shortcuts lead to more efficient models for the bottleneck designs.
无参数标识快捷方式对于瓶颈体系结构尤为重要。如果将图5(右)中的标识快捷方式替换为投影,则可以显示时间复杂性和模型大小加倍,因为快捷方式连接到两个高维端。因此,身份捷径为瓶颈设计提供了更有效的模型。

在这里插入图片描述

50-layer ResNet: We replace each 2-layer block in the 34-layer net with this 3-layer bottleneck block, resulting in a 50-layer ResNet (Table 1). We use option B for increasing dimensions. This model has 3.8 billion FLOPs.
每层更换50层34层网络与此3层瓶颈块,导致50层ResNet(表1)。我们使用选项B来增加维度。这种模式有38亿次失败。

101-layer and 152-layer ResNets: We construct 101-layer and 152-layer ResNets by using more 3-layer blocks(Table 1). Remarkably, although the depth is significantly increased, the 152-layer ResNet (11.3 billion FLOPs) still has lower complexity than VGG-16/19 nets (15.3/19.6 billion FLOPs).
101层和152层resnet:我们使用更多的3层块构建101层和152层resnet(表1)。值得注意的是,尽管深度显著增加,但152层ResNet(113亿个FLOPs)仍然比VGG-16/19网络(153/196亿个FLOPs)的复杂度低。

The 50/101/152-layer ResNets are more accurate than the 34-layer ones by considerable margins (Table 3 and 4). We do not observe the degradation problem and thus enjoy significant accuracy gains from considerably increased depth. The benefits of depth are witnessed for all evaluation metrics (Table 3 and 4).
50/101/152层重网比34层重网精度高出相当大的差距(表3和表4)。我们没有观察到退化问题,因此可以从显著增加的深度中获得显著的精度增益。深度的好处在所有评估指标中都有体现(表3和表4)。

在这里插入图片描述

Comparisons with State-of-the-art Methods. In Table 4 we compare with the previous best single-model results. Our baseline 34-layer ResNets have achieved very competitive accuracy. Our 152-layer ResNet has a single-model top-5 validation error of 4.49%. This single-model result outperforms all previous ensemble results (Table 5). We combine six models of different depth to form an ensemble(only with two 152-layer ones at the time of submitting). This leads to 3.57% top-5 error on the test set (Table 5).This entry won the 1st place in ILSVRC 2015.
与最先进方法的比较。在表4中,我们将与之前的最佳单模型结果进行比较。我们的基准34层resnet已经达到了非常有竞争力的准确性。我们的152层ResNet有一个单一模型TOP5验证误差为4.49%。这个单一模型的结果优于所有先前的集合结果(表5)。我们将六个不同深度的模型组合成一个整体(提交时只有两个152层模型)。这导致测试集的前5名错误率为3.57%(表5)。该参赛作品在2015年ILSVRC中获得第一名。

4.2. CIFAR-10 and Analysis

We conducted more studies on the CIFAR-10 dataset, which consists of 50k training images and 10k testing images in 10 classes. We present experiments trained on the training set and evaluated on the test set. Our focus is on the behaviors of extremely deep networks, but not on pushing the state-of-the-art results, so we intentionally use simple architectures as follows.
我们对CIFAR-10数据集进行了更多的研究,该数据集包括10个班的50k个训练图像和10k个测试图像。我们提出了在训练集上训练的实验,并在测试集上进行了评估。我们的重点是极深层网络的行为,而不是推动最先进的结果,因此我们有意使用以下简单的架构。

The plain/residual architectures follow the form in Fig. 3(middle/right). The network inputs are 32×32 images, with the per-pixel mean subtracted. The first layer is 3×3 convolutions. Then we use a stack of 6n layers with 3×3 convolutions on the feature maps of sizes {32,16,8} respectively, with 2n layers for each feature map size. The numbers of filters are{16,32,64}respectively. The subsampling is performed by convolutions with a stride of 2. The network ends with a global average pooling, a 10-way fully-connected layer, and soft max. There are totally 6n+2 stacked weighted layers. The following table summarizes
the architecture:
普通/剩余架构遵循图3(中/右)中的形式。网络输入为32×32幅图像,减去每像素的平均值。第一层是3×3卷积。然后我们分别在大小为{32,16,8}的特征映射上使用6n层和3×3卷积,每个特征图大小有2n层。过滤器的数量分别为{16,32,64}。子采样是通过步长为2的卷积进行的。该网络以全局平均池、10路完全连接层和softmax结束。共有6n+2个加权层。下表总结了体系结构:
在这里插入图片描述

When shortcut connections are used, they are connected to the pairs of 3×3 layers (totally 3n shortcuts). On this dataset we use identity shortcuts in all cases (i.e., option A), so our residual models have exactly the same depth, width, and number of parameters as the plain counterparts.
当使用快捷方式连接时,它们连接到3×3层(共3个快捷方式)对上。在这个数据集中,我们在所有情况下都使用标识快捷方式(即选项A),因此,我们的残差模型具有与普通模型完全相同的深度、宽度和参数数量。

We use a weight decay of 0.0001 and momentum of 0.9, and adopt the weight initialization in [12] and BN [16] but with no dropout. These models are trained with a mini-batch size of 128 on two GPUs. We start with a learning rate of 0.1, divide it by 10 at 32k and 48k iterations, and terminate training at 64k iterations, which is determined on a 45k/5k train/val split. We follow the simple data augmentation in [24] for training: 4 pixels are padded on each side, and a 3 2×32 crop is randomly sampled from the padded image or its horizontal flip. For testing, we only evaluate the single view of the original 32×32 image.
我们使用0.0001的权重衰减和0.9的动量,并采用了[12]和BN[16]中的权重初始化,但没有丢失。这些模型在两个gpu上训练成128个小批量。我们从0.1的学习率开始,在32k和48k迭代时除以10,在64k迭代时终止训练,这是根据45k/5k训练/val分割确定的。我们按照[24]中简单的数据扩充方法进行训练:每边填充4个像素,从填充图像或其水平翻转中随机抽取一个32×32的裁剪。为了测试,我们只评估原始32×32图像的单个视图。

We compare n = {3,5,7,9}, leading to 20, 32,44, and 56-layer networks. Fig. 6 (left) shows the behaviors of the plain nets. The deep plain nets suffer from increased depth, and exhibit higher training error when going deeper. This phenomenon is similar to that on ImageNet (Fig.4, left) and on MNIST (see [41]), suggesting that such an optimization difficulty is a fundamental problem.
我们比较n={3,5,7,9},得到20、32、44和56层网络。图6(左)显示了平面网的行为。深平原网受深度增加的影响,越深训练误差越大。这种现象类似于ImageNet(图4,左图)和MNIST(见[41]),这表明这种优化困难是一个基本问题。

We further explore n = 1 8 that leads to a 110-layer ResNet. In this case, we find that the initial learning rate of 0.1 is slightly too large to start converging5. So we use 0.01 to warm up the training until the training error is below 80% (about 400 iterations), and then go back to 0.1 and continue training. The rest of the learning schedule is as done previously. This 110-layer network converges well (Fig. 6, middle). It has fewer parameters than other deep and thin networks such as FitNet and Highway (Table 6), yet is among the state-of-the-art results (6.43%,
Table 6).
我们进一步研究n=18,这将导致110层ResNet。在这种情况下,我们发现初始学习率0.1稍大,无法开始收敛5。所以我们用0.01预热训练直到训练误差小于80%(大约400次迭代),然后回到0.1继续训练。学习计划的其余部分如前所述。这个110层网络收敛性很好(图6,中间)。它的参数比其他深而薄的要少FitNet和Highway(表6)等网络是最先进的结果(6.43%,表6)。

在这里插入图片描述

Analysis of Layer Responses. Fig. 7 shows the standard deviations (std) of the layer responses. The responses are the outputs of each 3×3 layer, after BN and before other nonlinearity (ReLU/addition). For ResNets, this analysis reveals the response strength of the residual functions. Fig. 7 shows that ResNets have generally smaller responses than their plain counterparts. These results support our basic motivation (Sec.3.1) that the residual functions might be generally closer to zero than the non-residual functions. We also notice that the deeper ResNet has smaller magnitudes of responses, as evidenced by the comparisons among ResNet-20, 56, and 110 in Fig.7. When there are more layers, an individual layer of ResNets tends to modify the signal less.
层响应分析。图7显示了层响应的标准偏差(std)。响应是每3×3层的输出,在BN之后和其他非线性(ReLU/addition)之前。对于resnet,这个分析揭示了残差函数的响应强度。图7示出resnet通常比它们的普通对应物具有更小的响应。这些结果支持我们的基本动机(第3.1节),即残差函数可能比非残差函数更接近于零。我们还注意到更深的ResNet具有较小的响应量,如图7中ResNet-20、56和110之间的比较所证明的。当有更多层时,单个resnet层倾向于减少信号的修改。

在这里插入图片描述

Exploring Over 1000 layers. We explore an aggressively deep model of over 1000 layers. We set n = 200 that leads to a 1202-layer network, which is trained as described above. Our method shows no optimization difficulty, and this 103-layer network is able to achieve training error<0.1% (Fig. 6, right). Its test error is still fairly good(7.93%, Table 6).
探索超过1000层。我们探索了一个超过1000层的深度模型。我们将n=200设置为1202层网络,该网络按上述方式训练。我们的方法没有优化的困难,而且这个103层网络能够达到训练误差<0.1%(图6,右图)。其测试误差仍相当好(7.93%,表6)。

But there are still open problems on such aggressively deep models. The testing result of this 1202-layer network is worse than that of our 110-layer network, although both have similar training error. We argue that this is because of overfitting. The 1202-layer network may be unnecessarily large (19.4M) for this small dataset. Strong regularization such as maxout [9] or dropout is applied to obtain the best results on this dataset. In this paper, we use no maxout/dropout and just simply impose regularization via deep and thin architetures by design, without distracting from the focus on the difficulties of optimization. But combining with stronger regularization may improve results, which we will study in the future.
但在这种激进的深层次模型上,仍然存在一些开放性的问题。这个1202层网络的测试结果比我们的110层网络差,尽管两者都是有类似的训练错误。我们认为这是因为过度适应。1202层网络对于这个小数据集来说可能是不必要的大(19.4米)。强正则化(如maxout[9]或dropout)用于在该数据集上获得最佳结果。在本文中,我们没有使用maxout/dropout,只是通过设计简单地通过深而薄的体系结构实施正则化,而不分散对优化困难的关注。但结合更强的正则化可以提高结果,我们将在未来进行研究。

4.3. Object Detection on PASCAL and MS COCO

Our method has good generalization performance on other recognition tasks. Table 7 and 8 show the object detection baseline results on PASCAL VOC 2007 and 2012 [5] and COCO [26]. We adopt Faster R-CNN[32] as the detection method. Here we are interested in the improvements of replacing VGG-16 [40] with ResNet-101. The detection implementation (see appendix) of using both models is the same, so the gains can only be attributed to better networks. Most remarkably, on the challenging COCO dataset we obtain a 6.0% increase in COCO’s standard metric (mAP@[.5,.95]), which is a 28% relative improvement. This gain is solely due to the learned representations.
我们的方法在其他识别任务上具有良好的泛化性能。表7和表8显示了PASCAL VOC 2007和2012[5]和COCO[26]的目标检测基线结果。我们采用更快的R-CNN[32]作为检测方法。这里我们对用ResNet-101代替VGG-16[40]的改进感兴趣。使用这两种模型的检测实现(见附录)是相同的,因此增益只能归因于更好的网络。最值得注意的是,在具有挑战性的COCO数据集上,COCO的标准度量值(mAP@[.5,.95])增加了6.0%,相对提高了28%。这种增益完全是由于学习的表现。

在这里插入图片描述

Based on deep residual nets, we won the 1st places in several tracks in ILSVRC & COCO 2015 competitions: ImageNet detection, ImageNet localization, COCO detection, and COCO segmentation. The details are in the appendix.
基于深度残差网,我们在ILSVRC&COCO 2015竞赛中获得了多个赛道的第一名:ImageNet检测、ImageNet定位、COCO检测和COCO分割。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值