【深度学习】卷积神经网络(CNN)基础知识整理

0写在前面

这两天陆续看了一些关于卷积神经网络的视频和博文,把我觉得比较有用的知识和内容梳理一下,理顺逻辑,自己也可加深理解,写在这里,日后想看,随手就能翻来,永不会丢失。

1卷积神经网络

既然叫卷积神经网络,这里面首先是卷积,然后是神经网,是2者的一个结合,卷积这个概念实际上来自于信号处理领域,一般是对2个信号进行卷积运算,见下图:

42b60f91360227932fc15130a0770e8a.png

db6abf4c6e497f7a0a0b516df1a447a3.png

神经网络,这是机器学习的元老,是对人脑神经元工作机制的模拟,每个神经元是一个计算单元,输入的数据与权重进行相乘、求和,再加上偏置,得到的数据再经过激活函数,将结果进行输出,见下图,多个神经元相互连接组成神经网络,具体就不展开说了。

ba8c2a5c32da861ab9afd7e6aabc846a.png

3d21b3f7bfc625be2dbffa5f3638274f.png

卷积神经网络在图像分类和识别领域的应用非常多,最早用于手写数字的分类识别,后来逐渐发展起来。

2图片格式

那就从手写体图像识别说起吧,一副图片如果是单色的,那么可以看成是一个二维的数字矩阵,每个像素点的颜色都可以用灰度值来表示;那如果图像是彩色的,可以将图像看成是RGB三个单色图片叠加的组合。

82525a0e99804656bb08cf6afbead256.pnga22085a84a55be1d68287a085f73e962.png

每一张图片的每一个像素点,其实都是一个数值,整体可看成一个三维矩阵。

3图片卷积运算

那么对一个彩色图像做卷积,到底做了什么呢?下面这张动图,很好地展示了图像卷积计算的过程,原始图像有RGB三个通道channel1-3,对应有3个卷积核Kernel1-3,每一个通道的图片与对应的卷积核做乘加运算,每个通道得到的数值再相加,加上总体的偏置Bias得到特征图(feature map)里面的一个值。

85bd064cd500ebac75a694482974adda.gif

下面这个图是一个立体的展示。

9a6345526480377f4b920424b5f874b6.jpeg

4 kernel与feature map

这里面第一个问题,就是卷积核为什么是3*3大小的,实际上这个尺寸也是经过学者们不断研究总结出来的,目前认为3*3的感受野足够用,而且运算量也会相对低,还有1*1的卷积核在使用,其它的基本不用了。

第二个问题,卷积核里面的参数是怎么来的,其实这里面的参数机器学习要实现的,当我们把所有的核参数都调整好,那这个模型也就确定了。也有一些先验的卷积核,如下面的核,进行卷积之后,可以实现锐化和边缘提取的效果。

b665f17fa181d84f3dbe973816824fc0.png

13a4d110b5c7b76539ab0cf06a2a5988.png

e40c1669bdc062bf5fb2419d0322f155.png


916d8538f1ef5a8930d24132ed7b5206.png

c9899ab3f0a752a0e1a7c9f73b859a88.png

那我们对一幅图片进行卷积之后,就会形成一个Feature map,它会提取一些特征,用不同的核进行卷积就会输出多个Feature map,

卷积核/Kernels,(convolution kernel)也叫过滤器、滤波器。

特征图/Feature map,当图像像素值经过过滤器后得到的就是特征图。

下面2张图就很直观地展示了kernel和feature map的实际样子。

9b1b692212b09fc425f4d7eabbc380ca.png

3059e700a0981cc6102f36ccd9bb645a.png

卷积神经网络处理过程中,随着模型运算的深入,图像的尺寸(h*w)会越来越小,但是提取的特征会越来越多。

aded24499bfb2b1d03e5ce6b41453dd6.png

5 padding/边缘填充

这里面由于边界的问题,每一次卷积之后,图像不可避免地会被压缩一点,这就涉及到一个概念padding,如果设置padding的值为“same”,则会在原图像周围补充1圈像素点,一般补0,这样后面的图像尺寸都会与原图像相同。默认参数是“valid”,翻译过来是有效的意思,这里的有效指的是与卷积核做运算的图片像素都是有效的,实际上就是没有外圈的补0。

unvalid

b088b74937d429df0aaaf31dcd2b06a5.png

valid

43711aa108f378cdb2909b0baa016048.png

下图展示的就是带padding的卷积效果,这个图的问题是用的是4*4的卷积核,实际中没有用4*4卷积核的。

用3*3的卷积核,可保持图像卷积后尺寸不变。

2671b12e17ab7021fb2520fa115cdf75.gif

图片引自:https://github.com/vdumoulin/conv_arithmetic

6 Stride/步长

上图是步长为1的情况,如果步长为 2,就是相当每隔两行或者两列进行卷积,实际上起到了降维的作用,就是卷积后的feature map尺寸会变小。

