改进YOLO的群养猪行为识别算法研究及部署(小程序-网站平台-pyqt)

概述

在这里插入图片描述

群养猪的运动信息和行为信息与其健康状况息息相关,但人工巡视费时费力,本实验提出采用行为识别算法于群养猪的养殖管理中,识别群养猪drink(饮水)stand(站立)lie(躺卧)行为,为自动化养殖提供基础。本项目最终以三种不同的形式进行部署,分别为:

实验流程

下图是基于改进YOLOv5s的行为识别>群养猪行为识别模型建立流程,可概括为以下几个阶段:数据集的准备工作,YOLOv5模型的搭建,模型结构的调优和模型的部署。

在这里插入图片描述

数据集的准备工作

关于群养猪的行为相关的数据集十分难获取,尤其是饮水行为的数据集。进行数据集的准备工作时,首先通过在生猪养殖场抓拍特定行为的图片和编写脚本爬取网络图片来采集数据集,然后使用labelImg软件进行数据集的标注,并将群养猪的行为定义为drink(饮水)、stand(站立)和lie(躺卧),标注完成后编写代码将标注数据转化为txt格式,原始图片和txt格式的标注文件共同构成行为识别>群养猪行为识别数据集。

YOLOv5模型的搭建

在YOLOv5s模型的搭建阶段,将输入端、骨干网络、颈部网络和头部网络按照一定组织结构连接起来,同时可在yolov5/models/yolov5s.yaml文件中按需修改骨干网络和头部网络的结构,修改后可通过运行yolov5/models/yolo.py文件查看网络结构。

注意:YOLOv5模型的搭建对应的工作目录是yolov5

模型结构的调优

在模型结构的调优阶段,在深度学习平台中开始对模型进行训练,直到模型收敛,然后对模型进行测试,比较并调整模型结构,周而复始,直到得到适用于群养环境下密集拥挤的生猪检测场景的模型。

在YOLOv5s基础上,提出两种改进行为识别>群养猪行为识别方法。第一点改进为:将坐标注意力模块(Coordinate Attention,CA)融合在YOLOv5s的骨干网络之后,记为YOLOv5s_CA。CA能够突出特征图的重要行为特征,抑制一般特征,对比于基于YOLOv5s行为识别>群养猪行为识别算法,该模型的召回率、F1得分和mAP@0.5均有提升,分别为90.6%,0.897和93.0%。第二点改进为:在YOLOv5s_CA的基础上,用DIoU-NMS后处理算法替换NMS,记为改进YOLOv5s_CA。该改进方法在行为识别预测阶段,能够有效保留图像中密集遮挡的目标生猪检测框,降低生猪的漏检率。下图为改进YOLOv5s_CA的网络结构:

在这里插入图片描述

下表为基于YOLOv5s网络的消融实验结果:

CADIoU-NMS精确率(%)召回率(%)F1mAP@0.5(%)推理时间
--92.486.40.89392.92.475ms/张
-88.890.60.89793.02.725ms/张
-88.493.10.90793.66.600ms/张
90.991.50.91294.16.763ms/张

注意:YOLOv5模型结构的调优对应的工作目录是yolov5

模型的部署

通用中间格式ONNX

首先将自己训练得到的行为识别>群养猪行为识别模型,转换为机器学习通用中间格式ONNX,为后续ONNX Runtime部署奠定基础。导出ONNX需要声明输入图像的大小,我指定为640×640​,其核心代码如下:

