免费贴图素材网站,电商设计师工资高吗,wordpress+模板+国外,天津网站优化公司价格《博主简介》 小伙伴们好#xff0c;我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】#xff0c;共同学习交流~ #x1f44d;感谢小伙伴们点赞、关注#xff01; 《------往期经典推…《博主简介》 小伙伴们好我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源可关注公-仲-hao:【阿旭算法与机器学习】共同学习交流~ 感谢小伙伴们点赞、关注 《------往期经典推荐------》
一、AI应用软件开发实战专栏【链接】
项目名称项目名称1.【人脸识别与管理系统开发】2.【车牌识别与自动收费管理系统开发】3.【手势识别系统开发】4.【人脸面部活体检测系统开发】5.【图片风格快速迁移软件开发】6.【人脸表表情识别系统】7.【YOLOv8多目标识别与自动标注软件开发】8.【基于YOLOv8深度学习的行人跌倒检测系统】9.【基于YOLOv8深度学习的PCB板缺陷检测系统】10.【基于YOLOv8深度学习的生活垃圾分类目标检测系统】11.【基于YOLOv8深度学习的安全帽目标检测系统】12.【基于YOLOv8深度学习的120种犬类检测与识别系统】13.【基于YOLOv8深度学习的路面坑洞检测系统】14.【基于YOLOv8深度学习的火焰烟雾检测系统】15.【基于YOLOv8深度学习的钢材表面缺陷检测系统】16.【基于YOLOv8深度学习的舰船目标分类检测系统】17.【基于YOLOv8深度学习的西红柿成熟度检测系统】18.【基于YOLOv8深度学习的血细胞检测与计数系统】19.【基于YOLOv8深度学习的吸烟/抽烟行为检测系统】20.【基于YOLOv8深度学习的水稻害虫检测与识别系统】21.【基于YOLOv8深度学习的高精度车辆行人检测与计数系统】22.【基于YOLOv8深度学习的路面标志线检测与识别系统】23.【基于YOLOv8深度学习的智能小麦害虫检测识别系统】24.【基于YOLOv8深度学习的智能玉米害虫检测识别系统】25.【基于YOLOv8深度学习的200种鸟类智能检测与识别系统】26.【基于YOLOv8深度学习的45种交通标志智能检测与识别系统】27.【基于YOLOv8深度学习的人脸面部表情识别系统】28.【基于YOLOv8深度学习的苹果叶片病害智能诊断系统】29.【基于YOLOv8深度学习的智能肺炎诊断系统】30.【基于YOLOv8深度学习的葡萄簇目标检测系统】31.【基于YOLOv8深度学习的100种中草药智能识别系统】32.【基于YOLOv8深度学习的102种花卉智能识别系统】33.【基于YOLOv8深度学习的100种蝴蝶智能识别系统】34.【基于YOLOv8深度学习的水稻叶片病害智能诊断系统】35.【基于YOLOv8与ByteTrack的车辆行人多目标检测与追踪系统】36.【基于YOLOv8深度学习的智能草莓病害检测与分割系统】37.【基于YOLOv8深度学习的复杂场景下船舶目标检测系统】38.【基于YOLOv8深度学习的农作物幼苗与杂草检测系统】39.【基于YOLOv8深度学习的智能道路裂缝检测与分析系统】40.【基于YOLOv8深度学习的葡萄病害智能诊断与防治系统】41.【基于YOLOv8深度学习的遥感地理空间物体检测系统】42.【基于YOLOv8深度学习的无人机视角地面物体检测系统】43.【基于YOLOv8深度学习的木薯病害智能诊断与防治系统】44.【基于YOLOv8深度学习的野外火焰烟雾检测系统】45.【基于YOLOv8深度学习的脑肿瘤智能检测系统】46.【基于YOLOv8深度学习的玉米叶片病害智能诊断与防治系统】47.【基于YOLOv8深度学习的橙子病害智能诊断与防治系统】48.【车辆检测追踪与流量计数系统】49.【行人检测追踪与双向流量计数系统】50.【基于YOLOv8深度学习的反光衣检测与预警系统】51.【危险区域人员闯入检测与报警系统】52.【高密度人脸智能检测与统计系统】53.【CT扫描图像肾结石智能检测系统】54.【水果智能检测系统】55.【水果质量好坏智能检测系统】56.【蔬菜目标检测与识别系统】57.【非机动车驾驶员头盔检测系统】58.【太阳能电池板检测与分析系统】59.【工业螺栓螺母检测】60.【金属焊缝缺陷检测系统】61.【链条缺陷检测与识别系统】62.【交通信号灯检测识别】
二、机器学习实战专栏【链接】已更新31期欢迎关注持续更新中~~ 三、深度学习【Pytorch】专栏【链接】 四、【Stable Diffusion绘画系列】专栏【链接】 五、YOLOv8改进专栏【链接】持续更新中~~ 六、YOLO性能对比专栏【链接】持续更新中~
《------正文------》
基本功能演示 基于YOLOv10深度学习的草莓成熟度检测与识别系统【python源码Pyqt5界面数据集训练代码】 摘要草莓成熟度检测与识别系统对提高农业生产效率和产品质量具有关键意义其不仅可以提高草莓生产和分销的效率以及质量为农业生产提供了精准度和产量双提升的可能。本文基于YOLOv10深度学习框架通过5605张成熟与未成熟草莓的相关图片训练了一个进行草莓成熟度目标检测的模型,可以很好的检测草莓成熟、未成熟这2个类别。并基于此模型开发了一款带UI界面的草莓成熟度检测与识别系统更便于进行功能的展示。该系统是基于python与PyQT5开发的支持图片、视频以及摄像头进行目标检测并保存检测结果。本文提供了完整的Python代码和使用教程给感兴趣的小伙伴参考学习完整的代码资源文件获取方式见文末。 文章目录 基本功能演示前言一、软件核心功能介绍及效果演示软件主要功能界面参数设置说明检测结果说明主要功能说明1图片检测说明2视频检测说明3摄像头检测说明4保存图片与视频检测说明 二、模型的训练、评估与推理1.YOLOv10简介YOLOv10优化点双标签分配模型设计改进 2. 数据集准备与训练模型训练 3. 训练结果评估4. 检测结果识别 【获取方式】结束语 点击跳转至文末《完整相关文件及源码》获取 前言
草莓成熟度检测与识别系统对提高农业生产效率和产品质量具有关键意义。在传统农业中判断果实成熟度往往依靠人工视觉这一过程耗时耗力且缺乏一致性。利用YOLOv10深度学习框架的强大图像处理能力该检测系统可以准确快速地评估草莓的成熟度确保及时收获从而最大化产量和利润同时保持草莓的最佳风味和营养价值。 其应用场景主要包括 智能农业在自动化采摘机器人中应用实现高效率的分拣和收集。 农场质量控制监测作物生长状态辅助农民管理作物生长周期。 食品加工厂自动化分拣草莓确保加工果品质量一致性。 农产品批发市场快速分级草莓提升交易效率。 超市与零售业为消费者提供成熟度分级明确的草莓提高顾客满意度。 农业研究和教育收集成熟度数据用于科学研究和教学演示。 供应链物流在物流环节检测草莓状态预防货物在运输过程中过熟或变质。 总结来说草莓成熟度检测与识别系统提高了草莓生产和分销的效率以及质量为农业生产提供了精准度和产量双提升的可能。随着技术的进一步迭代和普及这一系统有望在全球范围内推广为现代农业发展及相关产业链带来革命性的变革。
博主通过搜集实际场景中的草莓是否成熟相关数据图片根据YOLOv10的目标检测技术基于python与Pyqt5开发了一款界面简洁的草莓成熟度检测与识别系统可支持图片、视频以及摄像头检测同时可以将图片或者视频检测结果进行保存。
软件初始界面如下图所示
检测结果界面如下
一、软件核心功能介绍及效果演示
软件主要功能
1. 可用于实际场景中的草莓目标,可检测2个类别成熟、未成熟; 2. 支持图片、视频及摄像头进行检测同时支持图片的批量检测 3. 界面可实时显示目标位置、目标总数、置信度、用时等信息; 4. 支持图片或者视频的检测结果保存 5. 支持图片检测结果保存csv文件。
界面参数设置说明 置信度阈值也就是目标检测时的conf参数置信度阈值用于筛选模型检测结果中的边界框。每个边界框都有一个置信度分数表示该框中是否包含对象的概率。只有置信度大于或等于该阈值的检测结果才会被保留下来 交并比阈值也就是目标检测时的iou参数交并比阈值用于非极大值抑制NMS过程。例如当两个边界框的 IOU 大于等于设定的阈值则其中置信度较低的框会被抑制即删除。
检测结果说明 显示标签名称与置信度表示是否在检测图片上标签名称与置信度显示默认勾选会在检测图片上显示标签名称与置信度如果不勾选则不会显示 总目标数表示画面中的目标数目 目标选择可选择单个目标进行位置信息、置信度查看。 目标位置表示所选择目标的检测框左上角与右下角的坐标位置。默认显示的是置信度最大的一个目标信息
主要功能说明
功能视频演示见文章开头以下是简要的操作描述。
1图片检测说明
点击打开图片按钮选择需要检测的图片或者点击打开文件夹按钮选择需要批量检测图片所在的文件夹操作演示如下 点击目标下拉框后可以选定指定目标的结果信息进行显示。 点击保存按钮会对检测结果进行保存存储路径为save_data目录下。 注1.右侧目标位置默认显示置信度最大一个目标位置可用下拉框进行目标切换。所有检测结果均在左下方表格中显示。
2视频检测说明
点击视频按钮打开选择需要检测的视频就会自动显示检测结果再次点击可以关闭视频。 点击保存按钮会对视频检测结果进行保存存储路径为save_data目录下。
3摄像头检测说明
点击打开摄像头按钮可以打开摄像头可以实时进行检测再次点击可关闭摄像头。
4保存图片与视频检测说明
点击保存按钮后会将当前选择的图片【含批量图片】或者视频的检测结果进行保存。检测的图片与视频结果会存储在save_data目录下。
保存的检测结果文件如下
图片文件保存的csv文件内容如下包括图片路径、目标在图片中的编号、目标类别、置信度、目标坐标位置。 注其中坐标位置是代表检测框的左上角与右下角两个点的x、y坐标。
二、模型的训练、评估与推理
1.YOLOv10简介 YOLOv10是YOLO最新一代版本的实时端到端目标检测算法。该算法在YOLO系列的基础上进行了优化和改进旨在提高性能和效率之间的平衡。首先作者提出了连续双分配方法以实现NMS-free训练从而降低了推理延迟并提高了模型的性能。其次作者采用了全面的效率-准确性驱动的设计策略对YOLO的各种组件进行了综合优化大大减少了计算开销并增强了模型的能力。
YOLOv10优化点
双标签分配 与一对一配对不同一对多配对为每个真实标签分配一个预测标签避免了后处理中的非极大抑制NMS。然而它会导致弱监督从而导致较低的准确度和收敛速度。幸运的是这种缺陷可以通过一对多配对进行补偿。为了实现这一目标在YOLO中引入了双标签分配来结合这两种策略的优点。具体来说如上图所示我们为 YOLO 添加了一个额外的一对一头部。它保留了一致的结构并采用与原始的一对多分支相同的学习目标但利用一对一匹配获得标签分配。在训练过程中两个头与模型一起联合优化允许骨干网络和脖子从一对多分支提供的丰富监督信号中受益。在推理过程中我们丢弃一对多头并使用一对一头进行预测。这使得 YOLO 能够端到端部署而无需付出任何额外的推断成本。
模型设计改进 在模型设计方面提出了以下几种改进点 轻量级分类头 通过对分类头进行轻量化设计可以减少计算成本而不会显著影响性能。 空间通道解耦降采样 该方法通过分离空间和通道维度上的操作提高了信息保留率从而实现了更高的效率和竞争力。 排名引导块设计 该方法根据各个阶段的冗余程度采用不同的基本构建块以实现更高效的模型设计。 大核深度卷积和部分自注意力模块 这些模块可以在不增加太多计算开销的情况下提高模型的表现力。
2. 数据集准备与训练
通过网络上搜集关于草莓是否成熟相关图片并使用Labelimg标注工具对每张图片进行标注。数据集一共包含5605张图片其中训练集包含5058张图片验证集包含412张图片、测试集包含135张图片。 部分数据集及标注如下图所示 数据集各类别数量分布如下
模型训练
图片数据的存放格式如下在项目目录中新建datasets目录同时将检测的图片分为训练集与验证集放入Data目录下。
同时我们需要新建一个data.yaml文件用于存储训练数据的路径及模型需要进行检测的类别。YOLOv10在进行模型训练时会读取该文件的信息用于进行模型的训练与验证。data.yaml的具体内容如下
train: D:\2MyCVProgram\2DetectProgram\StrawberryRipeDetection_v10\datasets\Data\train
val: D:\2MyCVProgram\2DetectProgram\StrawberryRipeDetection_v10\datasets\Data\valid
test: D:\2MyCVProgram\2DetectProgram\StrawberryRipeDetection_v10\datasets\Data\testnc: 2
names: [ripe, unripe]注train与val后面表示需要训练图片的路径建议直接写自己文件的绝对路径。 数据准备完成后通过调用train.py文件进行模型训练epochs参数用于调整训练的轮数batch参数用于调整训练的批次大小【根据内存大小调整最小为1】代码如下
#coding:utf-8
from ultralytics import YOLO
import matplotlib
matplotlib.use(TkAgg)# 模型配置文件
model_yaml_path ultralytics/cfg/models/v10/yolov10n.yaml
#数据集配置文件
data_yaml_path datasets/Data/data.yaml
#预训练模型
pre_model_name yolov10n.ptif __name__ __main__:#加载预训练模型model YOLO(model_yaml_path).load(pre_model_name)#训练模型results model.train(datadata_yaml_path,epochs150, # 训练轮数batch4, # batch大小nametrain_v10, # 保存结果的文件夹名称optimizerSGD) # 优化器3. 训练结果评估
在深度学习中我们通常用损失函数下降的曲线来观察模型训练的情况。YOLOv10在训练时主要包含三个方面的损失定位损失(box_loss)、分类损失(cls_loss)和动态特征损失dfl_loss在训练结束后可以在runs/目录下找到训练过程及结果文件如下所示
各损失函数作用说明 定位损失box_loss预测框与标定框之间的误差GIoU越小定位得越准 分类损失cls_loss计算锚框与对应的标定分类是否正确越小分类得越准 动态特征损失dfl_lossDFLLoss是一种用于回归预测框与目标框之间距离的损失函数。在计算损失时目标框需要缩放到特征图尺度即除以相应的stride并与预测的边界框计算Ciou Loss同时与预测的anchors中心点到各边的距离计算回归DFLLoss。 本文训练结果如下
我们通常用PR曲线来体现精确率和召回率的关系本文训练结果的PR曲线如下。mAP表示Precision和Recall作为两轴作图后围成的面积m表示平均后面的数表示判定iou为正负样本的阈值。mAP.5表示阈值大于0.5的平均mAP可以看到本文模型目标检测的mAP0.5值为0.946结果是十分不错的。
4. 检测结果识别
模型训练完成后我们可以得到一个最佳的训练结果模型best.pt文件在runs/train/weights目录下。我们可以使用该文件进行后续的推理检测。 图片检测代码如下
#coding:utf-8
from ultralytics import YOLO
import cv2# 所需加载的模型目录
path models/best.pt
# 需要检测的图片地址
img_path TestFiles/19_jpg.rf.559f3dc4ae182c6def78d08dc7440fdb.jpg# 加载预训练模型
model YOLO(path, taskdetect)# 检测图片
results model(img_path)
print(results)
res results[0].plot()
# res cv2.resize(res,dsizeNone,fx0.5,fy0.5,interpolationcv2.INTER_LINEAR)
cv2.imshow(YOLOv8 Detection, res)
cv2.waitKey(0)执行上述代码后会将执行的结果直接标注在图片上结果如下
以上便是关于此款草莓成熟度检测与识别系统的原理与代码介绍。基于此模型博主用python与Pyqt5开发了一个带界面的软件系统即文中第二部分的演示内容能够很好的支持图片、视频及摄像头进行检测同时支持检测结果的保存。
关于该系统涉及到的完整源码、UI界面代码、数据集、训练代码、测试图片视频等相关文件均已打包上传感兴趣的小伙伴可以通过下载链接自行获取。 【获取方式】 关注下方名片G-Z-H【阿旭算法与机器学习】并发送【源码】即可获取下载方式 本文涉及到的完整全部程序文件包括python源码、数据集、训练好的结果文件、训练代码、UI源码、测试图片视频等见下图获取方式见文末 注意该代码基于Python3.9开发运行界面的主程序为MainProgram.py其他测试脚本说明见上图。为确保程序顺利运行请按照程序运行说明文档txt配置软件运行所需环境。 关注末尾名片公-Z-H:【阿旭算法与机器学习】并发送【源码】即可获取下载方式 结束语
以上便是博主开发的基于YOLOv10深度学习的草莓成熟度检测与识别系统的全部内容由于博主能力有限难免有疏漏之处希望小伙伴能批评指正。 关于本篇文章大家有任何建议或意见欢迎在评论区留言交流 觉得不错的小伙伴感谢点赞、关注加收藏哦