在python里实现基于LeNet-5的手写数字识别

时间: 2025-03-29 21:01:45 浏览: 6

要在 Python 中实现基于 LeNet-5 的手写数字识别,通常会借助深度学习框架如 TensorFlow 或 PyTorch 来构建和训练模型。以下是基于 Keras(TensorFlow 高级 API)的一个简单实现:

import numpy as np
from tensorflow.keras.datasets import mnist
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Conv2D, MaxPooling2D, Flatten, Dense

# 加载 MNIST 数据集
(x_train, y_train), (x_test, y_test) = mnist.load_data()

# 归一化像素值至 [0, 1] 范围,并将数据重塑为适合卷积网络的形式
x_train = x_train.reshape(-1, 28, 28, 1).astype('float32') / 255.
x_test = x_test.reshape(-1, 28, 28, 1).astype('float32') / 255.

# 将标签转换成 one-hot 编码形式
y_train = keras.utils.to_categorical(y_train, num_classes=10)
y_test = keras.utils.to_categorical(y_test, num_classes=10)

# 定义 LeNet-5 模型架构
model = Sequential()
model.add(Conv2D(filters=6, kernel_size=(5, 5), strides=(1, 1), activation='tanh', input_shape=(28, 28, 1)))
model.add(MaxPooling2D(pool_size=(2, 2)))

model.add(Conv2D(filters=16, kernel_size=(5, 5), strides=(1, 1), activation='tanh'))
model.add(MaxPooling2D(pool_size=(2, 2)))

model.add(Flatten())
model.add(Dense(units=120, activation='tanh'))
model.add(Dense(units=84, activation='tanh'))
model.add(Dense(units=10, activation='softmax'))

# 编译模型
model.compile(optimizer='adam', loss='categorical_crossentropy', metrics=['accuracy'])

# 训练模型
model.fit(x_train, y_train, batch_size=128, epochs=10, validation_split=0.2)

# 测试模型性能
test_loss, test_acc = model.evaluate(x_test, y_test)
print(f"Test Accuracy: {test_acc}")

此段程序首先加载了标准的 MNIST 数据库用于训练及验证;接着按照原始论文描述搭建了一个简化版的 LeNet-5 结构并通过 Adam 最佳化器来进行参数更新过程。

向AI提问 loading 发送消息图标

相关推荐

大学生入口

最新推荐

recommend-type

手写数字识别:实验报告

实验报告“手写数字识别”主要探讨了在AI领域如何运用不同的神经网络模型来识别手写数字。实验基于AIstudio平台,涵盖了数据预处理、数据加载、多种网络结构的尝试、损失函数的选择以及优化算法的应用,并展示了实验...
recommend-type

Python(TensorFlow框架)实现手写数字识别系统的方法

LeNet-5是Yann LeCun在1998年提出的一种早期的CNN模型,特别适合用于手写数字识别。该模型包含卷积层(C层)、池化层(S层)和全连接层(F层)。在LeNet-5中,卷积层用于提取图像特征,池化层则用于减小数据维度,...
recommend-type

图像处理实战指南:从边缘检测到水印嵌入的关键算法解析

内容概要:本文详细介绍了多种图像处理技术的实际应用和实现方法,涵盖了边缘检测、分形维数计算、霍夫直线检测、伪彩色增强、PCA降维、图像配准以及水印嵌入等多个方面。每种技术不仅提供了具体的Python代码示例,还分享了作者在实践中积累的经验和技巧。例如,边缘检测部分强调了Sobel算子的正确使用方法及其注意事项;分形维数计算部分展示了如何通过盒计数法进行实现;霍夫直线检测部分讨论了参数选择的影响;伪彩色增强部分介绍了基于LUT的颜色映射方法;PCA降维部分讲解了人脸识别的具体步骤;图像配准部分探讨了SIFT算法的应用;水印嵌入部分则深入剖析了DCT域的方法。 适合人群:具有一定编程基础并希望深入了解图像处理技术的开发者和技术爱好者。 使用场景及目标:适用于需要快速掌握图像处理核心技术的研究人员、工程师和学生。目标是帮助读者理解并能够独立实现常见的图像处理任务,如边缘检测、特征提取、图像融合、降维、配准和水印嵌入等。 其他说明:文中提供的代码片段均经过实际验证,可以直接用于实验环境。此外,作者还分享了许多实用的小贴士,如避免常见错误、优化性能等,有助于提高读者的实际操作能力。
recommend-type

生成式AI入门:商业与技术领导者的指南

