深度学习模型在图像识别中的应用:CIFAR-10数据集实践与准确率分析

news2024/11/20 4:45:36

文章目录

  • 前言
  • 导入所需的库
  • 忽略证书验证
  • 下载并加载 CIFAR-10 数据集
  • 数据预处理
  • 构建深度学习模型
  • 编译模型
  • 模型训练
  • 模型评估
  • 进行图片识别
  • 测试图片
  • 运行效果
  • 完整代码
  • 完结

前言

 深度学习

深度学习模型在图像识别领域的应用越来越广泛。通过对图像数据进行学习和训练,这些模型可以自动识别和分类图像,帮助我们解决各种实际问题。其中,CIFAR-10数据集是一个广泛使用的基准数据集,包含了10个不同类别的彩色图像。本文将介绍如何使用深度学习模型构建一个图像识别系统,并以CIFAR-10数据集为例进行实践和分析。文章中会详细解释代码的每一步,并展示模型在测试集上的准确率。此外,还将通过一张图片的识别示例展示模型的实际效果。通过阅读本文,您将了解深度学习模型在图像识别中的应用原理和实践方法,为您在相关领域的研究和应用提供有价值的参考。

导入所需的库

import tensorflow as tf
from tensorflow import keras
import ssl
import urllib.request
import cv2

代码中导入了 TensorFlow 和 Keras 库。TensorFlow 是一个开源的深度学习框架,Keras 是基于 TensorFlow 的高级神经网络 API。ssl 用于处理证书验证,urllib.request 用于下载图片,cv2 用于读取图片。

忽略证书验证

ssl._create_default_https_context = ssl._create_unverified_context

这行代码将忽略证书验证。在使用 urllib.request 下载数据集时,有时会遇到证书验证的问题。通过这行代码可以忽略证书验证,确保数据集能够顺利下载。

下载并加载 CIFAR-10 数据集

(x_train, y_train), (x_test, y_test) = keras.datasets.cifar10.load_data()

这行代码使用 Keras 提供的 cifar10.load_data() 方法从官方网站上下载 CIFAR-10 数据集,并将训练集和测试集分别保存到 (x_train, y_train)(x_test, y_test) 中。该数据集包含了60000张32x32像素的彩色图像,共分为10个类别。

数据预处理

数据预处理

x_train = x_train.astype('float32') / 255.0
x_test = x_test.astype('float32') / 255.0

这段代码将训练集和测试集中的图像数据类型转换为浮点型,并将像素值缩放到 [0, 1] 的范围内。这一步是为了使像素值的数值范围一致,便于神经网络的训练。

构建深度学习模型

构建深度学习模型

model = keras.Sequential([
    keras.layers.Conv2D(32, (3, 3), activation='relu', input_shape=(32, 32, 3)),
    keras.layers.MaxPooling2D((2, 2)),
    keras.layers.Conv2D(64, (3, 3), activation='relu'),
    keras.layers.MaxPooling2D((2, 2)),
    keras.layers.Conv2D(64, (3, 3), activation='relu'),
    keras.layers.Flatten(),
    keras.layers.Dense(64, activation='relu'),
    keras.layers.Dense(10)
])

这段代码使用 Keras 的 Sequential 模型构建一个卷积神经网络(CNN)模型。该模型包含了三个卷积层、两个最大池化层、一个扁平化层和两个全连接层。

具体来说:

  • 第一个卷积层使用32个大小为3x3的滤波器,并使用ReLU激活函数。
  • 第一个最大池化层使用2x2的滤波器。
  • 第二个卷积层使用64个大小为3x3的滤波器,并使用ReLU激活函数。
  • 第二个最大池化层使用2x2的滤波器。
  • 第三个卷积层使用64个大小为3x3的滤波器,并使用ReLU激活函数。
  • 扁平化层将多维张量转换为一维向量。
  • 第一个全连接层包含64个神经元,并使用ReLU激活函数。
  • 输出层包含10个神经元,对应CIFAR-10数据集中的类别。

