基于深度学习的生活垃圾智能分类系统(微信小程序+YOLOv5+训练数据集+开题报告+中期检查+论文)

摘要

 本文基于Python技术,搭建了YOLOv5s深度学习模型,并基于该模型研发了微信小程序的垃圾分类应用系统。本项目的主要工作如下:

        (1)调研了移动端垃圾分类应用软件动态,并分析其优劣势;分析了深度学习在垃圾分类领域的相关应用,着重研究了YOLO系列的工作原理和YOLOv5s、YOLOv5m、YOLOv5l、YOLOv5x四大模型的优缺点,最终选择了轻量级深度学习模型YOLOv5s。

        (2)本文给出了一种基于深度学习的垃圾图像分类模型YOLOv5s。微信小程序端的垃圾图像分类既要考虑模型的精度,也要保证模型的轻量化,即模型的参数量不能过大,因此在模型设计时需兼顾两者。最后,本项目深度学习模型对垃圾分类的准确率达到了98.5%。

        (3)最后实现了垃圾分类系统整体的设计和测试。系统采用前后端分离的方式进行设计,主要功能是通过手机拍照实现对生活垃圾的分类识别,其他功能包括相册照片识别、文字知识分享和垃圾知识图例展示等。

目录

摘要

研究背景

论文大纲

1. 系统设计

2.效果演示

3.数据集及训练

(一)获取数据

(二)数据标注

4.训练结果分析

5.下载链接


 

研究背景

  当代社会面临着日益严重的环境污染问题,其中垃圾处理是一个亟待解决的重要方面,垃圾围城所带来的土地、水污染、土壤等问题日益突出。因此,确保垃圾得到正确处理和适宜回收具有重要意义。为实现这一目标,需要在政府政策支持下,鼓励公众参与和教育,以及建设垃圾处理和回收设施等综合努力。

        使用Python技术开发垃圾分类深度学习算法,并使用微信小程序做前端界面是一个非常有前途的研究方向,可以帮助人们更好地理解垃圾分类的重要性,并辅助人们进行准确的垃圾分类,以实现正确的垃圾处理,促进环境的可持续发展。

论文大纲

1. 系统设计

        本项目的系统分为服务器端和微信小程序两大部分,采用前后端分离的方式。在微信小程序端,用户可以通过拍摄垃圾的图片,将图片上传到服务器进行处理。微信小程序负责图片的拍摄、上传以及接收和显示来自服务器的处理结果。在服务器端,接收到用户上传的图片后,使用训练好的YOLOv5s算法进行目标检测,识别图片中的垃圾物体,并进行标记和分类。服务器将对标记好的垃圾和其分类信息进行保存,并生成一张新的图片文件,其中标注有垃圾和分类信息。微信小程序再次向服务器发送请求,获取标记好的图片,并将其显示给用户。这样用户就可以在微信小程序中直观地看到图片中的垃圾和分类信息。

 

    服务器端的设计由两个主要的Python源代码文件(server.py和detector.py)和YOLOv5项目源文件组成。这种设计结构的使用使得服务器端能够有效地处理客户端的请求,并利用YOLOv5的强大功能来实现准确的目标检测。通过这种分离的设计方式,代码的可读性和可维护性得到提高,并且使系统的功能模块化,方便后续的扩展和优化。

2.效果演示

      本项目共定义了59种可以识别的垃圾名称类别。59种垃圾类别如图所示。

 

   本项目是一个微信小程序,命名为miniprogram-1。该项目包含一个名为“index”的首页页面,由四个文件组成:布局文件“index.wxml”、执行脚本文件“index.js”、风格文件“index.wxss”和数据配置文件“index.json”。

        Index首页界面包含两个按钮:“相册图片识别”和“拍照智能识别”。其中,“相册图片识别”按钮用于从相册中选择图片进行垃圾分类识别,而“拍照智能识别”按钮则通过调用go_camera函数来启动手机摄像头进行拍照。拍照完成后,系统会对拍摄的图片进行垃圾分类识别,并返回分类结果。垃圾分类小程序目录结构如图所示。

        点击小程序界面的“拍照智能识别”按钮,切换到拍照界面,并对所需要检测的生活垃圾进行拍照。然后,等待系统返回预测结果。如图所示,我们成功地对一瓶啤酒瓶进行了拍摄,并得到了对应的垃圾分类识别结果。在图中,我们用粉色矩形框标注了啤酒瓶,并在上方显示出此物品为“可回收物-玻璃瓶 0.87”,达到了预期的结果。这表明我们的垃圾分类识别系统能够准确地识别出拍摄的垃圾,并返回对应的分类结果。

 

