基于YOLOv8深度学习的玉米叶片病害智能诊断与防治系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标分类(2)

简介: 基于YOLOv8深度学习的玉米叶片病害智能诊断与防治系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标分类

基于YOLOv8深度学习的玉米叶片病害智能诊断与防治系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标分类(1)https://developer.aliyun.com/article/1536800

二、模型的训练、评估与推理

1.YOLOv8的基本原理

YOLOv8是一种前沿的深度学习技术,它基于先前YOLO版本在目标检测任务上的成功,进一步提升了性能和灵活性,在精度和速度方面都具有尖端性能。在之前YOLO 版本的基础上,YOLOv8 引入了新的功能和优化,使其成为广泛应用中各种物体检测任务的理想选择。主要的创新点包括一个新的骨干网络、一个新的 Ancher-Free 检测头和一个新的损失函数,可以在从 CPU 到 GPU 的各种硬件平台上运行

YOLO各版本性能对比:

其主要网络结构如下:

2. 数据集准备与训练

本文使用的玉米叶片病害数据集共包含3852张图片,分为4个病害类别,分别是['锈病','灰叶斑病','健康','枯叶病']。部分数据集及类别信息如下:

图片数据集的存放格式如下,在项目目录中新建datasets目录,同时将分类的图片分为训练集与验证集放入Data目录下。

3.模型训练

数据准备完成后,通过调用train.py文件进行模型训练,epochs参数用于调整训练的轮数,batch参数用于调整训练的批次大小【根据内存大小调整,最小为1】,代码如下:

#coding:utf-8
from ultralytics import YOLO
import matplotlib
matplotlib.use('TkAgg')
if __name__ == '__main__':
    # 训练模型配置文件路径
    yolo_yaml_path = 'ultralytics/cfg/models/v8/yolov8-cls.yaml'
    # 官方预训练模型路径
    pre_model_path = "yolov8n-cls.pt"
    # 加载预训练模型
    model = YOLO(yolo_yaml_path).load(pre_model_path)
    # 模型训练
    model.train(data='datasets/Data', epochs=150, batch=4)

4. 训练结果评估

在深度学习中,我们通常用损失函数下降的曲线来观察模型训练的情况。YOLOv8在训练结束后,可以在runs/目录下找到训练过程及结果文件,如下所示:

本文训练结果如下:

通过accuracy_top1图片准确率曲线图我们可以发现,该模型在验证集的准确率约为0.99,结果还是很不错的。

5. 利用模型进行推理

模型训练完成后,我们可以得到一个最佳的训练结果模型best.pt文件,在runs/trian/weights目录下。我们可以使用该文件进行后续的推理检测。

图片检测代码如下:

#coding:utf-8
from ultralytics import YOLO
import cv2
# 所需加载的模型目录
path = 'models/best.pt'
# 需要检测的图片地址
img_path = "TestFiles/RS_Rust 1598.JPG"
# 加载模型
model = YOLO(path, task='classify')
# 检测图片
results = model(img_path)
print(results)
res = results[0].plot()
# res = cv2.resize(res,dsize=None,fx=0.3,fy=0.3,interpolation=cv2.INTER_LINEAR)
cv2.imshow("YOLOv8 Detection", res)
cv2.waitKey(0)

执行上述代码后,会将执行的结果直接标注在图片上,结果如下:

以上便是关于此款玉米叶片病害智能诊断与防治系统的原理与代码介绍。基于此模型,博主用pythonPyqt5开发了一个带界面的软件系统,即文中第二部分的演示内容,能够很好的支持图片、批量图片、视频及摄像头进行检测

相关文章
|
4天前
|
机器学习/深度学习 存储 算法
基于YOLOv8与ByteTrack的车辆行人多目标检测与追踪系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标追踪、运动物体追踪
基于YOLOv8与ByteTrack的车辆行人多目标检测与追踪系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标追踪、运动物体追踪
|
4天前
|
机器学习/深度学习 存储 计算机视觉
基于YOLOv8深度学习的PCB板缺陷检测系统【python源码+Pyqt5界面+数据集+训练代码】目标检测
基于YOLOv8深度学习的PCB板缺陷检测系统【python源码+Pyqt5界面+数据集+训练代码】目标检测
|
4天前
|
机器学习/深度学习 存储 安全
基于YOLOv8深度学习的行人跌倒检测系统【python源码+Pyqt5界面+数据集+训练代码】目标检测
基于YOLOv8深度学习的行人跌倒检测系统【python源码+Pyqt5界面+数据集+训练代码】目标检测
|
22小时前
|
机器学习/深度学习 自然语言处理 供应链
深度学习在大数据分析中的应用非常广泛
深度学习在大数据分析中的应用非常广泛
|
22小时前
|
机器学习/深度学习 搜索推荐 TensorFlow
深度学习在音乐与艺术创作中的应用越来越广泛
深度学习在音乐与艺术创作中的应用越来越广泛
|
22小时前
|
机器学习/深度学习 搜索推荐 TensorFlow
深度学习在医学影像诊断中的应用正在逐渐展现出巨大的潜力
深度学习在医学影像诊断中的应用正在逐渐展现出巨大的潜力
|
23小时前
|
机器学习/深度学习 TensorFlow 算法框架/工具
深度学习在图像识别中的应用
深度学习在图像识别中的应用
|
23小时前
|
机器学习/深度学习 人工智能 自动驾驶
深度学习在图像识别中的应用与挑战
【6月更文挑战第16天】本文深入探讨了深度学习技术在图像识别领域的应用,包括其原理、优势及面临的主要挑战。通过分析当前的研究进展和案例,揭示了深度学习在处理复杂图像数据时的强大能力及其局限性,为未来的研究方向提供了展望。
|
1天前
|
机器学习/深度学习 传感器 监控
探索深度学习在图像识别中的应用与挑战
【6月更文挑战第16天】本文深入探讨了深度学习技术在图像识别领域的应用,并分析了当前面临的主要挑战。文章首先介绍了深度学习的基础知识及其在图像识别中的重要性,随后详细阐述了卷积神经网络(CNN)的工作原理及其在图像处理中的关键作用。接着,本文讨论了数据增强、迁移学习等提高模型性能的技术,并通过实例展示了深度学习在医学影像分析、自动驾驶车辆视觉系统和面部识别系统中的应用。最后,本文指出了深度学习在图像识别领域所面临的挑战,包括数据集偏差问题、模型泛化能力以及对抗性攻击等,并对未来的研究方向进行了展望。
|
1天前
|
机器学习/深度学习 数据采集 人工智能
深度学习在医疗影像分析中的应用与未来展望
深度学习技术近年来在医疗影像分析领域取得了显著进展,通过自动化处理和高度准确的诊断能力,极大地提升了疾病检测和治疗的效率。本文探讨了当前深度学习在医疗影像分析中的应用现状,具体案例,以及未来可能的发展方向和面临的挑战。
13 3