pytorch使用-Lenet实现


一、Lenet实现网络图

在这里插入图片描述

二、创建网络

import torch.nn as nn
import torch.nn.functional as F


# TODO: 构建神经网络
class LeNet(nn.Module):

    def __init__(self):
        super(LeNet, self).__init__()

        self.conv1 = nn.Conv2d(1, 6, (5, 5))
        self.conv2 = nn.Conv2d(6, 16, (5, 5))

        self.fc1 = nn.Linear(16*5*5, 120)
        self.fc2 = nn.Linear(120, 84)
        self.fc3 = nn.Linear(84, 10)

    def forward(self, x):
        # 卷积 -> 激活 ->池化
        x = F.max_pool2d(F.relu(self.conv1(x)), (2, 2))
        x = F.max_pool2d(F.relu(self.conv1(x)), 2)

        x = x.view(x.size()[0], -1)
        x = F.relu(self.fc1(x))
        x = F.relu(self.fc2(x))
        x = self.fc3(x)

        return x


net = LeNet()
print(net)

在这里插入图片描述

网络的可学习参数通过 net.parameters() 返回,net.named_parameters 可同时返回可学习的参数及名称。

net = LeNet()
print(len(list(net.parameters())))

for name, para in net.named_parameters():
    print(name, ":", para.size())

在这里插入图片描述

# 输出测试
input = torch.randn(1, 1, 32, 32)
out = net(input)
print(out)

# 梯度归零 和 反向传播
net.zero_grad()
out.backward(torch.ones_like(out))

在这里插入图片描述

三、定义损失函数

nn实现了神经网络中大多数的损失函数,例如nn.MSELoss用来计算均方误差,nn.CrossEntropyLoss用来计算交叉滴损失。

# 输出测试
input = torch.randn(1, 1, 32, 32)
out = net(input)

# 定义损失函数
criterion = nn.MSELoss()

# 随机生成标签
target = torch.randn(10)
target = target.view(1, -1)

loss = criterion(out, target)

print(loss)
loss.backward()

# 反向传播
net.zero_grad()
loss.backward()

四、定义优化器

更新网络参数,选择优化算法 SGD

# 传统SGD实现
learning_rate = 0.01
for f in net.parameters():
    f.data.sub_(f.grad.data*learning_rate)

# pytorch
import torch.optim as optim

# 初始化优化器
optimizer = optim.SGD(net.parameters(), lr=0.01)

# 梯度清零
optimizer.zero_grad()
output = net(input)

# 反向传播
loss = criterion(out, target)
loss.backward()
# 参数更新
optimizer.step()

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

大虾飞哥哥

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

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

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

打赏作者

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

抵扣说明:

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

余额充值