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 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> Pytorch搭建LeNet5 -> 正文阅读

[人工智能]Pytorch搭建LeNet5

Pytorch搭建LeNet5

1. LeNet神经网络介绍

LeNet神经网络由深度学习三巨头之一的Yan LeCun提出,他同时也是卷积神经网络 (CNN,Convolutional Neural Networks)之父。LeNet主要用来进行手写字符的识别与分类,并在美国的银行中投入了使用。LeNet的实现确立了CNN的结构,现在神经网络中的许多内容在LeNet的网络结构中都能看到,例如卷积层,Pooling层,ReLU层。虽然LeNet早在20世纪90年代就已经提出了,但由于当时缺乏大规模的训练数据,计算机硬件的性能也较低,因此LeNet神经网络在处理复杂问题时效果并不理想。虽然LeNet网络结构比较简单,但是刚好适合神经网络的入门学习。

2. LeNet神经网络结构
在这里插入图片描述
3. Pytorch搭建LeNet5

import torch.nn as nn
from collections import OrderedDict
import torch


# 利用torch.nn.Sequential和collections.OrderedDict()来构建每一个layer
class C1(nn.Module):
    def __init__(self):
        super(C1, self).__init__()

        self.c1 = nn.Sequential(OrderedDict([    # 1代表输入通道数,6代表输出通道数,5代表卷积核的大小5x5,默认stride=1
            ('c1', nn.Conv2d(1, 6, 5)),     # 6@28×28
            ('relu1', nn.ReLU()),           
            ('s2', nn.MaxPool2d(2, 2))      # 6@14x14,通道数不变,超参数2分别表示池化大小和步长
        ]))

    def forward(self, img):
        output = self.c1(img)               # 输入是1x32x32
        return output


class C3(nn.Module):
    def __init__(self):
        super(C3, self).__init__()

        self.c3 = nn.Sequential(OrderedDict([
            ('c3', nn.Conv2d(6, 16, 5)),    # 16@10×10
            ('relu2', nn.ReLU()),
            ('s4', nn.MaxPool2d(2, 2))      # 16@5×5
        ]))

    def forward(self, img):
        output = self.c3(img)
        return output


class C5(nn.Module):
    def __init__(self):
        super(C5, self).__init__()

        self.c5 = nn.Sequential(OrderedDict([
            ('c5', nn.Conv2d(16, 120, 5)),  # 120@1x1
            ('relu3', nn.ReLU())
        ]))

    def forward(self, img):
        output = self.c5(img)
        return output


class F6(nn.Module):
    def __init__(self):
        super(F6, self).__init__()

        self.f6 = nn.Sequential(OrderedDict([
            ('f4', nn.Linear(120, 84)),
            ('relu4', nn.ReLU())
        ]))

    def forward(self, img):
        output = self.f6(img)
        return output


class F7(nn.Module):
    def __init__(self):
        super(F7, self).__init__()

        self.f7 = nn.Sequential(OrderedDict([
            ('f7', nn.Linear(84, 10)),
            ('sig8', nn.LogSoftmax(dim=-1))
        ]))

    def forward(self, img):
        output = self.f7(img)
        return output


class LeNet5(nn.Module):
    """
    Input - 1x32x32
    Output - 10
    """
    def __init__(self):
        super(LeNet5, self).__init__()

        self.c1 = C1()
        self.c3_1 = C3()
        self.c3_2 = C3()
        self.c5 = C5()
        self.f6 = F6()
        self.f7 = F7()

    def forward(self, img):
        output = self.c1(img)

        x = self.c3_1(output)
        output = self.c3_2(output)

        output += x

        output = self.c5(output)
        output = output.view(img.size(0), -1)       # 将卷积层的输出摊平为120维向量
        output = self.f6(output)                    # 全连接层将120维变为84维
        output = self.f7(output)                    # 全连接层将84维变为10维,用于预测输出的结果
        return output


if __name__ == '__main__':

    model = LeNet5()                        # 网络实例化
    print(model)
    in_put = torch.rand(1, 1, 32, 32)       # 随机构建一张一个通道的32*32的输入图片
    out = model(in_put)
    print(out)                              # 哪一维的数字最大,输入就属于那一类别

LeNet5(
  (c1): C1(
    (c1): Sequential(
      (c1): Conv2d(1, 6, kernel_size=(5, 5), stride=(1, 1))
      (relu1): ReLU()
      (s2): MaxPool2d(kernel_size=2, stride=2, padding=0, dilation=1, ceil_mode=False)
    )
  )
  (c3_1): C3(
    (c3): Sequential(
      (c3): Conv2d(6, 16, kernel_size=(5, 5), stride=(1, 1))
      (relu2): ReLU()
      (s4): MaxPool2d(kernel_size=2, stride=2, padding=0, dilation=1, ceil_mode=False)
    )
  )
  (c3_2): C3(
    (c3): Sequential(
      (c3): Conv2d(6, 16, kernel_size=(5, 5), stride=(1, 1))
      (relu2): ReLU()
      (s4): MaxPool2d(kernel_size=2, stride=2, padding=0, dilation=1, ceil_mode=False)
    )
  )
  (c5): C5(
    (c5): Sequential(
      (c5): Conv2d(16, 120, kernel_size=(5, 5), stride=(1, 1))
      (relu3): ReLU()
    )
  )
  (f6): F6(
    (f6): Sequential(
      (f4): Linear(in_features=120, out_features=84, bias=True)
      (relu4): ReLU()
    )
  )
  (f7): F7(
    (f7): Sequential(
      (f7): Linear(in_features=84, out_features=10, bias=True)
      (sig8): LogSoftmax()
    )
  )
)
tensor([[-2.2676, -2.2554, -2.3434, -2.3523, -2.4532, -2.2200, -2.1823, -2.3595,
         -2.3212, -2.2984]], grad_fn=<LogSoftmaxBackward>)

Process finished with exit code 0

https://www.jianshu.com/p/cd73bc979ba9

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-08-07 12:05:08  更:2021-08-07 12:07: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年11日历 -2024/11/18 6:47:26-

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