IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 用Lenet 5处理CIFAR10数据集 -> 正文阅读

[人工智能]用Lenet 5处理CIFAR10数据集

1.Lenet

LeNet-5 这个网络虽然很小,但是它包含了深度学习的基本模块:卷积层,池化层,全连接层。是其他深度学习模型的基础, 这里我们对LeNet-5进行深入分析。同时,通过实例分析,加深对与卷积层和池化层的理解。

在这里插入图片描述
C1层:
类型:卷积层
输入图片:3232
卷积核大小:5
5
卷积核种类:6
输出featuremap大小:28*28

S2层:
类型:池化层
输入:2828
采样大小:2
2
输出featuremap大小:14*14

C3层
类型:卷积层
输入:1414
卷积核大小:5
5
卷积核种类:16
输出featuremap大小:10*10

S4层:
类型:池化层
输入:1010
采样大小:2
2
输出featuremap大小:5*5

C5,F6,OUTPUT层:
类型:全连接层
[b,400]–>[b,120]–>[b,84]–>[b,10]

2.用cifar10进行训练和测试

先写Lenet类,

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

class Lenet5(nn.Module):
    def __init__(self):
        super(Lenet5, self).__init__()
        self.model = nn.Sequential(
            # x:[b,3,32,32]->[b,6,28,28]
            nn.Conv2d(3, 6, kernel_size=(5, 5), stride=1, padding=0),
            # x:[b,6,28,28]->[b,6,14,14]
            nn.AvgPool2d(kernel_size=2, stride=2, padding=0),
            # x:[b,6,14,14]->[b,16,10,10]
            nn.Conv2d(6, 16, kernel_size=5, stride=1, padding=0),
            # x:[b,16,10,10]->[b,16,5,5]
            nn.AvgPool2d(kernel_size=2, stride=2, padding=0),
            # x:[b,16,5,5]->[b,400]
            nn.Flatten(),
            nn.Linear(400, 120),
            nn.ReLU(),
            nn.Linear(120, 84),
            nn.ReLU(),
            nn.Linear(84, 10),
            nn.ReLU(),
        )
        

    def forward(self, x):
        x = self.model(x)
        return x

主函数,训练和测试

import torch
from torchvision import datasets
from torchvision import transforms
from torch.utils.data import DataLoader
from lenet5 import Lenet5
from torch import nn, optim


def main():
    batch_size = 50

    cifar_train = datasets.CIFAR10('cifar', train=True, transform=transforms.Compose([
        transforms.Resize((32, 32)),
        transforms.ToTensor(),
    ]), download=True)
    cifar_train = DataLoader(cifar_train, batch_size=batch_size, shuffle=True)

    cifar_test = datasets.CIFAR10('cifar', train=False, transform=transforms.Compose([
        transforms.Resize((32, 32)),
        transforms.ToTensor(),
    ]), download=True)
    cifar_test = DataLoader(cifar_test, batch_size=batch_size, shuffle=True)
    x, label = iter(cifar_train).next()
    print(x.shape, label)


    device = torch.device('cuda')
    model = Lenet5().to(device)
    criteon = nn.CrossEntropyLoss().to(device)  # 交叉熵
    optimizer = optim.Adam(model.parameters(), lr=1e-3)  # 优化器步长设置为0.001

    for epoch in range(1000):

        model.train()  # 转换为train
        for i, (x, label) in enumerate(cifar_train):
            x, label = x.to(device), label.to(device)
            logits = model(x)
            loss = criteon(logits, label)  
            optimizer.zero_grad()  # 梯度置为零
            loss.backward()  # 计算梯度
            optimizer.step()  # 更新参数
        print(i)
        print(epoch, loss.item())

        model.eval()  # 转换为test
        with torch.no_grad():  # 不对参数作变化,即不让test的数据影响网络
            total_correct = 0
            total_number = 0
            for i,(x,label) in enumerate(cifar_test):
                x, label = x.to(device), label.to(device)
                logits = model(x)
                pred = logits.argmax(dim=1)
                total_correct += torch.eq(pred, label).float().sum().item()
                total_number += x.size(0)
            accuracy = total_correct / total_number  # 计算准确率
            print(i)
            print(epoch, accuracy)

if __name__ == '__main__':
    main()
  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-07-31 16:38:15  更:2021-07-31 16:39:51 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/22 10:29:10-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码