pytorch之nn.Conv1d详解

原文链接1:https://blog.csdn.net/liujh845633242/article/details/102668515
原文链接2:https://www.jianshu.com/p/a6da4ad8e8e7

class torch.nn.Conv1d(
		in_channels, 
		out_channels, 
		kernel_size, 
		stride=1, 
		padding=0, 
		dilation=1, 
		groups=1, 
		bias=True)

input = torch.randn(50, 300, 35)
conv1 = nn.Conv1d(in_channels=300, out_channels=100, kernel_size=3)
# batch_size x max_sent_len x embedding_size -> batch_size x embedding_size x max_sent_len
print("input:", input.size()) # 50*300*35
output = conv1(input)
print("output:", output.size()) # 50*100*33	因为35-3+1=33

在这里插入图片描述

在这里插入图片描述
注意卷积中的参数padding_mode:
padding_mode的可选项有4种:‘zero’、‘reflect’、‘replicate’、‘circular’,默认为零填充’zero’

# Input
tensor([[[[ 1.,  2.,  3.,  4.],
          [ 5.,  6.,  7.,  8.],
          [ 9., 10., 11., 12.],
          [13., 14., 15., 16.]]]], requires_grad=True)
# 若padding_mode='circular'	即循环填充
  conv_reflect = torch.nn.Conv2d(1,1,1,1,padding=1,padding_mode='circular',bias=False)
# Output
  tensor([[[[16., 13., 14., 15., 16., 13.],
          [ 4.,  1.,  2.,  3.,  4.,  1.],
          [ 8.,  5.,  6.,  7.,  8.,  5.],
          [12.,  9., 10., 11., 12.,  9.],
          [16., 13., 14., 15., 16., 13.],
          [ 4.,  1.,  2.,  3.,  4.,  1.]]]], grad_fn=<ThnnConv2DBackward>)

输出的结果的来源:
假设将输入矩阵从左到右,从上到下进行无限的重复循环延申,就是如下结果:
在这里插入图片描述
然后选取其中的padding=1的部分即为最终结果。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值