训练分类器

记录一下自己学 pytorch,学习的资料为 pytorch 的中文文档,传送门:https://apachecn.gitee.io/pytorch-doc-zh/#/docs/1.4/blitz/cifar10_tutorial

# 当必须处理图像、文本、音频或视频数据时,可以使用 python 标准库将数据加载到 numpy 数组里。然后将这个数组转化成 torch.*Tensor 。
#    对于图片,有 Pillow, OpenCV 等包可以使用
#    对于音频,有 scipy 和 librosa 等把包可以使用
#    对于文本,不管是原声 python 的或者是基于 Cython 的文本,可以使用 NLTK 和 SpaCy

# 特别对于视觉方面,有一个叫做 torchvision 的包,其中包含了针对 Imagenet、 CIFAR10、 MNIST 等常用数据集的数据加载器(data loaders),还有对图像数据转换的操作,即 torchvision.datasets 和 torch.utils.data.DataLoader。
# 在这个教程中,我们将使用 CIFAR10 数据集。在 CIFAR-10 里面的图片数据大小是 3 x 32 x 32
# 训练一个分类器
# 将按顺序做一下步骤:
#    1. 通过 torchvision 加载 CIFAR10 里面的训练和测试数据集,并对数据进行标准化
#    2. 定义卷积神经网络
#    3. 定义损失函数
#    4. 利用训练数据训练网络
#    5. 利用测试数据测试网络
1. 价载并标准化 CIFAR10

import torch
import torchvision
import torchvision.transforms as transforms

# torchvision 数据集加载完后的输出是范围在 [0,1]之间的 PILImage。将其标准化为范围在[-1,1]之间的张量
transform = transforms.Compose(
                          [transforms.ToTensor(),
                          transforms.Normalize((0.5, 0.5, 0.5), (0.5, 0.5, 0.5))])

trainset = trochvision.datasets.CIFAR10(root='./data', train=True, download=True, transform = transform)
trainloader = torch.utils.data.DataLoader(trainset, batch_size = 4, shuffle = True, num_workers=2)

testset = torchvision.datasets.CIFAR10(root='./dada', train=False,download=True,transform=transform)
testloader = torch.utils.data.DataLoader(testset, batch_size = 4, shuffle=False, num_workers=2)

classes = ('plane', 'car', 'bird', 'cat', 'deer', 'dog', 'frog', 'horse', 'ship', 'truck')
#输出为:
Downloading https://www.cs.toronto.edu/~kriz/cifar-10-python.tar.gz to ./data/cifar-10-python.tar.gz
Files already downloaded and verified
2. 定义一个卷积神经网络

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


class Net(nn.Module):
    def __init__(self):
        super(Net, self).__init__()
        self.conv1 = nn.Conv2d(3, 6, 5)
        self.pool = nn.MaxPool2d(2, 2)
        self.conv2 = nn.Conv2d(6, 16, 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 = self.pool(F.relu(self.conv1(x)))
        x = self.pool(F.relu(self.conv2(x)))
        x = x.view(-1, 16 * 5 * 5)
        x = F.relu(self.fc1(x))
        x = F.relu(self.fc2(x))
        x = self.fc3(x)
        return x


net = Net()
3. 定义损失函数和优化器

#使用多分类的交叉熵损失函数和随机梯度下降优化器

import torch.optim as optim

criterion = nn.CrossEntropyLoss()
optimizer = optim.SGD(net.parameters(), ;r=0.001, momentum=0.9)
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容