Pytorch中膨胀卷积的用法详解


Posted in Python onJanuary 07, 2020

卷积和膨胀卷积

在深度学习中,我们会碰到卷积的概念,我们知道卷积简单来理解就是累乘和累加,普通的卷积我们在此不做赘述,大家可以翻看相关书籍很好的理解。

最近在做项目过程中,碰到Pytorch中使用膨胀卷积的情况,想要的输入输出是图像经过四层膨胀卷积后图像的宽高尺寸不发生变化。

开始我的思路是padding='SAME'结合strides=1来实现输入输出尺寸不变,试列好多次还是有问题,报了张量错误的提示,想了好久也没找到解决方法,上网搜了下,有些人的博客说经过膨胀卷积之后图像的尺寸不发生变化,有些人又说发生变化,甚至还给出了公式,按着他们的方法修改后还是有问题,报的错误还是没有变。一时不知道怎样解决,网上关于膨胀卷积输出尺寸的大小相关的知识也很少。

终于......,经过自己的研究,发现了问题所在。好啦!我们先从膨胀卷积的概念开始。

1、膨胀卷积的概念

Dilated Convolutions,翻译为扩张卷积或空洞卷积。扩张卷积与普通的卷积相比,除了卷积核的大小以外,还有一个扩张率(dilation rate)参数,主要用来表示扩张的大小。扩张卷积与普通卷积的相同点在于,卷积核的大小是一样的,在神经网络中即参数数量不变,区别在于扩张卷积具有更大的感受野。感受野是卷积核在图像上看到的大小,例如5x5的卷积核的感受野大小为25。

2、示意图

Pytorch中膨胀卷积的用法详解

a.普通卷积,dilation=1,感受野为3x3=9

b.膨胀卷积,dilation=2,感受野为7x7=49

c.膨胀卷积,dilation=4,感受野为16x16 = 256

3、感受野的概念

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

Pytorch中膨胀卷积的用法详解

重点来啦

卷积核经过膨胀后实际参与运算的卷积大小计算公式:

膨胀后的卷积核尺寸 = 膨胀系数 × (原始卷积核尺寸-1)+ 1

例如对于输入是19 x 19(暂且不考虑图像通道数)大小的图像做膨胀卷积,要使输出的图像大小保持不变,即就是仍然为19 x 19,我们要怎样实现呢?

我们的代码是基于pytorch实现的,它的卷积参数中没有padding='SAME‘的选项,padding的可取值为0,1,2,3等等的值。它的计算方式和tensorflow中的padding='VALID'的计算方式一样。

Output=(W-F+2P)/S+1

我们取strides=1,这里的原始卷积核为3 x 3大小,dilation=6,我们可以计算出膨胀后的卷积核大小为6(3-1)+1=13

带入公式可以求得:

(19-13+2*p)/1+1=19,要使这个式子成立,可以反推出padding=6。

这样一来,就可以使得输入输出的尺寸保持不变。达到了我们想要的效果。

4、膨胀卷积的优点

膨胀卷积在保持参数个数不变的情况下增大了卷积核的感受野

5、应用领域

图像修复,图像分割,语音合成。

以上这篇Pytorch中膨胀卷积的用法详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python创建日历实例
Aug 21 Python
实例讲解Python中函数的调用与定义
Mar 14 Python
Python基础篇之初识Python必看攻略
Jun 23 Python
Python使用正则表达式获取网页中所需要的信息
Jan 29 Python
Python 实现还原已撤回的微信消息
Jun 18 Python
python gensim使用word2vec词向量处理中文语料的方法
Jul 05 Python
用python建立两个Y轴的XY曲线图方法
Jul 08 Python
python 执行终端/控制台命令的例子
Jul 12 Python
Pytorch 中retain_graph的用法详解
Jan 07 Python
关于Pytorch的MLP模块实现方式
Jan 07 Python
Python定时任务框架APScheduler原理及常用代码
Oct 05 Python
python opencv通过4坐标剪裁图片
Jun 05 Python
Python urlopen()和urlretrieve()用法解析
Jan 07 #Python
简单了解Django ORM常用字段类型及参数配置
Jan 07 #Python
解决torch.autograd.backward中的参数问题
Jan 07 #Python
Pytorch 中retain_graph的用法详解
Jan 07 #Python
PyTorch中的Variable变量详解
Jan 07 #Python
python enumerate内置函数用法总结
Jan 07 #Python
pytorch加载自定义网络权重的实现
Jan 07 #Python
You might like
什么是调频(FM)、调幅(AM)、短波(SW)、长波(LW)
2021/03/01 无线电
多php服务器实现多session并发运行
2006/10/09 PHP
使用PHP Socket写的POP3类
2013/10/30 PHP
Zend Framework教程之Loader以及PluginLoader用法详解
2016/03/09 PHP
PHP使用OB缓存实现静态化功能示例
2019/03/23 PHP
js 获取Listbox选择的值的代码
2010/04/15 Javascript
基于jquery的滚动条滚动固定div(附演示下载)
2012/10/29 Javascript
JS中图片缓冲loading技术的实例代码
2013/08/29 Javascript
基于jquery和svg实现超炫酷的动画特效
2014/12/09 Javascript
详解Bootstrap创建表单的三种格式(一)
2016/01/04 Javascript
用canvas 实现个图片三角化(LOW POLY)效果
2016/02/18 Javascript
一个用jquery写的判断div滚动条到底部的方法【推荐】
2016/04/29 Javascript
微信小程序 表单Form实例详解(附源码)
2016/12/22 Javascript
详解Angular的数据显示优化处理
2016/12/26 Javascript
详解jQuery事件
2017/01/13 Javascript
js编写简单的计时器功能
2017/07/15 Javascript
webpack+vue-cli项目中引入外部非模块格式js的方法
2018/09/28 Javascript
在Node.js下运用MQTT协议实现即时通讯及离线推送的方法
2019/01/24 Javascript
JavaScript惰性载入函数实例分析
2019/03/27 Javascript
微信小程序实现手势滑动效果
2019/08/26 Javascript
js实现无刷新监听URL的变化示例代码详解
2020/06/03 Javascript
[55:35]VGJ.S vs Mski Supermajor小组赛C组 BO3 第二场 6.3
2018/06/04 DOTA
python实现telnet客户端的方法
2015/04/15 Python
Django 根据数据模型models创建数据表的实例
2018/05/27 Python
替换python字典中的key值方法
2018/07/06 Python
Python爬取智联招聘数据分析师岗位相关信息的方法
2019/08/13 Python
python操作yaml说明
2020/04/08 Python
解决使用python print打印函数返回值多一个None的问题
2020/04/09 Python
如何基于python实现年会抽奖工具
2020/10/20 Python
使用Python爬取Json数据的示例代码
2020/12/07 Python
时尚设计师手表:The Watch Cabin
2018/10/06 全球购物
网络体系结构及协议的定义
2014/03/13 面试题
优秀学生干部推荐材料
2014/02/03 职场文书
生活小常识广播稿
2014/09/16 职场文书
公安机关起诉意见书
2015/05/20 职场文书
Win11如何启用启动修复 ? Win11执行启动修复的三种方法
2022/04/08 数码科技