动手学习pytorch之【CNN】——基础模型代码实现

Convolutional-NN

Simple-CNN

如果想看原理的话,请看我的同专栏下的文章

  • 一个简单的多输入通道运行过程示意图:
    在这里插入图片描述
    基础实现:
import torch
from torch import nn
from d2l import torch as d2l


# 自定义的二维互相关操作
def corr2d(X, K):
    h, w = K.shape
    Y = torch.zeros((X.shape[0] - h + 1, X.shape[1] - w + 1))
    for i in range(Y.shape[0]):
        for j in range(Y.shape[1]):
            Y[i, j] = (X[i:i + h, j:j + w] * K).sum()
    return Y


# 自定义卷积层
class Conv2D(nn.Module):
    def __init__(self, kernel_size):  # kernel_size 是二维的
        super().__init__()
        self.weight = nn.Parameter(torch.rand(kernel_size))
        self.bias = nn.Parameter(torch.zeros(1))  # 广播

    def forward(self, x):
        return corr2d(x, self.weight) + self.bias


# Part A  单通道卷积
X = torch.ones((6, 8))
X[:, 2:6] = 0
K = torch.tensor([[1.0, -1.0]])
Y = corr2d(X, K)  # 目标值

# 二维卷积层一般都使用四维输入和输出格式(批量大小、通道、高度、宽度)
X = X.reshape((1, 1, 6, 8))  # # 其中批量大小和通道数都为1
Y = Y.reshape((1, 1, 6, 7))
lr = 3e-2  # 学习率

# 实现自学习的卷积核(忽略偏置),这里调用nn模块中的类
# 二维卷积,输入和输出通道都是1,相当于P=D=1,U和V通过结合kernel_size计算得到
# padding = P, stride = S, output: (𝑀 − 𝐾 + 2𝑃) /𝑆 + 1
conv2d = nn.Conv2d(1, 1, kernel_size=(1, 2), bias=False)
for i in range<
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值