编译模型

model.compile(optimizer='adam',
              loss=tf.keras.losses.SparseCategoricalCrossentropy(from_logits=True),
              metrics=['accuracy'])

这段代码编译了模型。指定了优化器(使用 Adam 优化器)、损失函数(使用交叉熵损失函数)和评估指标(准确率)。

模型训练

model.fit(x_train, y_train, epochs=10, validation_data=(x_test, y_test))

这段代码使用模型的 fit() 方法来训练模型。传入训练集图像数据和对应标签,指定迭代次数为10,并提供验证集用于验证训练过程中的性能。

模型评估

test_loss, test_acc = model.evaluate(x_test, y_test, verbose=2)
print('测试准确率:', test_acc)

这段代码使用模型的 evaluate() 方法对测试集进行评估,并打印出测试准确率。

进行图片识别

image_url = "模型训练img/2.jpg"
image = cv2.imread(image_url)
image = keras.preprocessing.image.load_img(image_url, target_size=(32, 32))
image = keras.preprocessing.image.img_to_array(image)
image = image.reshape(1, 32, 32, 3)
image = image.astype('float32') / 255.0
predictions = model.predict(image)
class_index = tf.argmax(predictions[0])
class_label = class_index.numpy()
class_labels = ['飞机', '汽车', '鸟', '猫', '鹿', '狗', '青蛙', '马', '船', '卡车']
predicted_label = class_labels[class_label]
print('预测的类别:', predicted_label)

这段代码首先定义了一张图片的URL,然后使用 cv2 库的 imread() 方法读取该图片文件。接着使用 Keras 的图像处理函数 load_img() 加载图片,并将其转换为数组形式。然后对图片进行尺寸调整和归一化处理。最后,使用模型的 predict() 方法对图片进行预测,得到预测结果的概率分布。找到概率分布中概率最大的类别下标,并获取类别标签。最后打印出预测的类别名称。

测试图片

请添加图片描述

运行效果

在这里插入图片描述

完整代码

import tensorflow as tf
from tensorflow import keras
import ssl
import urllib.request
import cv2

# 忽略证书验证
ssl._create_default_https_context = ssl._create_unverified_context

# 下载并加载 CIFAR-10 数据集
(x_train, y_train), (x_test, y_test) = keras.datasets.cifar10.load_data()

# 数据预处理
x_train = x_train.astype('float32') / 255.0
x_test = x_test.astype('float32') / 255.0

# 构建深度学习模型
model = keras.Sequential([
    keras.layers.Conv2D(32, (3, 3), activation='relu', input_shape=(32, 32, 3)),
    keras.layers.MaxPooling2D((2, 2)),
    keras.layers.Conv2D(64, (3, 3), activation='relu'),
    keras.layers.MaxPooling2D((2, 2)),
    keras.layers.Conv2D(64, (3, 3), activation='relu'),
    keras.layers.Flatten(),
    keras.layers.Dense(64, activation='relu'),
    keras.layers.Dense(10)
])

# 编译模型
model.compile(optimizer='adam',
              loss=tf.keras.losses.SparseCategoricalCrossentropy(from_logits=True),
              metrics=['accuracy'])

# 模型训练
model.fit(x_train, y_train, epochs=10, validation_data=(x_test, y_test))

# 模型评估
test_loss, test_acc = model.evaluate(x_test, y_test, verbose=2)
print('测试准确率:', test_acc)

# 进行图片识别
image_url = "模型训练img/2.jpg"

image = cv2.imread(image_url)

image = keras.preprocessing.image.load_img(image_url, target_size=(32, 32))
image = keras.preprocessing.image.img_to_array(image)
image = image.reshape(1, 32, 32, 3)
image = image.astype('float32') / 255.0

predictions = model.predict(image)
class_index = tf.argmax(predictions[0])
class_label = class_index.numpy()