3.数据集及训练

        深度学习算法效果依赖于样本库数据的质量高低,故在采集生活垃圾原始图像后,需对样本库中图像数据进行标准化处理,具体包括数据清洗、尺寸标准化、数据标准以及数据集划分,数据集标准化过程如图所示。

 

(一)获取数据

        本项目共收集1500张带各种垃圾的图片,包含玻璃瓶、餐盒、纸箱、透明塑料瓶等59种垃圾,原始垃圾图像数据如图所示。

   首先,进行数据清洗工作,将采集的照片逐一清洗,去除画面模糊、质量差的图像数据,确保数据的高质量要求。然后,将清洗过后的图像统一裁剪为608×608大小,确保数据集中的图像尺寸大小一致,以便作为YOIOv5s深度学习算法的输入。

(二)数据标注

         然后进行标注工作,标注工具用LabelImg进行标注。

        本文将标注后的生活垃圾数据按照训练集占70%,测试集占30%划分,通过分配确保了数据集用于算法模型训练及测试的合理性。

4.训练结果分析

        本系统通过综合考虑最终采用YOLOv5网络模型,YOLOv5模型运算速度最快,虽AP精度略低于其他三种YOLOv5模型,但其精准度可满足本项目的要求。同时,YOLOv5网络模型因其计算量较小,可在CPU上流畅运行,对电脑硬件和成本要求较低。所以最终采用了YOLOv5网络模型,其网络结构如图所示。

 

垃圾分类模型YOLOv5s训练结果如图所示。在经过200轮训练后,准确率达到了98.5%,可满足本项目的分类精度需求。 

 

5.下载链接

        若您想获得博文中涉及的实现完整全部程序文件(包完整程序、数据集、开题报告、中期报告和论文等,如下图),已将所有涉及的文件同时打包到里面,点击即可运行。

 完整代码下载,请关注下方公众号!!!

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入解析实时数仓Doris:介绍、架构剖析、应用场景与数据划分细节

码到三十五 : 个人主页 心中有诗画,指尖舞代码,目光览世界,步履越千山,人间尽值得 ! Doris是一款高性能、开源的实时分析数据仓库,旨在为用户提供毫秒级查询响应、高并发、高可用以及易于扩展的OLAP解决方…

【Qt 学习笔记】QWidget的geometry属性及window frame的影响

博客主页:Duck Bro 博客主页系列专栏:Qt 专栏关注博主,后期持续更新系列文章如果有错误感谢请大家批评指出,及时修改感谢大家点赞👍收藏⭐评论✍ QWidget的geometry属性 文章编号:Qt 学习笔记 / 16 文章目…

VirusTaxo:病毒物种注释

https://github.com/omics-lab/VirusTaxo 安装 git clone https://github.com/omics-lab/VirusTaxo mamba create -n VirusTaxo python3.10 mamba activate VirusTaxo cd VirusTaxo python3 -m venv environment source ./environment/bin/activate pip install -r require…

mmdetection模型使用mmdeploy部署在windows上的c++部署流程【详细全面版】

0. 前置说明: 该文档适用于:已经使用mmdetection训练好了模型,并且完成了模型转换。要进行模型部署了。 1. 概述 MMDeploy 定义的模型部署流程,如下图所示: 模型转换【待撰写,敬请期待…】 主要功能是:把输入的模型格式,转换为目标设备的推理引擎所要求的模型格式…

解决Xshell登录云服务器的免密码和云服务器生成子用户问题

Xshell登录云服务器的免密码问题 前言一、Xshell登录云服务器的免密码操作实践 二、centos创建用户创建用户实操删除用户更改用户密码直接删除子用户 前言 Xshell登录云服务器免密码问题的解决方案通常涉及使用SSH密钥对。用户生成一对密钥(公钥和私钥)…

HLOOKUP函数结合数据验证实现的动态图表

小伙伴们,大家好啊!今天我们分享一个使用HLOOKUP函数结合数据验证实现的动态图表技巧; 接下来我们具体说说操作步骤吧。 步骤1:选中A列的【路口车辆通过数】单元格区域,复制粘贴后到右边的空白区域,如I列…

Day:006(1) | Python爬虫:高效数据抓取的编程技术(爬虫工具)

selenium介绍与安装 Selenium是一个Web的自动化测试工具,最初是为网站自动化测试而开发的,类型像我们玩游戏用的按键精灵,可以按指定的命令自动操作,不同是Selenium 可以直接运行在浏览器上,它支持所有主流的浏览器&am…

游戏行业科普 (二)游戏是怎么做出来,怎么卖出去的?

