赞
踩
深度学习中,从LetNet到当前最火的GPT所用的Transformer,经典网络引领一波又一波的技术革命,它们把AI技术不断推向高潮。
用pytorch构建CNN经典网络模型LetNet,还可用数据进行训练模型,得到一个优化的模型。
数据分析
经典算法
LeNet是由Yann Lecun(2018年图灵奖得主,CNN的缔造者)创造的CNN经典网络,是卷积神经网络史上的开篇之作。
LeNet诞生于1990年,在手写体字符识别领域创造性的引入了卷积神经网络的基本操作,意义重大,可以说是现代卷积神经网络的发展起点。
输入图像分辨率:28x28 单通道
结构:
(1)卷积层1:5x5 —>输出4个24×24大小的特征图;
(2)池化层1:平均池化层 2x2;
(3)卷积层2:5x5 —>输出12个8x8大小的特征图;
(4)池化层2:2x2
(5)全连接层 ---->输出
优势:采用CNN自动提取特征。
不足:使用了平均池化,一般而言,不如Max-Pooling提取特征具有分类辨识度。
Pytorch实现
以下便是使用Pytorch实现的经典网络结构LeNet:
class LeNet(nn.Module): def __init__(self, num_classes, grayscale=False): """ num_classes: 分类的数量 grayscale:是否为灰度图 """ super(LeNet5, self).__init__() self.grayscale = grayscale self.num_classes = num_classes if self.grayscale: # 可以适用单通道和三通道的图像 in_channels = 1 else: in_channels = 3 # 卷积神经网络 self.features = nn.Sequential( nn.Conv2d(in_channels, 4, kernel_size=5), nn.ReLU(), nn.MaxPool2d(kernel_size=2), nn.Conv2d(4, 12, kernel_size=5), nn.ReLU(), nn.MaxPool2d(kernel_size=2) # 原始的模型使用的是 平均池化 ) # 分类器 self.classifier = nn.Sequential( nn.Linear(12*4*4, num_classes) # 全连接层 ) def forward(self, x): x = self.features(x) # 输出 12*4*4 特征图 x = torch.flatten(x, 1) # 展平 (1, 12*4*4) logits = self.classifier(x) # 输出 10 probas = F.softmax(logits, dim=1) return logits, probas
LetNet广泛的应用于邮政编码、支票号码识别等任务场景。
后来CNN网络结构不断发展,为深度学习在计算机视觉的蓬勃发展奠定基础。
觉得有用 收藏 收藏 收藏
点个赞 点个赞 点个赞
End
GPT专栏文章:
GPT实战系列-ChatGLM3本地部署CUDA11+1080Ti+显卡24G实战方案
GPT实战系列-LangChain + ChatGLM3构建天气查询助手
GPT实战系列-大模型为我所用之借用ChatGLM3构建查询助手
GPT实战系列-P-Tuning本地化训练ChatGLM2等LLM模型,到底做了什么?(二)
GPT实战系列-P-Tuning本地化训练ChatGLM2等LLM模型,到底做了什么?(一)
GPT实战系列-ChatGLM2部署Ubuntu+Cuda11+显存24G实战方案
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。