class_labels = ['飞机', '汽车', '鸟', '猫', '鹿', '狗', '青蛙', '马', '船', '卡车']
predicted_label = class_labels[class_label]
print('预测的类别:', predicted_label)

完结

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/691445.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ChatGPT独家汇总:发现最优秀的人工智能对话体验

欢迎来到我们的 ChatGPT 镜像网站汇总博客!在这个令人激动的人工智能时代,ChatGPT 作为一款顶尖的语言模型,已经引起了全球范围内的热议。但是,您是否曾经为了找到最佳的 ChatGPT 使用体验而苦苦搜寻?别担心&#xff0…

(15)第一人称视角视频

文章目录 前言 15.1 推荐的零件 15.2 连接图示 15.3 通过任务计划器最小化OSD设置 15.4 集成式OSD 15.5 用户视频/博客 15.6 与FPV飞行特别相关的安全警告 15.7 政府/地方法规 前言 第一人称视角在飞行时为你提供了真正的飞行员视角,它将视频摄像机和发射器…

梯度下降求函数极小值

梯度下降求函数极小值 Himmelblau 函数表达式 ∫ ( x , y ) ( x 2 y − 11 ) 2 ( x y 2 − 7 ) 2 \int(x,y)(x^{2}y-11)^{2} (xy^{2}-7)^{2} ∫(x,y)(x2y−11)2(xy2−7)2 Himmelblau.py 绘制 import numpy as np import matplotlib.pyplot as plt# from mpl_toolkits.mp…

Redis中的缓存雪崩、击穿、穿透的原因以及解决办法

缓存雪崩、击穿、穿透一旦发生,会导致大量的请求积压到数据库层。如果请求的并发量很大,就会导致数据库宕机或是故障,这就是很严重的生产事故了。 俗话说,知己知彼,百战不殆。了解了问题的成因,我们就能够…

PentestGPT:一款由ChatGPT驱动的强大渗透测试工具

关于PentestGPT PentestGPT是一款由ChatGPT驱动的强大渗透测试工具,该工具旨在实现渗透测试任务执行过程的自动化。该工具基于ChatGPT实现其功能,允许广大研究人员以交互式的方式使用,并指导渗透测试人员进行渗透测试任务的总体进度调控并执行指定操作。 除此之外,Pentes…

[学习笔记]python的web开发全家桶2(ing)

初识网站 默认编写的静态的效果动态:需要用到Web框架的功能。 对于目前的我们来看,什么可以做数据存储:txt文件excel文件专业的软件:数据库管理系统 MySQL/Oracle/SQLServer/DB2/Access... 7 MysQL 7.1 安装MySQL MySQL&…

#10042. 「一本通 2.1 练习 8」收集雪花

题目描述 不同的雪花往往有不同的形状。在北方的同学想将雪花收集起来,作为礼物送给在南方的同学们。一共有 n 个时刻,给出每个时刻下落雪花的形状,用不同的整数表示不同的形状。在收集的过程中,同学们不希望有重复的雪花。你可以…

Tomcat【redis-session共享】

目录 1、创建虚拟主机(01-02)相同【192.168.200.121、192.168.200.122】 2、LB配置文件【192.168.200.120】 3、tomcat节点配置TomcatClusterRedisSessionManager方式实现redis共享(01-02)相同 4、安装redis、配置【192.168.20…

智慧餐饮未来:点赋科技智能饮品机器人带来的变革

随着科技的不断发展,智慧餐饮作为餐饮行业的新兴概念已经不再只是简单的餐厅智能化,而是包括了数字化、智能化和现代化等多个方面。点赋科技智能饮品机器人是智慧餐饮中最具代表性的之一,它的发展将引领智慧餐饮行业的未来方向。 首先&#x…

TIA博途Wincc中制作电机风扇或水泵旋转动画的具体方法示例