torch.onnx.export(model, img, f, verbose=False, opset_version=12, input_names=['images'],dynamic_axes={'images': {0: 'batch', 2: 'height', 3: 'width'},  # size(1,3,640,640)'output': {0: 'batch', 2: 'y', 3: 'x'}} if opt.dynamic else None)

注意:导出ONNX的代码为yolov5/models/export.py。在导出改进YOLOv5s_CA模型为ONNX格式时,坐标注意力中使用了nn.AdaptiveAvgPool2d,这个操作符在ONNX是动态的,ONNX暂时不支持导出。因此,导出的是基于YOLOv5s的行为识别>群养猪行为识别模型,并在后续的部署中使用该模型。

使用ONNX Runtime部署即可调用ONNX格式的模型,其核心代码如下:

import onnxruntime as ort
self.onnx_session = ort.InferenceSession(onnx_path)
# 推理结果
pred = self.onnx_session.run(None, input_feed)[0]  # <class 'numpy.ndarray'>(1, 25200, 9)

注意:使用ONNX进行推理的代码为yolov5_deploy/onnx_inference3.py

部署平台

  • 腾讯云
  • Ubuntu-20.04
  • CPU-2核
  • 内存-2GB
    在这里插入图片描述

使用Flask部署后端服务

使用轻量级的Flask框架编写调用YOLOv5s模型进行推理的接口,各个接口的功能如下:

接口功能
http://1.12.231.219:8083/demo上传图片并进行推理识别的demo
http://1.12.231.219:8083/upload_image上传图片
http://1.12.231.219:8083/results/查看图片
http://1.12.231.219:8083/yolo调用ONNX模型进行推理

注意:使用Flask部署后端服务的工作目录为yolov5_deploy

下图为能直接展示的Flask后端接口:
在这里插入图片描述

网站平台

网站部署网址:http://1.12.231.219/

在网站平台的实现上,实验采用Vue.js作为前端框架,使用轻量级的Flask框架编写的后端接口,采用前后端分离的方式进行网站平台的开发。下图为网站平台首页:

将网页下拉到底部,用户可以点击“选择文件”的按钮上传群养猪图片,并点击“行为识别”:

在这里插入图片描述

注意:使用Vue部署网站平台的工作目录为deepvue。Vue项目的打包部署已上传至谷歌云端

微信小程序

在微信小程序的实现上,实验使用微信开发者工具进行开发,后端采用Flask框架进行编写,以前后端分离的方式完成该项目设计与开发。由于需要域名才能上线小程序,因此微信端的部署仅限于本地开发,之后有充足的经济支持会考虑上架小程序

微信小程序的界面如下图所示,界面划分为“登录”、 “行为识别”和“个人中心”三个部分。

行为识别>群养猪行为识别检测系统(微信小程序)操作展示如下:
在这里插入图片描述

<
注意:使用开发微信小程序的工作目录为wx-pig

PyQt应用程序

在应用软件的实现上,实验采用Python和PyQt5完成对行为识别>群养猪行为识别检测系统的开发,借助界面设计辅助工具QtDesigner完成应用软件的界面设计工作。应用软件的主界面如下所示,界面划分为五个模块,分别为“图片显示模块”、“图片调整模块”、“图片信息模块”、“识别结果模块”和“功能按钮模块”。
应用程序操作如下所示:
在这里插入图片描述

注意:使用PyQt开发应用程序的工作目录为yolov5_pyqt。PyQt应用程序的部署exe文件已上传至谷歌云端硬盘

更多信息

计算机视觉、图像处理、毕业辅导、作业帮助、代码获取,远程协助,代码定制,私聊会回复!

http://www.ppmy.cn/news/1519949.html

相关文章

论tomcat线程池和spring封装的线程池

Tomcat 中的线程池是什么&#xff1f; 内部线程池&#xff1a;Tomcat 确实有一个内部的线程池&#xff0c;用于处理 HTTP 请求&#xff0c;通常是org.apache.tomcat.util.threads.ThreadPoolExecutor 类的实例。这个线程池专门用于处理进入的 HTTP 请求和发送响应。可以通过 T…

【C++】手动实现String类的封装(分文件编译)

实现了String类的大部分封装&#xff0c;采用分文件编译 //mystring.h #ifndef MYSTRING_H #define MYSTRING_H#include <iostream> #include <cstring> using namespace std;class myString { private:char *str; //定义一个字符串int size; //记录字符串…

线性代数 第五讲:线性方程组_齐次线性方程组_非齐次线性方程组_公共解同解方程组_详解

线性方程组 文章目录 线性方程组1.齐次线性方程组的求解1.1 核心要义1.2 基础解系与线性无关的解向量的个数1.3 计算使用举例 2. 非齐次线性方程的求解2.1 非齐次线性方程解的判定2.2 非齐次线性方程解的结构2.3 计算使用举例 3.公共解与同解3.1 两个方程组的公共解3.2 同解方程…

鸿蒙界面开发(五):相对布局

相对布局RelativeContainer 相对布局的容器&#xff0c;支持容器内部的子元素设置相对位置关系&#xff0c;适用于界面复杂场景的情况&#xff0c;对多个子组件进行对齐和排列。子元素支持指定兄弟或父元素作为锚点&#xff0c;基于锚点做相对位置布局。 锚点&#xff1a;通过…

RK3568 Android 11 蓝牙BluetoothA2dpSink 获取用于生成频谱的PCM

Android 中的 A2DP Sink A2DP Sink 在 Android 系统中主要用于 接收 其他蓝牙设备&#xff08;如手机、平板、电脑等&#xff09;发送过来的 高质量的立体声音频。简单来说&#xff0c;它让你的 Android 设备可以充当一个 蓝牙音箱 或 耳机 的角色。 核心功能&#xff1a; 接…

vue3 监听

watch &#xff08;1&#xff09;监听ref 状态的变化 const num ref(1) watch(num,(newValue,oldValue)>{console.log(newValue,oldValue);//2,1 }) setTimeout(()>{num.value },500)&#xff08;2&#xff09;computed const num ref(1); const double computed((…

惠中科技光伏清洗剂:绿色清洁,引领光伏行业新潮流

在当今全球能源转型的大潮中&#xff0c;光伏产业作为绿色能源的重要组成部分&#xff0c;正以前所未有的速度蓬勃发展。然而&#xff0c;随着光伏板在户外环境的长时间暴露&#xff0c;其表面不可避免地会积累灰尘、鸟粪、油污等污染物&#xff0c;严重影响光伏板的透光率和发…

Gorm--Scan

在 Gorm 中&#xff0c;Scan 是一个用于将查询结果映射到自定义结构体或变量的函数。与 Find 或 First 不同&#xff0c;Scan 允许你将查询结果存储到与数据库模型不完全匹配的结构体中。它特别适合用于自定义查询结果或联合查询的场景。 type Result struct {Name stringEma…

#单片机基础 笔记二

SPI中断 1.SPI总线协议 1.1协议介绍 SPI接口是Motorola &#xff08;motorola | Smartphones, Accessories & Smart Home Devices&#xff09;首先提出的全双工三线/四线同步串行外围接口采用主从模式&#xff08;Master Slave&#xff09;架构。 时钟由Master控制&#xf…

ELK学习笔记——如何给Kibana新增用户和角色

Kibana新增用户和角色 首先用超管账号登录上Kibana&#xff0c;按照下面步骤操作 1、创建角色 按图操作 2、创建用户 按图操作 3、给用户分配角色 至此&#xff0c;角色和用户绑定成功&#xff1b; 最后&#xff0c;可以退出管理员账号&#xff0c;登录这个新…

github私有仓库通过action部署hexo到公开仓库

github私有仓库通过action部署hexo到公开仓库 有一段时间一直将博客md文件直接放到公开仓库然后通过工作流action创建一个gh-page分支&#xff0c;来实现部署 但是这样做有一个问题&#xff0c;如果你的源文件&#xff0c;或者配置文件中有涉及变量&#xff0c;或者密钥key&a…

Linux-vim

文章目录 vi和vimvim的基本概念vim的基本操作vim正常模式命令集插入模式从插入模式切换为命令模式移动光标删除文字复制替换撤销上一次操作更改跳至指定的行 vim末行模式命令集列出行号跳到文件中的某一行查找字符保存文件推出vim vi和vim vi/vim的区别简单点来说&#xff0c;…

Linux C 内核编程 /proc 编程例子

直接上代码 proc_demo.c内核版本&#xff1a; 5.4.0-150-generic #include <linux/module.h> #include <linux/sched.h> #include <linux/proc_fs.h> #include <linux/seq_file.h> #include <linux/uaccess.h> #include <linux/slab.h>s…

threading.local的使用

python中的threading.local对象 在Python中&#xff0c;使用threading.local对象的意义在于为每个线程提供了一种安全地存储和访问线程局部变量的方式。这种机制对于多线程编程特别有用&#xff0c;因为它可以帮助开发者避免一些常见的多线程编程问题&#xff0c;如数据竞争、…

技术周刊 | Rspack 1.0、v0 支持 Vue、2024 年度编程语言排行榜、Ideogram 2.0、从 0 实现一个 React

大家好&#xff0c;我是童欧巴&#xff0c;欢迎来到第 126 期技术周刊。 资讯 Rspack 1.0 Rspack 1.0 正式发布&#xff0c;作为一款基于 Rust 的高性能 JavaScript 打包工具&#xff0c;它兼容 webpack API 和生态&#xff0c;提供了显著提升的构建性能。1.0 版本在性能、兼…

第三章:实时流数据处理与分析

目录 3.1 流处理框架深入解析与实战 Flink与Kafka Streams的性能对比&#xff1a;事件驱动架构的代码实现 1. Apache Flink&#xff1a;流处理的“性能怪兽” 2. Kafka Streams&#xff1a;轻量级、低延迟的流式处理框架 实时异常检测与报警系统&#xff1a;结合Flink CEP…

【Transformer】基本概述

文章目录 提出背景核心思想—注意力机制流程解析参考资料 提出背景 在Transformer模型出现之前&#xff0c;循环神经网络&#xff08;RNN&#xff09;及其变体&#xff0c;如长短期记忆网络&#xff08;LSTM&#xff09;和门控循环单元&#xff08;GRU&#xff09;&#xff0c;…

版本控制工具git

版本控制工具 git 数据库 > 有代码历史版本 > 仓库 每个文件都是不同的历史版本&#xff0c;以便恢复 集中式版本控制系统 例如&#xff1a;SVN 缺陷&#xff1a; 1.依赖于中心服务器 分布式的版本管理系统 只有程序员用 git 只有需要在同步代码的时候需要联网 程…

Java笔试面试题AI答之面向对象(9)

文章目录 49. 简述Java继承时&#xff0c;类的执行顺序是什么&#xff1f;一、类的静态成员初始化顺序二、对象的初始化顺序三、总结 50. 举例说明什么情况下会更倾向于使用抽象类而不是接口&#xff1f;1. 当需要定义和实现部分通用行为时2. 当需要访问修饰符或方法修饰符时3.…

sqlite3的db.wait方法:等待所有查询完成

Node.js中sqlite3的db.wait方法深入解析 在Node.js环境中&#xff0c;sqlite3库为开发者提供了一个与SQLite数据库进行交互的简洁API。在处理数据库操作时&#xff0c;有时需要等待直到所有的查询都完成&#xff0c;这时db.wait方法就显得尤为重要。本文将深入解析sqlite3库中…