游戏行业科普系列文章,大家可以关注起来,等我慢慢芬分享~~ 《蛋仔派对》 一、研运流程--游戏是怎么做出来的 一款游戏的开发和运营大体上可以分为预研立项、设计开发、测试调优、发行上线和成熟运营几个阶段。 1)预研立项: 初始研…

关于时频分析的一些事-答知乎问(一)

从信号的时频谱图中可以提取什么特征? 基于时频谱图的特征一般包括能量特征、时域和频域拓展特征以及时频内禀特征。 基于时频图的能量特征 基于时频图的特征中,能量特征是最简单的一种,通过分析时频谱图中的能量分布特性而获取信号的时频…

生活中的数学 --- 等额本息贷款和等额本金贷款的月供应该怎么算?

等额本息贷款和等额本金贷款的月供应该怎么算? 从一个例子开始,假设我要从银行贷款36万(即,本金),银行给出的贷款年利率是12%(月利率为年利率除以12),贷款半年(6个月),按月还款,分6期还完。 问分…

Zookeeper分布式应用程序协调服务

目录 一、ZooKeeper基本介绍 1.ZooKeeper的简介 2.ZooKeeper的工作机制 3.ZooKeeper的特点 4.ZooKeeper的数据结构 5.ZooKeeper的应用场景 5.1 统一命名服务 5.2 统一配置管理 5.3 统一集群管理 5.4 服务器动态上下线 5.5 软负载均衡 二.ZooKeeper的选举机制 1.第…

DL00295-基于AirSim仿真环境的无人机深度强化学习算法路径规划完整实现含详细说明文档

-创建了一个开放的AI Gym环境,包括多旋翼和固定翼无人机的运动学模型。 -提供了一些UE4环境来训练和测试深度强化学习DRL导航策略。 -基于AirSim和SB3。 完整代码链接见文末。 DL00295-基于AirSim仿真环境的无人机深度强化学习算法路径规划完整实现含详细说明文档

设计模式代码实战-外观模式

1、问题描述 小明家的电源总开关控制了家里的三个设备:空调、台灯和电视机。每个设备都有独立的开关密码,分别用数字1、2和3表示。即输入1时,空调关闭,输入2时,台灯关闭,输入3时,电视机关闭&am…

[大模型]Yi-6B-Chat FastApi 部署调用

Yi-6B-Chat FastApi 部署调用 环境准备 在 Autodl 平台中租赁一个 3090 等 24G 显存的显卡机器,如下图所示镜像选择 PyTorch–>2.0.0–>3.8(ubuntu20.04)–>11.8(11.3 版本以上的都可以)。 接下来打开刚刚租用服务器的 JupyterLab…

基于springboot+vue+Mysql的线上教学平台

开发语言:Java框架:springbootJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:…

Linux ARM平台开发系列讲解(QEMU篇) 1.2 新添加一个Linux kernel设备树

1. 概述 上一章节我们利用QEMU成功启动了Linux kernel,但是细心的小伙伴就会发现,我们用默认的defconfig是没有找到设备树源文件的,但是又发现kernel启动时候它使用了设备树riscv-virtio,qemu,这是因为qemu用了一个默认的设备树文件,该章节呢我们就把这个默认的设备树文件…

web APIs总结(2)

1. 页面滚动事件 很多网页需要检测用户把页面滚动到某个区域后做一些处理, 比如固定导航栏、返回顶部事件名:scroll监听某个元素的内部滚动直接给某个元素加即可 获取位置 scrollLeft和scrollTop (属性) (注&#xf…

手机银行客户端框架之TMF框架介绍

腾讯移动开发平台(Tencent Mobile Framework)整合了腾讯在移动产品中开发、测试、发布和运营的技术能力,为企业提供一站式、覆盖全生命周期的移动端技术平台。核心服务包括移动客户端开发组件、H5容器、灰度发布、热更新、离线包、网关服务、…

ChatGPT 会被 OpenAI 的版权诉讼摧毁吗?|TodayAI

未来人工智能是否能与人类融合成为一个引人关注的问题,但目前,ChatGPT等人工智能技术可能首先需要面对一个更紧迫的挑战:大规模的版权侵权诉讼。近期,ChatGPT因涉嫌在未经授权的情况下使用大量作者的作品进行训练,而被…

我的新书,在西西弗书店上架了!

大家好,我是程序员小灰。今天告诉大家一个好消息,我的新书在西西弗书店上架了! 熟悉小灰的朋友都知道,我以前是京东的一名程序员,现在全职投入到IT领域的自媒体创作。在2019年,我出版了人生中的第一本书《漫…