卷积和反卷积核计算公式

卷积和反卷积核计算公式1.卷积输出:out_size=in_size+2×padding−kernel_sizestride+1out\_size=\frac{in\_size+2\timespadding-kernel\_size}{stride}+1out_size=stridein_size+2×padding−kernel_size​+1如果想让输入和输出大小一样,则stride必须为1,并且:padding=kernel_size−12padding=\frac{kernel\_siz

1. 卷积

输出:
o u t _ s i z e = i n _ s i z e + 2 × p a d d i n g − k e r n e l _ s i z e s t r i d e + 1 out\_size = \frac{in\_size+2\times padding – kernel\_size}{stride} + 1 out_size=stridein_size+2×paddingkernel_size+1

如果想让输入和输出大小一样,则stride必须为1,并且:
p a d d i n g = k e r n e l _ s i z e − 1 2 padding = \frac{kernel\_size-1}{2} padding=2kernel_size1
因此kernel应该为奇数。
比较常用的组合为: kernel_size=3, padding=1, stride=1kernel_size=5, padding=2, stride=1

如果想让输出为输入的一半,则: stride=2
p a d d i n g = k e r n e l − 1 2 padding= \frac{kernel-1}{2} padding=2kernel1
常用组合为:stride=2, kernel=3, padding=1。注意如果出现除不尽的情况,则一律向下取整。

对于pooling,计算和conv一样。不过pooling没有padding,因此:
o u t _ s i z e = i n _ s i z e − k e r n e l s t r i d e + 1 out\_size = \frac{in\_size-kernel}{stride}+1 out_size=stridein_sizekernel+1

2. 反卷积

转置卷积的计算公式为:
o u t _ s i z e = s t r i d e × ( i n _ s i z e − 1 ) + k e r n e l out\_size = stride\times (in\_size-1)+kernel out_size=stride×(in_size1)+kernel
转置卷积中的padding作用于卷积正好相反,是将最外层的去掉一圈,所以带有padding的反卷积输出为:

o u t _ s i z e = s t r i d e × ( i n _ s i z e − 1 ) × + k e r n e l − 2 × p a d d i n g out\_size = stride\times (in\_size-1)\times + kernel – 2\times padding out_size=stride×(in_size1)×+kernel2×padding

如果要像conv那样在外围加0的话,pytorch中可以使用output_padding参数。

实现2倍上采样,需要: stride=2, kernel_size=2*padding+2

常用组合为:stride=2, kernel=2, padding=0stride=2, kernel_size=4, padding=1, 这样能实现2倍上采样:
o u t _ s i z e = 2 ⋅ ( i n _ s i z e − 1 ) + 2 − 2 ⋅ 0 = 2 ⋅ i n _ s i z e \begin{aligned} out\_size &= 2\cdot (in\_size-1)+2-2\cdot 0 \\ &= 2\cdot in\_size \end{aligned} out_size=2(in_size1)+220=2in_size

3. 卷积中的dilation

dilation又称为 atrous convolutions,即在卷积核的相邻元素之间增加spacing。dilation_rate由参数d控制,通常添加d-1个空格进入kernel中。d=1时表示普通的卷积操作。

dilated conv可以在不增加卷积核大小的情况下增大感受野,同时不增加额外开销,在多个扩张卷积逐次堆叠的情况下尤其有效。

dilated conv有效卷积核大小为:
k ^ = k + ( k − 1 ) ( d − 1 ) \hat k = k + (k − 1)(d − 1) k^=k+(k1)(d1)
因此dilated conv的输出大小为:

o s i z e = i n s i z e + 2 ⋅ p a d d i n g − k ^ s t r i d e + 1 = i n s i z e + 2 ⋅ p a d d i n g − k − ( k + 1 ) ⋅ ( d − 1 ) s t r i d e + 1 \begin{aligned} o_size =& \frac{in_{size} + 2\cdot padding – \hat k}{stride} + 1 \\ =& \frac{in_{size} + 2\cdot padding – k – (k+1)\cdot (d-1)}{stride} + 1 \end{aligned} osize==strideinsize+2paddingk^+1strideinsize+2paddingk(k+1)(d1)+1

举例如下:
在这里插入图片描述

今天的文章卷积和反卷积核计算公式分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/30639.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注