基于CNN的10种物体识别项目

server/2024/9/24 17:34:16/

一:数据导入和处理

1.导入相关包:

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
import tensorflow as tf

2.下载数据

(x_train_all, y_train_all), (x_test, y_test) = tf.keras.datasets.cifar10.load_data()# x_valid:测试的图片集 x_train:训练的图片集。y_valid:测试的目标集,y_train:训练的目标集
x_valid, x_train = x_train_all[:5000], x_train_all[5000:]
y_valid, y_train = y_train_all[:5000], y_train_all[5000:]“”“
x_valid.shape:(5000,32,32,3)
x_text.shape:(45000, 32, 32, 3)
y_test.shape: (10000,1)
”“”

3.数据归一化

from sklearn.preprocessing import StandardScaler# 这里使用StandardScaler标准差标准化
scaler = StandardScaler()
# 先将数据转换为numpy中的float32类型后再改变形状
x_train_scaled = scaler.fit_transform(x_train.astype(np.float32).reshape(-1, 1)).reshape(-1, 32, 32, 3)
x_valid_scaled = scaler.transform(x_valid.astype(np.float32).reshape(-1, 1)).reshape(-1, 32, 32, 3)
x_test_scaled = scaler.transform(x_test.astype(np.float32).reshape(-1, 1)).reshape(-1, 32, 32, 3)

二:定义卷积神经网络

# 定义卷积神经网络.
model = tf.keras.models.Sequential()
# 2次卷积, 一次池化, 总共3层. 
# 第一层
model.add(tf.keras.layers.Conv2D(filters=32, kernel_size=3, padding='same', activation='relu', input_shape=(32, 32, 3)))
model.add(tf.keras.layers.Conv2D(filters=32, kernel_size=3, padding='same', activation='relu'))
model.add(tf.keras.layers.MaxPool2D(pool_size=2))# 第二层
model.add(tf.keras.layers.Conv2D(filters=64, kernel_size=3, padding='same', activation='relu', ))
model.add(tf.keras.layers.Conv2D(filters=64, kernel_size=3, padding='same', activation='relu'))
model.add(tf.keras.layers.MaxPool2D(pool_size=2))# 第三层
model.add(tf.keras.layers.Conv2D(filters=128, kernel_size=3, padding='same', activation='relu', ))
model.add(tf.keras.layers.Conv2D(filters=128, kernel_size=3, padding='same', activation='relu'))
model.add(tf.keras.layers.MaxPool2D(pool_size=2))# 将数据展平
model.add(tf.keras.layers.Flatten())# 全连接层
model.add(tf.keras.layers.Dense(256, activation='relu'))
# 加入dropout减轻过拟合现象
model.add(tf.keras.layers.AlphaDropout(0.3))
model.add(tf.keras.layers.Dense(10, activation='softmax'))

配置网格

# 配置网络,损失,优化器,函数
model.compile(loss='sparse_categorical_crossentropy',optimizer='sgd',metrics=['acc'])

三:训练

# 传入训练图片集,训练目标集,共迭代十次
# validation_data中传入测试图片集,测试目标集
history = model.fit(x_train_scaled, y_train, epochs=10,validation_data=(x_valid_scaled, y_valid))

画出损失看一下

pd.DataFrame(history.history).plot(figsize=(8, 5))
plt.grid()
plt.gca().set_ylim(0, 2)
plt.show()

总结:

对于图片分类:

1.先确定使用什么算法来对物体识别

2.将数据处理到适用于这个算法的格式

3. 构建这个算法的卷积神经网络

4.训练调参

5.预测


http://www.ppmy.cn/server/121442.html

相关文章

缓存技术的核心价值与应用

缓存技术,作为一种高效的资源优化手段,其核心在于将频繁访问的数据或计算结果预先存储在高速存储介质中,以便快速响应后续的相同或相似请求,从而显著减少了重新计算或检索的开销。这种机制不仅大幅提升了系统处理速度和用户体验&a…

【C语言】文件操作

目录 💯为什么使用文件? 💯 什么是文件? ⭐程序文件 ⭐数据文件 ⭐文件名 💯二进制文件和文本文件? 💯文件的打开和关闭 ⭐流和标准流 1.流 2.标准流 ⭐文件指针 ⭐文件的打开和关…

Java高级编程——泛型(泛型类、泛型接口、泛型方法,完成详解,并附有案例+代码)

文章目录 泛型21.1 概述21.2 泛型类21.3 泛型方法21.4 泛型接口 泛型 21.1 概述 JDK5中引入的特性&#xff0c;在编译阶段约束操作的数据类型&#xff0c;并进行检查 泛型格式&#xff1a;<数据类型> 泛型只能支持引用数据类型&#xff0c;如果写基本数据类型需要写对…

Voxel mamba :基于Mamba的3D目标检测算法解析

目录 1 算法简介1.1 前提补充空间填充曲线&#xff08;Space-filling Curve&#xff09;点云分组 2 模块介绍2.1 希尔伯特输入层&#xff08;Hilbert Input Layer&#xff09;2.2 双尺度 SSM 模块&#xff08;Dual-scale SSM Block&#xff09;2.3 隐式窗口分区 &#xff08;Im…

关于nodejs

NODEJS官网停止对16版本的维护后还能在项目中使用吗 虽然 Node.js 官网停止对 16 版本的维护&#xff0c;但在项目中仍然可以继续使用一段时间。 然而&#xff0c;这存在一些风险和需要考虑的因素&#xff1a; 风险方面&#xff1a; 安全漏洞&#xff1a;随着时间的推移&am…

dockerfile 添加arthas 监控插件。容器添加arthas监控

1. arthas官网&#xff1a; 简介 | arthas 2. arthas下载地址&#xff1a; Releases alibaba/arthas GitHub 3. 下载版本&#xff1a; 4. 下载压缩包后&#xff0c;解压缩&#xff0c;放入Dockerfile 同级目录 5. dockerfile 命令&#xff1a; RUN mkdir -p /opt/arthas…

信息技术的革新与未来展望

信息技术的革新与未来展望 随着全球数字化进程的加速&#xff0c;信息技术&#xff08;IT&#xff09;已经深入到了社会的各个角落。无论是政府、企业&#xff0c;还是普通消费者&#xff0c;信息技术的应用无处不在。本文将探讨IT技术的革新、其在各个领域的应用以及未来可能…

数据结构-2.9.双链表

一.双链表与单链表的对比&#xff1a; 二.双链表的初始化(带头结点)&#xff1a; 1.图解&#xff1a; 2.代码演示&#xff1a; #include<stdio.h> #include<stdlib.h> ​ //定义双链表结构体 typedef struct DNode {int data;struct DNode *prior;//前驱指针即指…