使用OpenCV DNN推理YOLOv5-CLS转换后的ONNX分类模型

这篇具有很好参考价值的文章主要介绍了使用OpenCV DNN推理YOLOv5-CLS转换后的ONNX分类模型。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

YOLOv5是一种先进的目标检测算法,而YOLOv5-CLS则是YOLOv5的一个变种,专门用于图像分类任务。为了在实际应用中使用YOLOv5-CLS模型,我们需要将其转换为Open Neural Network Exchange (ONNX) 格式,并使用OpenCV DNN库来进行推理。

步骤1: 安装OpenCV和ONNX 首先,你需要确保已经安装了OpenCV和ONNX。可以通过以下命令来安装:

pip install opencv-python
pip install onnx

步骤2: 转换YOLOv5-CLS为ONNX格式 在这一步,我们将使用YOLOv5的官方代码库将YOLOv5-CLS模型转换为ONNX格式。请按照以下步骤进行操作:

  1. 克隆YOLOv5的官方代码库:
    git clone https://github.com/ultralytics/yolov5.git
    
  2. 进入yolov5目录,并下载预训练的YOLOv5-CLS模型权重:
    cd yolov5
    wget https://github.com/ultralytics/yolov5/releases/download/v5.0/yolov5s6.pt
    
  3. 运行export.py脚本来将模型转换为ONNX格式:
    python export.py --weights yolov5s6.pt --include onnx --img 640
    

    此步骤将生成一个名为'yolov5s6.onnx'的文件,这就是我们要使用的YOLOv5-CLS模型的ONNX版本。

    步骤3: 使用OpenCV DNN进行推理 现在,我们已经准备好进行推理了。下面是一个简单的示例代码,展示了如何使用OpenCV DNN库加载和运行YOLOv5-CLS模型:

    import cv2
    
    # 加载YOLOv5-CLS模型
    net = cv2.dnn.readNetFromONNX("yolov5s6.onnx")
    
    # 加载图像
    image = cv2.imread("test.jpg")
    
    # 创建blob并设置输入
    blob = cv2.dnn.blobFromImage(image, 1/255., (640, 640), swapRB=True)
    net.setInput(blob)
    
    # 进行推理
    output = net.forward()
    
    # 解析推理结果
    classes = open("coco.names").read().strip().split("\n")
    for detection in output[0, 0]:
        scores = detection[5:]
        class_id = np.argmax(scores)
        confidence = scores[class_id]
        if confidence > 0.5:
            label = f"{classes[class_id]}: {confidence:.2f}"
            print(label)
    
    # 显示图像
    cv2.imshow("Image", image)
    cv2.waitKey(0)
    cv2.destroyAllWindows()
    

    请注意,上述代码中我们假设已经有一个名为'test.jpg'的测试图像和一个包含类别名称的 'coco.names' 文件。

    结论: 本文介绍了如何使用OpenCV DNN库来进行YOLOv5-CLS模型的推理。我们首先将YOLOv5-CLS模型转换为ONNX格式,然后使用OpenCV DNN库加载和运行该模型进行图像分类。通过按照本文提供的步骤和示例代码,你可以轻松地在实际应用中使用YOLOv5-CLS模型进行图像分类任务。文章来源地址https://www.toymoban.com/news/detail-559304.html

