美文网首页
《PyTorch深度学习实践》(5)

《PyTorch深度学习实践》(5)

作者: 天涯海角之路 | 来源:发表于2020-06-06 00:12 被阅读0次

主题

卷积神经网络(基础篇)

总结

  1. 相机成像:一个光敏电阻接受一个小的光锥,由光敏电阻阵列接受来自物理世界的光波。

  2. 卷积层的权重是4-D张量,第一个维度是输入数据的通道数

代码

只需要把对模型的定义换掉,其余不变

class Net(torch.nn.Module):
    def __init__(self):
        super(Net, self).__init__()
        self.conv1 = torch.nn.Conv2d(1, 10, kernel_size=5)
        self.conv2 = torch.nn.Conv2d(10, 20,kernel_size=5)
        self.pooling = torch.nn.MaxPool2d(2)
        self.fc = torch.nn.Linear(320, 10)

    def forward(self, x):
        batch_size = x.size(0)
        x = F.relu(self.pooling(self.conv1(x)))
        x = F.relu(self.pooling(self.conv2(x)))
        x = x.view(batch_size, -1)
        x = self.fc(x)
        return x

[1,   300] Loss: 0.627
[1,   600] Loss: 0.195
[1,   900] Loss: 0.146
Accuracy on test set:96.88 %
[2,   300] Loss: 0.115
[2,   600] Loss: 0.103
[2,   900] Loss: 0.090
Accuracy on test set:97.64 %
[3,   300] Loss: 0.080
[3,   600] Loss: 0.074
[3,   900] Loss: 0.074
Accuracy on test set:97.98 %
[4,   300] Loss: 0.059
[4,   600] Loss: 0.064
[4,   900] Loss: 0.063
Accuracy on test set:98.52 %
[5,   300] Loss: 0.056
[5,   600] Loss: 0.050
[5,   900] Loss: 0.056
Accuracy on test set:98.50 %
[6,   300] Loss: 0.049
[6,   600] Loss: 0.051
[6,   900] Loss: 0.046
Accuracy on test set:98.59 %
[7,   300] Loss: 0.044
[7,   600] Loss: 0.043
[7,   900] Loss: 0.045
Accuracy on test set:98.55 %
[8,   300] Loss: 0.038
[8,   600] Loss: 0.040
[8,   900] Loss: 0.046
Accuracy on test set:98.79 %
[9,   300] Loss: 0.038
[9,   600] Loss: 0.036
[9,   900] Loss: 0.037
Accuracy on test set:98.71 %
[10,   300] Loss: 0.032
[10,   600] Loss: 0.034
[10,   900] Loss: 0.040
Accuracy on test set:98.83 %

  1. 定义模型:在def __init__(self)中不考虑batch_size的大小,在def forward中考虑batch_size的大小。

  2. 卷积层:torch.nn.Conv2d(in_channels, out_channels, kernel_size=···):kernel_size传入一个数指的是正方形尺寸,也可以传入一个元组,即矩形算子尺寸。其他参数:padding=1,bias=Fasle/True,stride=2。卷积层不必传入输入的长宽尺寸,因为它是遍历卷积

  3. MaxPooling层:torch.nn.MaxPool2d(kernel_size=2)通道数不变。因为该层没有参数,所以在定义模型时只需实例化一个,它可以被重复使用。

  4. Tensor.view()会返回一个新的Tensor,不会修改原Tensor,可以理解为是一个计算图节点。这个节点在forward阶段建立,它的传入参数需要考虑batch_size,即返回的新Tensor的尺寸的第一个维数是batch_size。在forward(self, x)中,首先写上batch_size = x.size(0)以获取当前训练传入的样本个数,后续用于x.view(batch_size, -1)

用GPU加速

迁移到GPU上分为两步:

  1. 把模型迁移至GPU:把网络的参数与结构信息全部放入GPU,转换成CUDA Tensor
model = Net()
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
model.to(device)
  1. 把数据(训练与测试)迁移至GPU:数据与模型要迁移在同一块GPU上
inputs, target = data
inputs, target = inputs.to(device), target.to(device)

相关文章

网友评论

      本文标题:《PyTorch深度学习实践》(5)

      本文链接:https://www.haomeiwen.com/subject/jluazhtx.html