Pytorch中Conv2d、ConvTranspose2d和MaxPool2d参数计算公式


2023.2.8跟新一下,以前菜鸡,没用过dilation这个属性,简化了公式,但是最近接触到了ASPP模块,空洞卷积模块,其中用到了dilation属性,因此更新一下博客

1 Conv2d参数计算

torch.nn.Conv2d(in_channels, out_channels, kernel_size, stride=1, padding=0, dilation=1, groups=1, bias=True, padding_mode='zeros', device=None, dtype=None)

设置:
stride = S
kernel_size = K
padding = P
dilation = D 表示的是卷积核K*K个点,相邻两个点之间的距离为(dilation-1)
空洞卷积具体动画见:Pytorch中各种卷积动画
在这里插入图片描述

输入尺寸为Win,输出尺寸为Wout
公式:
在这里插入图片描述
如果不是空洞卷积,即dilation默认为1时,则使用下面的公式即可!!
在这里插入图片描述

2 ConvTranspose2d参数计算

torch.nn.ConvTranspose2d(in_channels, out_channels, kernel_size, stride=1, padding=0, output_padding=0, groups=1, bias=True, dilation=1, padding_mode='zeros', device=None, dtype=None)

设置:

  1. in_channels(int) – 输入信号的通道数
  2. out_channels(int) – 卷积产生的通道数
  3. kerner_size(int or tuple) - 卷积核的大小
  4. stride(int or tuple,optional) - 输入特征图元素之间添加stride-1个元素
  5. padding(int or tuple, optional) - 输入的每一条边补充0的层数,高宽都增加2*padding
  6. output_padding(int or tuple, optional) - 输出边补充0的层数,高宽都增加padding
  7. groups(int, optional) – 从输入通道到输出通道的阻塞连接数
  8. bias(bool, optional) - 如果bias=True,添加偏置
  9. dilation(int or tuple, optional) – 卷积核元素之间的间距,这个属性有点东西,先不管,还不会
    10.input为输出的特征图尺寸大小,output为输出的特征图尺寸大小

公式:

在这里插入图片描述
这里含有dilation属性的公式就不给了,一般不会用这个函数进行空洞卷积的,有需要可以去官网看一下,有具体公式,一般上面的公式就够用了!!

这里重在使用吧,具体得推导公式需要结合参数进行演算。

3 MaxPool2d参数计算

首先熟悉它的默认参数设置:
在这里插入图片描述
给出的计算公式:
在这里插入图片描述
简化计算:

因为这里的dilation基本不设置,所以题目默认是1,将以上公式化简一下得:
好像和Conv2d的公式是一样的:
在这里插入图片描述
这里我下午在计算输出尺寸的时候,去找了相关博客,结果果断被带入坑里了,算了半天尺寸不对,最后去官网看了一下,原来因为默认值不知道,导致翻车,裂开,这里给出官网链接,大家官网为准

点我就有超能力

  • 2
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
PyTorch,`nn.Conv2d`是用于定义卷积层的类。它有以下参数: * `in_channels`:输入通道的数量。 * `out_channels`:输出通道的数量。 * `kernel_size`:卷积核的大小。可以是一个整数,表示使用一个正方形卷积核,也可以是一个元组,表示使用一个矩形卷积核。 * `stride`:卷积核的步幅大小。可以是一个整数,表示使用相同的步幅大小,也可以是一个元组,表示使用不同的步幅大小。 * `padding`:输入边界周围要填充的零的数量。 * `dilation`:卷积核元素之间的间隔。 * `groups`:输入和输出的通道被分为的组数。默认值为1,表示没有分组。 * `bias`:是否要添加偏置项。默认值为True。 例如,以下代码定义了一个卷积层,它有3个输入通道,64个输出通道,使用3x3的卷积核,步幅为1,没有填充,没有分组和偏置项: ``` import torch.nn as nn conv = nn.Conv2d(in_channels=3, out_channels=64, kernel_size=3, stride=1, padding=0, groups=1, bias=True) ``` 你也可以使用元组来定义不同的参数,例如: ``` conv = nn.Conv2d(3, 64, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1), dilation=(1, 1), groups=1, bias=True) ``` 这将创建一个具有相同设置的卷积层,但使用了元组来表示`kernel_size`,`stride`和`padding`参数。这些参数的第一个元素表示行方向上的大小,第二个元素表示列方向上的大小。此外,`dilation`参数也可以使用元组来表示不同的行和列间隔大小。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Philo`

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值