深度学习|卷积神经网络(CNN)介绍(后篇)


01

回顾


昨天介绍了CNN的卷积操作,能减少权重参数的个数,卷积操作涉及到三个超参数:

  • 深度(Depth)

  • 步长(Stride)

  • 零填充(Zero-padding)

还有一种运算,叫做求内积,关于这部分的总结,请参考:

深度学习|卷积神经网络(CNN)介绍(前篇)

扫描二维码关注公众号,回复: 3876051 查看本文章


下面,阐述CNN剩下的两种操作,ReLU,Pooling。



02

ReLU操作

CNN用的激活函数不是Sigmoid函数,大家都知道Sigmoid函数最大的问题是随着深度学习会出现梯度消失,这样会导致最后的收敛速度变得很慢,经过实践证明,采取另外一个函数,性能会更好些,这就是 ReLU 函数,它长这样:

640?wx_fmt=png&wxfrom=5&wx_lazy=1


可以看出在 x 大于 0 时,它是线性函数,在 x 小于 0 时,它是非线性的函数,因此ReLu综合起来看为非线性函数。 



ReLU函数对CNN的实际意义

可以看出CNN中的卷积操作是线性操作,对应元素相乘,然后再求和,又知道在现实世界中,大部分的数据都是非线性的,所以有必要引入一个非线性的激活函数,下面通过ReLU操作看下对图片的影响:


原图像

0?wx_fmt=png


左图为对原图像卷积后的图像,右图为ReLU后的图像,对于单通道图上取值范围为0-255其中255白色,0是黑色,因为卷积后的结果有可能为负值,所以经过ReLU后,所有的值为非负值,不再出现有问题的负值。

0?wx_fmt=png




03

Pooling层

Pooling层能起到降低上一层输入的特征的维数的作用,但是同时能保持其最重要的信息,Pooling操作分多种:最大池化,平均池化,求和池化等。


以最大池化为例,池化一般在ReLU操作之后,首先定义一个相邻区域,然后求出这个区域的最大值,再选定一个步长,依次遍历完图像,如下图所示:


0?wx_fmt=png


Pooling 操作的实际意义

  • 使得输入的特征维数降低,更易于管理

  • 有了第一条,也会使得权重参数个数变少,更易于收敛。

  • Pooling操作相当于决策树中的剪枝操作,能防止过拟合。

  • 经过池化操作后,CNN可以适应图片小的位移,扭曲,位移

  • 经过吃化操作后,CNN可以帮助我们达成在一定尺度上的不变性,这是非常重要的,因为图像不再受外界环境的干扰。




04

CNN总结

至此已经介绍完了CNN使用的核心技术,如果将卷积操作,ReLU操作,Pooling操作结合起来,我们可以得到如下深度网络,可以看出共进行了2次卷积和池化,完成对输入的图像的特征提取,接下来就是全连接层,所谓的全连接层与之前说的DNN(全连接多层神经网络)是一致的,大家可以参考之前的推送复习多层感知器。


0?wx_fmt=png

经过全连接层,会使用前一层提取的所有主要特征,使用一般的均值方差作为损失函数,在输出层可以使用softmax分类器完成多分类任务。可以看出预测的结果为一只船,这是合理的。


下面总结下CNN的算法:

  1. 初始化所有的过滤核,超参数,权重参数等

  2. 输入训练的图像数据,经过前向传播,包括:卷积操作,ReLU操作,池化操作和全连接层的前向传播,最后在输出层得到属于每个类的概率值。

  3. 计算在输出层的总误差,采用均方误差项:总误差 = ∑  ½ (目标概率 – 输出概率) ²

  4. 用反向传播计算误差项相对于权重参数和偏置项的梯度,以此最小化3中的误差和,等达到某个阈值时,停止训练。

  5. 对所有图像数据重复 2-4 操作。





算法channel会有系统地,认真地推送:机器学习(包含深度学习,强化学习等)的理论,算法,实践,源码实现。期待您的参与!

0?wx_fmt=jpeg



猜你喜欢

转载自blog.csdn.net/xo3ylAF9kGs/article/details/78877199