3f59a72686da2d086522febf2e265e81.gif

图片引自:https://github.com/vdumoulin/conv_arithmetic

7 pooling/池化 

池化主要作用是把数据降维,也叫下采样,可以有效的避免过拟合。主要有两种池化方式,Max pooling/ avg pooling,通常情况下,池化区域是2*2大小,池化之后,4*4的图片,会变成2*2大小。

46a37c9c06b8e7caae0a6ba465fda30d.png

8 shape

在tensorflow和pytorch中,shape的结构有所区别

tensorflow输入shape为(batch_size,  height, weight, in_channels)/(样本数、图像高度、图像宽度, 图像通道数)

pytorch输入shape为(batch_size, in_channels, height, weight)

db97fea8d38492c5c7b6c2b3fe6eef6e.png

上图中,

输入图片的shape: [inChannels, height,weight] /[3,8,8];

卷积核的shape: [outChannels, inChannels, height,weight]/[5,3,3,3];

输出图片的shape: [outChannels,   outHeight,  outweight ]/[5,6,6];

卷积核的输入通道数(in depth)由输入矩阵的通道数(inChannels)所决定。比如:一个RGB格式的图片,其输入通道数为3。

输出矩阵的通道数(out depth)由卷积核的输出通道数所决定,比如下面这个动画当中,卷积核有8个,那么输出outChannels则为8。

2798243825bd11a4abcffb584d7c1c16.gif

图片 引自:https://animatedai.github.io/

9 epoch、batch、Batch Size、step

epoch:表示将训练数据集中的所有样本都过一遍(且仅过一遍)的训练过程。在一个epoch中,训练算法会按照设定的顺序将所有样本输入模型进行前向传播、计算损失、反向传播和参数更新。一个epoch通常包含多个step。

batch:一般翻译为“批次”,表示一次性输入模型的一组样本。在神经网络的训练过程中,训练数据往往是很多的,比如几万条甚至几十万条——如果我们一次性将这上万条的数据全部放入模型,对计算机性能、神经网络模型学习能力等的要求太高了;那么就可以将训练数据划分为多个batch,并随后分批将每个batch的样本一起输入到模型中进行前向传播、损失计算、反向传播和参数更新。但要注意,一般batch这个词用的不多,多数情况大家都是只关注batch size的。

Batch Size(批大小): 表示在单次训练中传递给模型的图像数量,我们在神经网络训练过程中,往往需要将训练数据划分为多个batch;而具体每一个batch有多少个样本,那么就是batch size指定的了。

step:一般翻译为“步骤”,表示在一个epoch中模型进行一次参数更新的操作。通俗地说,在神经网络训练过程中,每次完成对一个batch数据的训练,就是完成了一个step。

10 神经网络

实际上,上面的卷积处理过程,都是在对图片进行特征提取,而最终要进行分类或预测就需要借助神经网络了,所以一般在卷积处理之后需要对数据进行压平(flatten)操作,使其变为1维的数据,便于送入神经网络的输入层。

神经网络模型里面(见下图),全连接层/Dense层是深度学习中常用的一种神经网络层,也称为密集连接层或多层感知机层。它既能当输入层(input layer),又能当输出层(output layer),还能当中间层(Hidden layer)。

c91db8903c43c9e36ea2c3113da5d851.png

推荐一个绘制神经网络图的工具:NN-SVG。

11 激活函数

在神经网络中,激活函数用于引入非线性,使网络能够学习复杂的映射关系。如果不用激活函数,每一层输出都是上层输入的线性函数,无论神经网络有多少层,输出都是输入的线性组合。以下是一些常用的激活函数。常用的有:

45d74f33555ee566a5157985056dd955.png


6fe8bb49a540684cbc273d0796eb6e45.png

81c58289bd111bd8ca0cb29adba1bcad.png

2b6ca222acc4a4f2b325026a6d0b0ed9.png

e9689f75eeadb26def65a5e6d4a81cde.png

1dcf35e13f7252462906d8cbdb141784.png

来源:电子e学堂

 
 

af6f0c06de09c8afa910a09d03b3b34a.jpeg

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
往期精彩回顾




适合初学者入门人工智能的路线及资料下载(图文+视频)机器学习入门系列下载机器学习及深度学习笔记等资料打印《统计学习方法》的代码复现专辑
  • 交流群

欢迎加入机器学习爱好者微信群一起和同行交流,目前有机器学习交流群、博士群、博士申报交流、CV、NLP等微信群,请扫描下面的微信号加群,备注:”昵称-学校/公司-研究方向“,例如:”张小明-浙大-CV“。请按照格式备注,否则不予通过。添加成功后会根据研究方向邀请进入相关微信群。请勿在群内发送广告,否则会请出群,谢谢理解~(也可以加入机器学习交流qq群772479961)

6eb4f6a884afb373039bc980021927f0.png

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值