本书《What Is Generative AI》由Kyle Stratis撰写,旨在为商业和技术领导者提供生成式人工智能(Generative AI)的基础知识。生成式AI是一种能够创造新内容的技术,包括图像、文本和视频,与传统的判别式AI不同,后者主要用于分类和回归任务。书中介绍了生成式AI的历史、发展以及现代架构,如变分自编码器(VAE)、生成对抗网络(GAN)和Transformer模型,并探讨了其在商业和创意领域的应用。作者强调,尽管生成式AI在推动增长、增强创造力和简化运营方面具有巨大潜力,但实施时也面临着伦理、法律和技术挑战。本书旨在为读者提供必要的知识和见解,以便他们能够评估生成式AI的投资回报率,并在日常生活中、商业活动或创意工作中有效利用这项技术。
recommend-type

掌握ASP.NET 2.0编程:PDF格式教程

《Asp.net 2.0高级编程》是一本专注于Microsoft ASP.NET 2.0平台的编程书籍,重点讲解了在.NET Framework 2.0环境下进行高级Web应用开发的技术。本书覆盖了ASP.NET 2.0的基础知识、核心技术以及最佳实践,适合作为高级开发者提升技能的参考读物。 从文件名称列表中我们可以得知,书籍被分割成了若干个章节的PDF文件,具体包括第3章至第1章的内容。虽然缺少了第02至第04章的顺序,但通常情况下,书籍的顺序是按照章节顺序递增的,因此我们假定列表是按照书的结构从前往后顺序排列的,即文件名列表中第3章的内容是本书的最后部分。 ### ASP.NET 2.0核心技术知识点: 1. **Web表单(Web Forms)**: ASP.NET 2.0的一个核心组件是Web表单,它允许开发者使用HTML标记来构建用户界面,并结合服务器端的C#或VB.NET代码来处理用户交互。Web Forms使用事件驱动模型,简化了复杂交互式Web应用的开发。 2. **服务器控件**: ASP.NET 2.0提供了大量的服务器端控件,这些控件在服务器端运行,能够生成适应不同浏览器的HTML和脚本代码。控件分为基础控件、数据控件、验证控件和导航控件等类别。 3. **数据绑定**: 数据绑定是ASP.NET中处理数据集(如DataTable、DataSet)与用户界面之间的同步的关键技术。开发者可以将数据源绑定到服务器控件,如GridView或Repeater,以显示和操作数据。 4. **状态管理**: 在Web应用中状态管理至关重要,ASP.NET 2.0提供了多种状态管理技术,包括View State、Session状态、Application状态和Cookie。这些技术帮助开发者在用户请求之间保持数据状态。 5. **安全机制**: ASP.NET提供了一系列的安全特性来保护Web应用免受恶意访问和数据泄露。这些特性包括表单认证、Windows认证、角色管理、成员资格和配置文件管理等。 6. **缓存策略**: 为了提高Web应用的性能,ASP.NET 2.0引入了缓存机制,允许开发者缓存整个页面或者页面的特定部分,以减少数据库访问次数和加快页面加载速度。 7. **用户控件和主题**: 用户控件和主题是ASP.NET中用于实现代码复用和页面样式的工具。用户控件允许开发者创建可重用的代码片段,而主题则用于定义网站的外观和感觉。 8. **部署与配置**: 在完成Web应用的开发后,需要将其部署到服务器上。ASP.NET 2.0简化了部署和配置过程,允许开发者通过Web.config文件灵活地配置应用的设置。 ### 标签与文件名称解析: - 标签中的“2.0高级编程》(pdf版)”和“《Asp.net”直接表明了本书的内容主题是关于ASP.NET 2.0的高级编程技术,而文件扩展名“pdf”表明了文档的格式。 - 文件名称列表中的“7-302-13906-7ch03.pdf”、“7-302-13906-7ch04.pdf”、“7-302-13906-7ch02.pdf”和“7-302-13906-7ch01.pdf”提供了本书各章内容的分段视图。这些文件名可能代表书籍的国际标准书号(ISBN)和章节编号,其中“7-302-13906”很可能是这本书的ISBN号码。章节编号则是书内结构的标记,读者可以按照编号顺序阅读来获得完整的学习体验。 考虑到以上所有信息,该压缩文件包是《Asp.net 2.0高级编程》电子书籍的分章节PDF格式,适合于已经有一定编程基础且想要深入学习ASP.NET 2.0高级特性的IT专业人士。通过对该书的学习,读者可以掌握ASP.NET 2.0框架的核心概念,学会构建和部署复杂的Web应用,并理解如何优化Web应用性能。
recommend-type

集成电路制造中的互扩散效应分析:理论与实验的融合

# 摘要 互扩散效应是影响集成电路性能的关键因素之一,涉及材料中的物质如何通过扩散过程影响彼此的分布和浓度。本文首先概述了互扩散效应的基本理论,
recommend-type

java string 数组

