tnblog
首页
视频
资源
登录

Pytorch 卷积神经网络效果

2001人阅读 2023/12/26 14:30 总访问:3475664 评论:0 收藏:0 手机
分类: pytorch

Pytorch 卷积神经网络效果

数据与在线实践


Google Colab
数据链接: https://pan.baidu.com/s/1VkrHDZGukkF900zLncMn5g 密码: 3lom

构建卷积神经网络


卷积网络中的输入和层与传统神经网络有些区别,需重新设计,训练模块基本一致

  1. import torch
  2. import torch.nn as nn
  3. import torch.optim as optim
  4. import torch.nn.functional as F
  5. # datasets 内置数据集
  6. # transforms 做预处理操作
  7. from torchvision import datasets,transforms
  8. import matplotlib.pyplot as plt
  9. import numpy as np
  10. %matplotlib inline

首先读取数据


分别构建训练集和测试集(验证集)
使用DataLoader来迭代取数据。

  1. # 定义超参数
  2. input_size = 28 #图像的总尺寸28*28
  3. num_classes = 10 #标签的种类数
  4. num_epochs = 3 #训练的总循环周期
  5. batch_size = 64 #一个撮(批次)的大小,64张图片
  6. # 训练集
  7. train_dataset = datasets.MNIST(root='./data',
  8. train=True,
  9. transform=transforms.ToTensor(),
  10. download=True)
  11. # 测试集
  12. test_dataset = datasets.MNIST(root='./data',
  13. train=False,
  14. transform=transforms.ToTensor())
  15. # 构建batch数据
  16. train_loader = torch.utils.data.DataLoader(dataset=train_dataset,
  17. batch_size=batch_size,
  18. shuffle=True)
  19. test_loader = torch.utils.data.DataLoader(dataset=test_dataset,
  20. batch_size=batch_size,
  21. shuffle=True)

卷积网络模块构建


一般卷积层,relu层,池化层可以写成一个套餐,接下来我将按照下面的神经网络图来进行构建我们的CNN模型。

注意卷积最后结果还是一个特征图,需要把图转换成向量才能做分类或者回归任务

  1. class CNN(nn.Module):
  2. def __init__(self):
  3. super(CNN, self).__init__()
  4. self.conv1 = nn.Sequential( # 输入大小 (1, 28, 28) Sequential 用于按顺序创建一个神经网络,依次堆叠不同的神经网络层
  5. nn.Conv2d( # 2d卷积
  6. in_channels=1, # 灰度图
  7. out_channels=16, # 要得到几多少个特征图
  8. kernel_size=5, # 卷积核大小
  9. stride=1, # 步长
  10. padding=2, # 如果希望卷积后大小跟原来一样,需要设置padding=(kernel_size-1)/2 if stride=1
  11. ), # 输出的特征图为 (16, 28, 28)
  12. nn.ReLU(), # relu层
  13. nn.MaxPool2d(kernel_size=2), # 进行池化操作(2x2 区域), 输出结果为: (16, 14, 14)
  14. )
  15. self.conv2 = nn.Sequential( # 下一个套餐的输入 (16, 14, 14)
  16. nn.Conv2d(16, 32, 5, 1, 2), # 输出 (32, 14, 14)
  17. nn.ReLU(), # relu层
  18. nn.Conv2d(32, 32, 5, 1, 2),
  19. nn.ReLU(),
  20. nn.MaxPool2d(2), # 输出 (32, 7, 7)
  21. )
  22. self.conv3 = nn.Sequential( # 下一个套餐的输入 (16, 14, 14)
  23. nn.Conv2d(32, 64, 5, 1, 2), # 输出 (32, 14, 14)
  24. nn.ReLU(), # 输出 (64, 7, 7)
  25. )
  26. self.out = nn.Linear(64 * 7 * 7, 10) # 全连接层得到的结果
  27. def forward(self, x):
  28. x = self.conv1(x)
  29. x = self.conv2(x)
  30. x = self.conv3(x)
  31. # 将原本的多维张量 x 重塑为一个二维张量,其第一个维度是批量大小,第二个维度是展平后的特征。
  32. x = x.view(x.size(0), -1) # flatten操作,结果为:(batch_size, 32 * 7 * 7)
  33. output = self.out(x)
  34. return output

评估标准


添加准确率作为评估标准

  1. def accuracy(predictions, labels):
  2. # torch.max 返回输入张量的最大值。这里我们使用它来获取预测概率最高的类别。
  3. # predictions.data 是一个包含了模型输出的张量。
  4. # torch.max 的第一个参数是要操作的张量,第二个参数 1 表示我们想要在每行中找到最大值(即每个样本的预测结果)。
  5. # [1] 表示我们只关心最大值的索引(即预测的类别),而不是最大值本身。
  6. pred = torch.max(predictions.data, 1)[1]
  7. # pred.eq(labels.data.view_as(pred)) 比较预测结果和真实标签。
  8. # labels.data 是一个包含真实标签的张量。
  9. # view_as(pred) 使 labels 的形状与 pred 相同。
  10. # eq 函数比较两个张量,如果相同则返回1,不同则返回0。
  11. # 因此这一行代码计算了正确预测的数量。
  12. rights = pred.eq(labels.data.view_as(pred)).sum()
  13. # 返回正确预测的数量和总的标签数量。
  14. # 这可以用于计算准确率:正确预测的数量 / 总标签数量。
  15. return rights, len(labels)

