基于卷积神经网络的垃圾分类系统实现(GUI应用)

server/2024/12/16 5:53:45/

1.摘要

本文主要实现了一个卷积神经网络模型进行垃圾图像分类,为了提高垃圾分类模型的准确率,使用使用Batch Normalization层、使用早期停止策略来防止过拟合等方法来优化模型,实验结果显示最终优化后的模型准确率较高90%左右。最终,本文基于PySimpleGUI库实现了一个图形用户界面(GUI)应用程序,旨在演示如何使用深度学习模型进行垃圾分类预测。

2.模型设计与实验

首先设计实现的基线模型结构如下:

为了进一步优化模型,本文从以下几个方面入手进行优化上述模型:

  1. 模型结构
    • 增加卷积层的数量和/或深度。当前的模型只有两个卷积层,这对于复杂的图像分类任务可能不够。
    • 使用Batch Normalization层在卷积层后,有助于加快训练速度并提高模型性能。
  2. 超参数调整
    • 调整学习率、批量大小、Dropout率等超参数。
    • 使用学习率调度器(如StepDecay、ReduceLROnPlateau等)动态调整学习率。
    • 尝试不同的优化器,如AdamW、RMSprop等。
  3. 正则化和Dropout
    • 在全连接层后添加Dropout层,以减少过拟合。
    • 尝试L1或L2正则化。
  4. 早期停止
    • 使用早期停止策略来防止过拟合,基于验证集的性能在连续多个epoch后没有提升时停止训练。

实现的代码如下:

# 调整模型结构
model = models.Sequential()
model.add(layers.Conv2D(32, (3, 3), activation='relu', input_shape=train_images[0].shape))
model.add(layers.BatchNormalization())
model.add(layers.Conv2D(32, (3, 3), activation='relu'))
model.add(layers.MaxPooling2D((2, 2)))
model.add(layers.Conv2D(64, (3, 3), activation='relu'))
model.add(layers.BatchNormalization())
model.add(layers.Conv2D(64, (3, 3), activation='relu'))
model.add(layers.MaxPooling2D((2, 2)))
model.add(layers.Flatten())
model.add(layers.Dropout(0.5))
model.add(layers.Dense(256, activation='relu'))
model.add(layers.Dropout(0.5))
model.add(layers.Dense(6, activation='softmax'))
# 编译模型
model.compile(optimizer="adam", loss="categorical_crossentropy", metrics=['accuracy'])
# 使用ReduceLROnPlateau进行学习率调整
lr_reducer = callbacks.ReduceLROnPlateau(monitor='val_loss', factor=0.2, patience=5, verbose=1, min_lr=0.00001)
# 训练模型
history = model.fit(train_images, train_labels, epochs=10, callbacks=[lr_reducer, callbacks.EarlyStopping(monitor='val_loss', patience=10)],validation_data=(test_images, test_labels))

本文在如下数据集上进行了实验,总计数据量为10104张,6分类问题。

其实验结果如下:

 3.垃圾分类小程序

        该应用程序为垃圾分类提供了一个直观且用户友好的界面,使用户能够轻松利用深度学习模型进行垃圾分类预测。其功能为:用户选择包含图像的文件夹;用户从列表中选择图像;应用程序加载并显示选定的图像,并使用模型进行预测;应用程序显示预测结果的条形图,突出显示预测类别测等。使用的函数如Matplotlib(用于绘图)、PySimpleGUI(用于构建GUI)、Keras(用于加载和使用深度学习模型)以及PIL(用于图像处理)

        实现的界面如下:

上传一文件夹下的数据进行测试,其结果显示如下:

 代码下载链接:

https://download.csdn.net/download/weixin_40651515/90117152

包含数据集等。


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

相关文章

protobuf c++开发快速上手指南

1、环境准备 在c环境使用 protobuf,需要安装protobuf runtime以及protobuf的编译器:protoc,其作用如下表格: 需要安装的环境作用protoc将proto文件编译成c源码protobuf runtime编译c源码需要链接到protobuf库 注意:…

多通道卷积

3通道的特征图经过一一对应的3通道的卷积核,生成一个新的特征图 卷积层: 6个卷积核组,3个通道每个通道有一个55的卷积核,3个通道为一组 以下这个图可以更直观的概括多通道多核的卷积过程:(一个卷积核组&…

【C++】- 掌握STL List类:带你探索双向链表的魅力

文章目录 前言:一.list的介绍及使用1. list的介绍2. list的使用2.1 list的构造2.2 list iterator的使用2.3 list capacity2.4 list element access2.5 list modifiers2.6 list的迭代器失效 二.list的模拟实现1. list的节点2. list的成员变量3.list迭代器相关问题3.1…

Github 2024-12-11C开源项目日报Top10

根据Github Trendings的统计,今日(2024-12-11统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量C项目10Netdata: 开源实时监控平台 创建周期:4020 天开发语言:C协议类型:GNU General Public License v3.0Star数量:68982 个Fork数量:577…

fiddler设置抓取https,还抓取不到https如何解决?

一、清楚 C:\Users\Admin\AppData\Roaming\Microsoft\Crypto\RSA 目录下所有文件(首次安装fiddler请忽略) 二、清除电脑上的根证书,WINR快捷键,输入:certmgr.msc, 然后回车,查找所有fiddler证书…

人工智能大语言模型起源篇(二),从通用语言微调到驾驭LLM

上一篇:《人工智能大语言模型起源篇(一),从哪里开始》 (5)Howard 和 Ruder 于2018年发表的《Universal Language Model Fine-tuning for Text Classification》,https://arxiv.org/abs/1801.06…

GitHub 开源仓库推荐:poe2skills

poe2skills是一个专为《流放之路 2》玩家和开发者设计的开源项目。它收集了游戏中所有的技能和被动宝石信息,帮助玩家更好地理解和利用游戏中的各种机制。对于那些希望深入挖掘游戏潜力的玩家来说,这个仓库无疑是一个宝贵的资源。 功能亮点 全面的技能数…

30、使用ESP8266跟SG90舵机制作四足蜘蛛机器人

目录 1、简介 2、使用例子 3、代码解析 4、资源下载 正文 1、简介 本篇使用ESP8266跟SG90舵机制作四足蜘蛛机器人,使用的180度舵机有8个,需要一块16路舵机控制板,也可以使用小一点的控制板8路也够了。下面开始今天的教程,源码在文章末尾自行下载,力求大家都能看懂。…