TIA博途Wincc中制作电机风扇或水泵旋转动画的具体方法示例 如下图所示,打开TIA博途软件,新建一个项目,添加一个1215 PLC,双击进入设备组态,设置属性—常规—系统和时钟存储器,勾选“启用系统存储器字节”、“启用时钟存储器字节”, 如下图所示,添加一个全局DB块,这里…

【Java】02--变量与数据类型Scanner

文章目录 1.什么是常量,什么是变量2.数据类型2.1什么是数据类型转换 3.为什么要使用Scanner 1.什么是常量,什么是变量 你只需要记住两点: 常量:就是一种不会根据环境而改变的数据,例如:圆周率。 变量&…

网络io模型、同步异步及Sanic和uvloop

网络io模型及基础概念 概念说明 用户空间与内核空间 操作系统的核心是内核,独立于普通的应用程序,可以访问受保护的内存空间,也有访问底层硬件设备的所有权限。为了保证用户进程不能直接操作内核(kernel)&#xff0…

银河麒麟系统安装mysql数据库[mysql-5.7.28-linux-glibc2.12-x86_64]

银河麒麟系统安装mysql数据库 1.1 准备材料 mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz MySQL5.7下载地址 https://cdn.mysql.com/archives/mysql-5.7/mysql-5.7.28-linux-glibc2.12-x86_64.tar.gz 1.1 安装前准备工作 1、检查是否已经安装MySQL [rootlocalhost ~]# rpm …

使用虚拟引擎创建海盗船长角色分解

介绍 你好!我叫 Stapan,我是电影和电影的角色艺术家,我有在动画工作室担任自由艺术家和角色艺术家的经验,现在我正在与 Artem Gansior 领导的 ODEE 团队一起制作一部短片。 参考 对于这个项目,最初的角色概念是由超…

MAYA曲线粒子

不从粒子中心发射 nParticleShape1.massrand(0.5,0.7);

【Linux】Linux服务器硬件条件的查看

【Linux】Linux服务器硬件条件的查看 文章目录 【Linux】Linux服务器硬件条件的查看1. CPU条件查看1.1 查看CPU 个数1.2 查看 CPU 物理核数1.3 查看CPU的运行模式1.4 查看 CPU 的型号 2. GPU 条件查看3. 查看磁盘空间、内存、Linux内核当前的系统版本号3.1 磁盘空间3.2 内存3.3…

电源自动化测试系统一站式软硬件解决方案ATECLOUD-Power

*测试系统:本系统是专门针对各类电源模块测试的一体化智能解决方案,此框架结构可根据客户实际测试需求以及预算进行调整,经济适用。 *测试产品:DC-DC电源模块、AC-DC电源模块、车用电源模块、机载电源模块、军用电源模块、特种电源…

A2B音频传输误码率测量方法

+hezkz17进数字音频系统研究开发交流答疑 如何测量音频传输误码率? 2023/6/27 14:03:58 要测量音频传输误码率,可以采取以下步骤: 选择合适的测试设备和仪器:使用专门用于音频传输测试的设备,例如音频信号发生器、示波器和频谱分析仪等。 设置测试场景:确保测试环境符合…

C语言time(NULL)学习

根据资料&#xff1b;如下一段代码&#xff1b; clock_t a,b; float cputime; atime(NULL);for (intz0;z<10000000;z){ float f0; for (int i 0; i<n; i)f h_idata[i]; }btime(NULL); cputime(float)(b-a); printf("cuptime%fmseconds\n",cputime); 前后2个…

Linux——2Linux基础命令

目录 2.1 Linux的目录结构 2.2 Linux命令入门 ls命令 Home目录和工作目录 2.3 目录切换相关命令 cd 切换工作目录 pwd 查看当前工作目录 2.4 相对路径、绝对路径和特殊路径符 相对路径和绝对路径 特殊路径符 2.5 创建目录命令mkdir 2.6 文件操作命令 touch、cat、…