原文链接:http://www.cnblogs.com/objectDetect/p/5947169.html

1 感受野的概念

  在卷积神经网络中,感受野的定义是 卷积神经网络每一层输出的特征图(feature map)上的像素点在原始图像上映射的区域大小。

   

  RCNN论文中有一段描述,Alexnet网络pool5输出的特征图上的像素在输入图像上有很大的感受野(have very large receptive fields (195 × 195 pixels))和步长(strides (32×32 pixels) ), 这两个变量的数值是如何得出的呢?

2 感受野大小的计算

感受野计算时有下面的几个情况需要说明:

  (1)第一层卷积层的输出特征图像素的感受野的大小等于滤波器的大小

  (2)深层卷积层的感受野大小和它之前所有层的滤波器大小和步长有关系

  (3)计算感受野大小时,忽略了图像边缘的影响,即不考虑padding的大小,关于这个疑惑大家可以阅读一下参考文章2的解答进行理解

这里的每一个卷积层还有一个strides的概念,这个strides是之前所有层stride的乘积。

  即: strides(i) = stride(1) * stride(2) * …* stride(i-1)

  关于感受野大小的计算采用 top to down 的方式, 即先计算最深层在前一层上的感受野,然后逐渐传递到第一层,使用的公式可以表示如下:   

   RF = 1 #待计算的feature map上的感受野大小 
  for layer in (top layer To down layer): 
    RF = ((RF -1)* stride) + fsize

stride 表示卷积的步长; fsize表示卷积层滤波器的大小  

用python实现了计算Alexnet zf-5和VGG16网络每层输出feature map的感受野大小,实现代码

#!/usr/bin/env pythonnet_struct = {'alexnet': {'net':[[11,4,0],[3,2,0],[5,1,2],[3,2,0],[3,1,1],[3,1,1],[3,1,1],[3,2,0]],'name':['conv1','pool1','conv2','pool2','conv3','conv4','conv5','pool5']},'vgg16': {'net':[[3,1,1],[3,1,1],[2,2,0],[3,1,1],[3,1,1],[2,2,0],[3,1,1],[3,1,1],[3,1,1],[2,2,0],[3,1,1],[3,1,1],[3,1,1],[2,2,0],[3,1,1],[3,1,1],[3,1,1],[2,2,0]],'name':['conv1_1','conv1_2','pool1','conv2_1','conv2_2','pool2','conv3_1','conv3_2','conv3_3', 'pool3','conv4_1','conv4_2','conv4_3','pool4','conv5_1','conv5_2','conv5_3','pool5']},'zf-5':{'net': [[7,2,3],[3,2,1],[5,2,2],[3,2,1],[3,1,1],[3,1,1],[3,1,1]],'name': ['conv1','pool1','conv2','pool2','conv3','conv4','conv5']}}imsize = 224def outFromIn(isz, net, layernum):totstride = 1insize = iszfor layer in range(layernum):fsize, stride, pad = net[layer]outsize = (insize - fsize + 2*pad) / stride + 1insize = outsizetotstride = totstride * stridereturn outsize, totstridedef inFromOut(net, layernum):RF = 1for layer in reversed(range(layernum)):fsize, stride, pad = net[layer]RF = ((RF -1)* stride) + fsizereturn RFif __name__ == '__main__':print "layer output sizes given image = %dx%d" % (imsize, imsize)for net in net_struct.keys():print '************net structrue name is %s**************'% netfor i in range(len(net_struct[net]['net'])):p = outFromIn(imsize,net_struct[net]['net'], i+1)rf = inFromOut(net_struct[net]['net'], i+1)print "Layer Name = %s, Output size = %3d, Stride = % 3d, RF size = %3d" % (net_struct[net]['name'][i], p[0], p[1], rf)

执行结果:

CNN网络结构理解:感受野计算方法相关推荐

  1. CNN网络结构发展最全整理

    来源:人工智能AI技术 本文约2500字,建议阅读9分钟 本文为你整理CNN网络结构发展史. 作者丨zzq 来源丨https://zhuanlan.zhihu.com/p/68411179 CNN基本 ...

  2. 收藏 | 一文遍览CNN网络结构的发展

    来源:人工智能AI技术本文约2600字,建议阅读8分钟 本文介绍了十五种经典的CNN网络结构. CNN基本部件介绍 1. 局部感受野 在图像中局部像素之间的联系较为紧密,而距离较远的像素联系相对较弱. ...

  3. CNN网络结构发展演变:从LeNet到HRNet(一)

    个人经验总结博客,写的不好的地方还请各路大神指正,不喜勿喷.网络结构图基本都是引用的,如有雷同,实在抱歉,可在下方评论中留言是否删除. 我们知道CNN网络结构一直在更新迭代,卷积可以理解为:" ...

  4. 深度学习-神经网络CNN-感受野大小的计算公式有哪些?可能会遇到哪些坑?如何理解感受野大小的计算公式?

    Reference 下面这个B站视频,属于讲感受野的专栏视频之一,使用的是正向公式,强烈推荐大家观看. 深度理解感受野(二):抓住卷积神经网络的内在特性,学习感受野的计算少不了 下面这篇CSDN文章, ...

  5. CNN中的感受野和有效感受野会对模型产生怎样的影响?

    2019-10-06 20:01:44 作者:Noam ( 八云 ) R. 编译:ronghuaiyang 导读 在卷积神经网络中,感受野是一个非常重要的概念,今天,我们具体来看一下感受野的相关概念以 ...

  6. 如何理解CNN中的感受野(receptive-field)以及如何计算感受野?

    本文转载自博客园用户@shine-lee的彻底搞懂感受野的含义与计算. 1. 感受野(Receptive-Field, RF)是什么? The receptive field is defined a ...

  7. CNN网络结构进化概述

    网络工程问题是深度学习中比较基础的问题,网络工程的难点在于,缺乏对深度神经网络的理论理解(即常说的黑盒模型),无法根据理论来设计网络结构,实际中更多的是不断的尝试,根据实验反馈出来的结果确定某一结构是 ...

  8. CNN网络结构的发展:从LeNet到EfficientNet

    关注上方"深度学习技术前沿",选择"星标公众号", 资源干货,第一时间送达! 作者:zzq https://zhuanlan.zhihu.com/p/68411 ...

  9. CS231n笔记-CNN网络结构

    所有图片来自PPT官网Index of /slides/2022 代码:Batch Normalization和Dropout_iwill323的博客-CSDN博客 目录 全连接层存在的问题 卷积层 ...

最新文章

  1. Windows 11 再惹“众怒”!网友:微软就是逼我去买新电脑!
  2. R语言观察日志(part16)--Google‘s R Style Guide
  3. mybatis mysql merge_使用Mybatis和druid连接池报错 merge sql error, dbType mysql, sql
  4. android 嵌套分组拖动_Android NestedScrolling嵌套滑动机制
  5. 具体数学-第7课(取整基础)
  6. iTextSharp 添加图片
  7. kjb文件 解析_十四期全国BIM一级考试真题及解析
  8. 奥克兰理工大学计算机学院,9月17日学术报告(新西兰奥克兰理工大学 Prof. Re
  9. CSS3各个模块详解
  10. 桌面文件删除了怎么恢复
  11. Java Game Resource
  12. 无损音频压缩——APE和FLAC比较
  13. 如何修改电脑密码(在不知道密码的前提下)
  14. 搭建企业内外网可快速稳定访问的共享文件服务器方案
  15. #### 联合索引存储结构 ####
  16. php根据来路,小西的博客
  17. java递归怎么写_Java 基本的递归写法
  18. 学习委员(班长、团支书)查作业软件,查人+重命名
  19. 重构os.nb.payload教程
  20. MySQL创建订单表

热门文章

  1. 注册表删除卸载列表中的软件
  2. 【小程序动画合集】10种小程序动画效果实现方法,文章太长建议收藏!
  3. python脚本文件的扩展命是什么_一些文件的扩展名
  4. 死并不可怕,可怕的是华丽地去死
  5. Modeling Personalized Item Frequency Information for Next-basket Recommendation SIGIR2020
  6. 机器人教育发展_机器人教育为什么火?本文带您了解未来机器人教育的发展趋势...
  7. Eclipse条件断点的使用
  8. wordpress 网站模板-免费wordpress 网站模板以及插件中心
  9. 【python】argv的用法
  10. FFmpeg 音频转换