训练网络模型

  1. # 实例化
  2. net = CNN()
  3. #损失函数
  4. criterion = nn.CrossEntropyLoss()
  5. #优化器
  6. optimizer = optim.Adam(net.parameters(), lr=0.001) #定义优化器,普通的随机梯度下降算法
  7. #开始训练循环
  8. for epoch in range(num_epochs):
  9. #当前epoch的结果保存下来
  10. train_rights = []
  11. for batch_idx, (data, target) in enumerate(train_loader): #针对容器中的每一个批进行循环 batch_idx是下标index
  12. net.train() # 训练模式
  13. output = net(data) # 预测值
  14. loss = criterion(output, target) # 计算损失值
  15. optimizer.zero_grad() # 梯度清理
  16. loss.backward() # 反向传播
  17. optimizer.step() # 更新参数
  18. right = accuracy(output, target) # 计算准确率
  19. train_rights.append(right) # 保存
  20. if batch_idx % 100 == 0:
  21. net.eval() # 测试模式
  22. #测试集的准确率
  23. val_rights = []
  24. for (data, target) in test_loader:
  25. output = net(data)
  26. right = accuracy(output, target)
  27. val_rights.append(right)
  28. #准确率计算
  29. train_r = (sum([tup[0] for tup in train_rights]), sum([tup[1] for tup in train_rights]))
  30. val_r = (sum([tup[0] for tup in val_rights]), sum([tup[1] for tup in val_rights]))
  31. print('当前epoch: {} [{}/{} ({:.0f}%)]\t损失: {:.6f}\t训练集准确率: {:.2f}%\t测试集正确率: {:.2f}%'.format(
  32. epoch, batch_idx * batch_size, len(train_loader.dataset),
  33. 100. * batch_idx / len(train_loader),
  34. loss.data,
  35. 100. * train_r[0].numpy() / train_r[1],
  36. 100. * val_r[0].numpy() / val_r[1]))

总结


在此之后又加了一层卷积发现收敛的效果变慢了。
通过使用3*3的卷积核与5*5的卷积核对比,发现前者的刚开始训练的时候损失下降较高然后快速降低,后者刚开始损失下降比较明显然后缓慢下降。


欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739

评价

Pytorch 初探

Pytorch 初探[TOC] Pytorch简介PyTorch由 Facebook 的 AI 研究团队开发的一个开源的机器学习库,它提供了张量(tensor)计...

Pytorch 自动求导与简单的线性回归

Pytorch 自动求导与简单的线性回归[TOC] 环境安装安装pytorch%pip install torch torchvision torchaudio 自动计算反向...

Pytorch Tensor 常见的形式

Pytorch Tensor 常见的形式[TOC] 值 描述 scalar 0维张量 vector 1维张量 matrix 2维张量 ...

Pytorch 气温预测

Pytorch 气温预测[TOC] 准备数据集下载temps.csv数据集。# 下载包 !wget https://raw.githubusercontent.com/AiDaShi/lea...

Pytorch Mnist分类任务

Pytorch Mnist分类任务[TOC] Mnist分类任务了解目标——网络基本构建与训练方法,常用函数解析——torch.nn.functional...

Pytorch 基于经典网络架构训练图像分类模型

Pytorch 基于经典网络架构训练图像分类模型[TOC] 数据预处理部分:数据增强:torchvision中transforms模块自带功能,比较...

Pytorch 卷积神经网络效果

Pytorch 卷积神经网络效果[TOC] 数据集Dataloader制作如何自定义数据集:1.数据和标签的目录结构先搞定(得知道到哪读数据)...

Pytorch 新闻分类任务(学习笔记)

Pytorch 新闻分类任务(学习笔记)[TOC] 目录结构 models文件夹该文件夹显示搭建的网络结构。里面有TextCNN.py和TextRNN....

Pytorch Flask服务部署图片识别(学习笔记)

Pytorch Flask服务部署图片识别(学习笔记)[TOC] Flask 简介Flask是一个用Python编写的轻量级Web应用框架。它简单易用,...

Pytorch 预测产量(易化学习笔记一)

Pytorch 预测产量(易化学习笔记一)[TOC] 实验目的(二维)通过温度进行产量预测。 实验代码导入数据集import torch im...

Pytorch 曲线拟合(易化学习笔记二)

Pytorch 曲线拟合(易化学习笔记二)[TOC] 感染与天数预测import matplotlib.pyplot as plt import torch import torch....

Pytorch 识别手写数字(易化学习笔记三)

Pytorch 识别手写数字(易化学习笔记三)[TOC] 识别手写数字LeNet-5手写数字识别的非常高效的卷积神经网络。高效原因:1....

Pytorch cifar10识别普适物体(易化学习笔记四)

Pytorch cifar10识别普适物体(易化学习笔记四)[TOC] CIFAR-10简介CIFAR-10(Canadian Institute For Advanced Research...

Pytorch loguru日志收集(易化学习笔记五)

Pytorch loguru日志收集(易化学习笔记五)[TOC] loguru日志简介Loguru 是一个 Python 日志库,旨在简化日志记录的设置和...

Pytorch TensorBoard运用(易化学习笔记六)

Pytorch TensorBoard运用(易化学习笔记六)[TOC] TensorBoard简介TensorBoard是TensorFlow的可视化工具包,旨在帮助研究...
这一世以无限游戏为使命!
排名
2
文章
636
粉丝
44
评论
93
docker中Sware集群与service
尘叶心繁 : 想学呀!我教你呀
一个bug让程序员走上法庭 索赔金额达400亿日元
叼着奶瓶逛酒吧 : 所以说做程序员也要懂点法律知识
.net core 塑形资源
剑轩 : 收藏收藏
映射AutoMapper
剑轩 : 好是好,这个对效率影响大不大哇,效率高不高
ASP.NET Core 服务注册生命周期
剑轩 : http://www.tnblog.net/aojiancc2/article/details/167
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术