1、池化层的理解

  pooling池化的作用则体现在降采样:保留显著特征、降低特征维度,增大kernel的感受野。另外一点值得注意:pooling也可以提供一些旋转不变性。

  池化层可对提取到的特征信息进行降维,一方面使特征图变小,简化网络计算复杂度并在一定程度上避免过拟合的出现;一方面进行特征压缩,提取主要特征。 
  最大池采样在计算机视觉中的价值体现在两个方面:(1)、它减小了来自上层隐藏层的计算复杂度;(2)、这些池化单元具有平移不变性,即使图像有小的位移,提取到的特征依然会保持不变。由于增强了对位移的鲁棒性,这样可以忽略目标的倾斜、旋转之类的相对位置的变化,以此提高精度,最大池采样方法是一个高效的降低数据维度的采样方法。 
  需要注意的是:这里的pooling操作是特征图缩小,有可能影响网络的准确度,因此可以通过增加特征图的深度来弥补(这里的深度变为原来的2倍)。

  在CNN网络中卷积池之后会跟上一个池化层,池化层的作用是提取局部均值与最大值,根据计算出来的值不一样就分为均值池化层与最大值池化层,一般常见的多为最大值池化层。池化的时候同样需要提供filter的大小、步长。

  tf.nn.max_pool(value, ksize, strides, padding, name=None)

  参数是四个,和卷积很类似:

  第一个参数value:需要池化的输入,一般池化层接在卷积层后面,所以输入通常是feature map,依然是[batch, height, width, channels]这样的shape

  第二个参数ksize:池化窗口的大小,取一个四维向量,一般是[1, height, width, 1],因为我们不想在batch和channels上做池化,所以这两个维度设为了1

  第三个参数strides:和卷积类似,窗口在每一个维度上滑动的步长,一般也是[1, stride,stride, 1]

  第四个参数padding:和卷积类似,可以取'VALID' 或者'SAME'

  返回一个Tensor,类型不变,shape仍然是[batch, height, width, channels]这种形式

  举例:池化输出特征图计算和卷积计算公式相同,区别是池化是求卷积区域中的max,不涉及卷积计算。

  (1)pooling(kernel size 2×2,padding 0,stride 2)  32*32*16->pooling之后(32-2+0)/2 + 1 =16*16

      pool3 = tf.nn.max_pool(layer3,[1,2,2,1],[1,2,2,1],padding='SAME')    // p = (f-1)/2=(2-1)/2=0,,所以padding='SAME'或“VALID”输出一样

  (2)pooling(kernel size 3×3,padding 0,stride 1)  32*32*16->pooling之后(32-3+0)/1 + 1 = 30*30

      pool3 = tf.nn.max_pool(layer3,[1,3,3,1],[1,1,1,1])    

 2、padding的理解

  之前在讨论卷积神经网络的时候,我们是使用filter来做元素乘法运算来完成卷积运算的。目的是为了完成探测垂直边缘这种特征。但这样做会带来两个问题。

  • 卷积运算后,输出图片尺寸缩小;
  • 越是边缘的像素点,对于输出的影响越小,因为卷积运算在移动的时候到边缘就结束了。中间的像素点有可能会参与多次计算,但是边缘像素点可能只参与一次。所以我们的结果可能会丢失边缘信息。

  那么为了解决这个问题,我们引入padding, 什么是padding呢,就是我们认为的扩充图片, 在图片外围补充一些像素点,把这些像素点初始化为0.

  padding的用途:

  (1)保持边界信息,如果没有加padding的话,输入图片最边缘的像素点信息只会被卷积核操作一次,但是图像中间的像素点会被扫描到很多遍,那么就会在一定程度上降低边界信息的参考程度,但是在加入padding之后,在实际处理过程中就会从新的边界进行操作,就从一定程度上解决了这个问题。

  (2)可以利用padding对输入尺寸有差异图片进行补齐,使得输入图片尺寸一致。

  (3)卷积神经网络的卷积层加入Padding,可以使得卷积层的输入维度和输出维度一致。

  (4)卷积神经网络的池化层加入Padding,一般都是保持边界信息和(1)所述一样。

  padding模式:SAME和VALID

  SAME:是填充,填充大小, p = (f-1)/2;VALID:是不填充,直接计算输出。

最新文章

  1. document.compatMode
  2. LeetCode-Search a 2D Matrix
  3. yourphp 的 ThinkTemplate.class.php与ContentReplaceBehavior.class.php
  4. Understanding transient variables in Java and how they are practically used in HashMap---reference
  5. Postman 基本操作学习
  6. WPF基础
  7. 使用Github Page鼓励自己每日编程
  8. CSS滤镜效果
  9. CF 1119C Ramesses and Corner Inversion
  10. linux云计算面试知识汇总,文件共享--vsftpd秘籍
  11. ubuntu多版本cuda并存与切换【两个博客链接】
  12. Dart- move html element
  13. hackerrank-knapsack
  14. 配置 logrotate 指导
  15. 利用Docker设置Node.js
  16. SharePoint Config database Log file too big – reduce it!
  17. 2017.9.28 web设计简单的购物车应用案例--session的简单应用
  18. python之路-进程
  19. xstream+dom4j比较对象
  20. 基于IAR6或者IAR7建立STM32开发工程(通过实际测试,使用IAR6.30.4)

热门文章

  1. tftp服务配置
  2. 搭建apphouse(docker镜像私服)
  3. Web性能测试工具:http_load安装&使用简介
  4. linux 中vim学习与总结
  5. 五分钟上手Git
  6. LNMP环境搭建(三:PHP)
  7. random随机模块,time时间模块
  8. Zipper (DP)
  9. [转】IIS:Do not nest virtual directories
  10. SE16传输配置表数据