到了这里,关于使用OpenCV DNN推理YOLOv5-CLS转换后的ONNX分类模型的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • yolov5 opencv dnn部署 github代码

    源码地址 yolov5官网还提供的dnn、tensorrt推理链接 本人使用的opencv c++ github代码,代码作者非本人,也是上面作者推荐的链接之一 实现推理源码中作者的yolov5s.onnx 推理条件 实现推理code中作者的yolov5s.onnx windows 10 Visual Studio 2019 Nvidia GeForce GTX 1070 opencv 4.5.5、opencv4.7.0 (注意 4.7.0代码

    2024年01月23日
    浏览(39)
  • YOLOv5 实例分割 用 OPenCV DNN C++ 部署

    如果之前从没接触过实例分割,建议先了解一下实例分割的输出是什么。 实例分割两个关键输出是:mask系数、mask原型 本文参考自该项目(这么优秀的代码当然要给star!):GitHub - UNeedCryDear/yolov5-seg-opencv-onnxruntime-cpp: yolov5 segmentation with onnxruntime and opencv 目录 Pre: 一、代码总结

    2024年02月12日
    浏览(27)
  • 用opencv的DNN模块做Yolov5目标检测(纯干货,源码已上传Github)

    最近在微信公众号里看到多篇讲解yolov5在openvino部署做目标检测文章,但是没看到过用opencv的dnn模块做yolov5目标检测的。于是,我就想着编写一套用opencv的dnn模块做yolov5目标检测的程序。在编写这套程序时,遇到的bug和解决办法,在这篇文章里讲述一下。 在yolov5之前的yolov3和

    2024年02月02日
    浏览(37)
  • OpenCV DNN C++ 使用 YOLO 模型推理

    YOLO(You Only Look Once)是一种流行的目标检测算法,因其速度快和准确度高而被广泛应用。OpenCV 的 DNN(Deep Neural Networks)模块为我们提供了一个简单易用的 API,用于加载和运行预先训练的深度学习模型。本文将详细介绍如何使用 OpenCV 的 DNN 模块来进行 YOLOv5 的目标检测。 确保

    2024年02月08日
    浏览(28)
  • Yolov5口罩佩戴实时检测项目(模型剪枝+opencv+python推理)

    如果只是想体验项目,请直接跳转到本文第2节,或者跳转到我的facemask_detect。 剪枝的代码可以查看我的github:yolov5-6.2-pruning 第1章是讲述如何得到第2章用到的onnx格式的模型文件(我的项目里直接提供了这个文件)。 第2章开始讲述如何使用cv2.dnn加载onnx文件并推理yolov5n模型

    2023年04月08日
    浏览(34)
  • yolov5-6.0项目部署+自用Pytorch模型转换rknn模型并在RK3568 linux(Debian)平台上使用qt部署使用NPU推理加速摄像头目标识别详细新手教程

    1 我们打开yolov的官网,Tags选择6.0版本 2. 下载该压缩包并解压到工程目录下 3. 我们这里使用pycharm,专门针对python的IDE,用起来非常方便,下载方式就是官网直接下载,用的是社区版 4. 我们需要安装环境,这里我推荐安装Anaconda在电脑上,这是一个非常方便的包管理工具,可

    2024年02月05日
    浏览(52)
  • 基于树莓派Qt+opencv+yolov5-Lite+C++部署深度学习推理

            本文是基于 qt和opencv的dnn 深度学习推理模块,在树莓派上部署YOLO系列推理,适用于yolov5-6.1以及yolov5-Lite,相比直接用python的onnxruntime,用基于opencv的dnn模块,利用训练生成的onnx模型,即可快速部署,不需要在树莓派上额外安装深度学习的一系列环境,因为我们知道

    2024年04月16日
    浏览(53)
  • yolov5的运行环境配置、参数修改和训练命令,并将训练的pt模型转换为rknn模型,并推理

    目录 一.yolov5的运行环境配置(Windows系统) 1、NVIDIA驱动安装与更新  2、Anaconda 的安装 3、Pytorch环境安装  4、pycharm安装 二.yolov5训练数据集,得到best.pt(Windows系统)  1.下载YOLO项目代码  2.环境安装 3. 数据集下载: 三.best.pt转为onnx模型(Windows系统) 四.best.onnx转为best.rknn模型(Linu

    2024年02月13日
    浏览(37)
  • YOLOV5应用实战项目:钢材表面缺陷检测(数据集:NEU-CLS)笔记

    本文记录的是YOLOV5的实战笔记,是一个用yolov5检测钢材表面缺陷的实战案例。 主要分为以下几个步骤: 1. 将原始标签xml文件数据处理成yolo要求的txt格式;(Labels标签数据已按照yolo要求的txt格式处理完成,数据集见文中下载方式) 2. 进行yolo模型的文件配置 3. 训练yolo模型

    2024年02月04日
    浏览(34)
  • 申威芯片UOS中opencv DNN推理

    在opencvdnn工程中:

    2024年02月09日
    浏览(30)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包