<think>好的,用户想了解Java中字符串数组的用法或解决相关问题。首先,我需要回忆Java中字符串数组的基本概念,包括声明、初始化和常见操作。根据提供的引用,特别是引用[3],提到了声明数组并指定大小的方式,如String[] strArray = new String[5];。这可能是一个重要的点。 接下来,用户可能需要具体的示例来理解如何操作字符串数组。例如,如何初始化数组,如何遍历元素,或者如何处理数组中的字符串。引用[2]提到了String对象的初始化简写语法,这可能对用户有帮助,尤其是在数组初始化时结合使用。 另外,用户的问题可能涉及常见问题,比如数组越界、空指针异常等。需
recommend-type

人事工资管理系统v0.9版本发布

人事工资管理系统是一个专门用于企业人力资源管理的软件工具,它主要负责处理员工的工资发放、考勤管理、个税计算、社会保险和公积金缴纳等相关业务。下面是对标题和描述中提到的知识点的详细说明: 标题中的"人事工资管理系统 v0.9"指的是一套人事工资管理系统软件的版本号,这里的版本号为v0.9,表明这是一个早期的版本,可能还有后续版本进行功能的完善和错误的修正。在软件工程中,版本号通常用来表示软件的更新迭代次数,其中小数点前的数字代表主版本号,小数点后的数字代表修订版本号,如果有第三个数字则代表补丁更新或内部修订。 描述中重复出现的"007人事工资管理系统"可能是文件名或者软件名称的一部分,具体含义不明。这里可能是一个虚拟的标识,用来代表人事工资管理系统,或是一个用来识别特定人事工资管理系统的代码或名称。 标签中同样出现了"人事工资管理系统"这一关键词。在数据库或文档管理中,标签用于分类或标识信息,这里作为标签,表明文件或软件的主题与人事工资管理相关。 压缩包子文件的文件名称列表中只有一个条目"RenShiGuanLi-v0.9",这是一个文件压缩包的名称,其中包含了人事工资管理系统v0.9版本的全部或部分文件。文件名中的“压缩包子”应该是中文输入法的自动修正错误,正确的应该是“压缩包”。 从上述文件信息来看,可以总结出如下知识点: 1. 人事工资管理系统的作用与功能: - 工资发放:自动计算和发放员工工资。 - 考勤管理:记录员工的上下班时间、迟到、早退、请假等信息。 - 个税计算:根据国家税法规定,计算员工应纳税额。 - 社会保险:管理五险(养老、失业、医疗、工伤、生育保险)缴纳情况。 - 公积金管理:处理住房公积金的缴纳与提取。 2. 版本号的作用: - 表明软件更新的阶段,让使用者了解软件的成熟度和功能的完整性。 - 方便软件开发者追踪错误和添加新功能。 3. 标签的作用: - 方便文件、数据库或其他信息的检索与分类。 - 通常用于标记内容的关键信息,便于快速识别。 4. 压缩包的作用: - 压缩数据以减小文件大小,节省存储空间。 - 方便文件的传输,尤其是在网络带宽受限的情况下。 - 可以将多个文件或文件夹打包为单一文件,便于管理和分发。 综合来看,"人事工资管理系统 v0.9"的相关知识点涵盖了人事工资管理系统的功能和作用,软件版本号的含义,标签的使用以及压缩包文件的基本概念和用途。这些知识点对于理解人事工资管理系统的基础架构和软件更新流程至关重要。
recommend-type

外延工艺改进:提升集成电路制造效率的秘籍

# 摘要 集成电路制造是现代电子工业的基石,而外延工艺作为其核心环节,对于集成电路的性能和质量具有决定性作用。本文综述了集成电路外延工艺的理论基础、实践技术及优化策略,并探讨了制造效率提升的途径。通过对外延层生长机制、技术分类及其质量评估方法的分析,深入讨论了提升外延层均匀性和缩短工艺周期的技术手段。此外,本文还讨论了新兴技术对外延工艺的影响,行业
recommend-type

&&在c语言中的用法

<think>好的,我现在要回答用户关于C语言中“&&”运算符用法的问题。首先,我需要确认用户的问题是否存在拼写错误,因为之前用户曾混淆过“II”和“||”。不过这里用户明确写的是“&&”,看起来像全角符号,但可能实际指的是“&&”。需要先指出这一点,避免误解。 接下来,我需要详细解释“&&”作为逻辑与运算符的用法。首先说明它是逻辑与,用于布尔条件判断,两个条件都为真时结果才为真。然后举一个简单的例子,比如在if语句中使用,例如if (a > 0 && b < 5)。同时,要提到短路求值的特性,即如果第一个条件为假,第二个条件不会执行,这对有副作用的表达式很重要,需要举例说明,比如避免空指针
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部