位置: IT常识 - 正文

基于OpenVINO在C++中部署YOLOv5-Seg实例分割模型(openvino使用)

编辑:rootadmin
基于OpenVINO在C++中部署YOLOv5-Seg实例分割模型

推荐整理分享基于OpenVINO在C++中部署YOLOv5-Seg实例分割模型(openvino使用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:openvino opencl,openvino使用,openvino使用,基于c++的opencv,openvino opencl,openvino开发语言,openvino教程,openvino开发语言,内容如对您有帮助,希望把文章链接给更多的朋友!

作者:英特尔物联网行业创新大使  王一凡 

目录

1.1 配置OpenVINO C++开发环境

1.2 下载并转换YoLOv5预训练模型

1.3 使用OpenVINO Runtime C++API编写推理程序

1.3.1 采集图像&图像解码

 1.3.2 YoLOv5-Seg模型的图像预处理

1.3.3 执行AI推理计算

1.3.4 推理结果进行后处理 

1.4 总结


        YOLOv5兼具速度和精度,工程化做的特别好,Git clone到本地即可在自己的数据集上实现目标检测任务的训练和推理,在产业界中应用广泛。开源社区对YOLOv5支持实例分割的呼声高涨,YOLOv5在v7.0中正式官宣支持实例分割。

        在前期文章中,已发布基于OpenVINO的YOLOv5模型的Python版本和C++版本推理程序,以及YOLOv5-Seg模型的Python版推理程序,本文主要介绍在C++中使用OpenVINO工具包部署YOLOv5-Seg模型,主要步骤有:

配置OpenVINO C++开发环境下载并转换YOLOv5-Seg预训练模型使用OpenVINO Runtime C++ API编写推理程序

下面,本文将依次详述

1.1 配置OpenVINO C++开发环境

        配置OpenVINO C++开发环境的详细步骤,请参考《在Windows中基于Visual Studio配置OpenVINO C++开发环境》。

1.2 下载并转换YoLOv5预训练模型

        下载并转换YOLOv5-seg预训练模型的详细步骤,请参考:《在英特尔独立显卡上部署YOLOv5 v7.0版实时实例分割模型》,本文所使用的OpenVINO是2022.3 LTS版。

首先,运行命令获得 yolov5s-seg ONNX 格式模型:yolov5s-seg.onnx:

python export.py --weights yolov5s-seg.pt --include onnx

然后运行命令获得yolov5s-seg IR格式模型:yolov5s-seg.xml和yolov5s-seg.bin,如下图所示

mo -m yolov5s-seg.onnx --compress_to_fp16

图 1-1  yolov5-seg ONNX格式和IR格式模型

1.3 使用OpenVINO Runtime C++API编写推理程序

一个端到端的AI推理程序,主要包含五个典型的处理流程:

采集图像&图像解码图像数据预处理AI推理计算对推理结果进行后处理将处理后的结果集成到业务流程

图 1-2  端到端的AI推理程序处理流程

1.3.1 采集图像&图像解码

OpenCV提供imread()函数将图像文件载入内存,

Mat cv::imread (const String &filename, int flags=IMREAD_COLOR)

         若是从视频流(例如,视频文件、网络摄像头、3D摄像头(Realsense)等)中,一帧一帧读取图像数据到内存,则使用cv::VideoCapture类,对应范例代码请参考OpenCV官方范例代码:opencv/samples/cpp at 4.x · opencv/opencv · GitHub。

基于OpenVINO在C++中部署YOLOv5-Seg实例分割模型(openvino使用)

图 1-3 从视频流读取图像帧范例

 1.3.2 YoLOv5-Seg模型的图像预处理

        YOLOv5-Seg模型构架是在YOLOv5模型构架基础上,增加了一个叫“Proto”的小型卷积神经网络,用于输出检测对象掩码(Mask),如下图所示:

图 1-4  YOLOv5-Seg模型输出的代码定义

详细参看:https://github.com/ultralytics/yolov5/blob/master/models/yolo.py#L92

        由此可知,YOLOv5-Seg模型对数据预处理的要求跟YOLOv5模型一模一样,YOLOv5-Seg模型的预处理代码可以复用YOLOv5模型的C++预处理代码。

        另外,从代码可以看出YOLOv5-Seg模型的输出有两个张量,一个张量输出检测结果,一个张量输出proto,其形状可以用Netron打开yolov5-seg.onnx查知,如下图所示。

图 1-5  YOLOv5-Seg模型的输入和输出

        “output0”是检测输出,第一个维度表示batch size,第二个维度表示25200条输出,第三个维度表示有117个字段,其中前85个字段(0~84)表示:cx、cy、w、h、confidence和80个类别分数,后32个字段与”output1”做矩阵乘法,可以获得尺寸为160x160的检测目标的掩码(mask),如下图所示。

图 1-6  检测目标的掩码

1.3.3 执行AI推理计算

        基于OpenVINO Runtime C++ API实现AI推理计算主要有两种方式:一种是同步推理方式,一种是异步推理方式,本文主要介绍同步推理方式。

主要步骤有:

初始化Core类:ov::Core core;编译模型:core.compile_model()创建推理请求infer_request:compiled_model.create_infer_request()读取图像数据并做预处理:letterbox()将预处理后的blob数据传入模型输入节点:infer_request.set_input_tensor()调用infer()方法执行推理计算:infer_request.infer()获得推理结果:infer_request.get_output_tensor()

基于OpenVINO Runtime C++API的同步推理代码如下所示:

// -------- Step 1. Initialize OpenVINO Runtime Core -------- ov::Core core; // -------- Step 2. Compile the Model -------- auto compiled_model = core.compile_model(model_file, "GPU.1"); //GPU.1 is dGPU A770 // -------- Step 3. Create an Inference Request -------- ov::InferRequest infer_request = compiled_model.create_infer_request(); // -------- Step 4. Read a picture file and do the preprocess -------- cv::Mat img = cv::imread(image_file); //Load a picture into memory std::vector<float> paddings(3); //scale, half_h, half_w cv::Mat resized_img = letterbox(img, paddings); //resize to (640,640) by letterbox // BGR->RGB, u8(0-255)->f32(0.0-1.0), HWC->NCHW cv::Mat blob = cv::dnn::blobFromImage(resized_img, 1 / 255.0, cv::Size(640, 640), cv::Scalar(0, 0, 0), true); // -------- Step 5. Feed the blob into the input node of YOLOv5 ------- // Get input port for model with one input auto input_port = compiled_model.input(); // Create tensor from external memory ov::Tensor input_tensor(input_port.get_element_type(), input_port.get_shape(), blob.ptr(0)); // Set input tensor for model with one input infer_request.set_input_tensor(input_tensor); // -------- Step 6. Start inference -------- infer_request.infer(); // -------- Step 7. Get the inference result -------- auto detect = infer_request.get_output_tensor(0); auto detect_shape = detect.get_shape(); std::cout << "The shape of Detection tensor:"<< detect_shape << std::endl; auto proto = infer_request.get_output_tensor(1); auto proto_shape = proto.get_shape();std::cout << "The shape of Proto tensor:" << proto_shape << std::endl;1.3.4 推理结果进行后处理 

        后处理工作主要是从”detect ”输出张量中拆解出检测框的位置和类别信息,并用cv::dnn::NMSBoxes()过滤掉多于的检测框;从”detect ”输出张量的后32个字段与”proto”输出张量做矩阵乘法,获得每个检测目标的形状为160x160的掩码输出,最后将160x160的掩码映射回原始图像完成所有后处理工作。

        完整的代码实现,请下载:https://gitee.com/ppov-nuc/yolov5_infer/blob/main/yolov5seg_openvino_dGPU.cpp

1.4 总结

    配置OpenVINO C++开发环境后,可以直接编译运行yolov5seg_openvino_dGPU.cpp,结果如下图所示。使用OpenVINO Runtime C++ API函数开发YOLOv5推理程序,简单方便,并可以任意部署在英特尔CPU、集成显卡和独立显卡上。

图 1-7 运行结果

本文链接地址:https://www.jiuchutong.com/zhishi/295899.html 转载请保留说明!

上一篇:Vue--》探索Pinia:Vue状态管理的未来(vue .find)

下一篇:基于web的网上图书商城的设计与实现/图书购物系统(基于web的网站设计与实现)

  • 提升企业网站优化排名实用的方法(企业网站优化解决方案)

    提升企业网站优化排名实用的方法(企业网站优化解决方案)

  • 华为5g双模手机有什么好处(华为5g双模手机是什么意思)

    华为5g双模手机有什么好处(华为5g双模手机是什么意思)

  • 抖音怎么转发别人作品(抖音怎么转发别人的作品是小框了)

    抖音怎么转发别人作品(抖音怎么转发别人的作品是小框了)

  • 施乐2520感光鼓怎么清零(施乐2520感光鼓寿命到期 091-401)

    施乐2520感光鼓怎么清零(施乐2520感光鼓寿命到期 091-401)

  • wps脚注上面的横线怎么加(wps脚注上面的横线打印不出来)

    wps脚注上面的横线怎么加(wps脚注上面的横线打印不出来)

  • 东芝a3和v9有什么区别(东芝a3和v9v10哪个产品新)

    东芝a3和v9有什么区别(东芝a3和v9v10哪个产品新)

  • 华为p30修改定位虚拟位置(华为p30怎么修改位置)

    华为p30修改定位虚拟位置(华为p30怎么修改位置)

  • 华为p40pro扫描功能在哪里(华为p40的扫描文件功能怎么开启?)

    华为p40pro扫描功能在哪里(华为p40的扫描文件功能怎么开启?)

  • 红米k30pro上市日期(红米k30pro手机上市时间)

    红米k30pro上市日期(红米k30pro手机上市时间)

  • upupoo动态壁纸怎么用不了(upupoo动态壁纸怎么设置成电脑壁纸)

    upupoo动态壁纸怎么用不了(upupoo动态壁纸怎么设置成电脑壁纸)

  • 头条关注和粉丝的区别(头条关注粉丝数据存储结构)

    头条关注和粉丝的区别(头条关注粉丝数据存储结构)

  • 苹果国行资源机是什么意思(苹果国行资源机和国行区别)

    苹果国行资源机是什么意思(苹果国行资源机和国行区别)

  • 红米note8pro怎么设置通知亮屏(红米note8pro怎么开小窗)

    红米note8pro怎么设置通知亮屏(红米note8pro怎么开小窗)

  • 抖音怎么删作品(抖音怎么删作品不会被降权)

    抖音怎么删作品(抖音怎么删作品不会被降权)

  • 华为手机怎么设置锁屏(华为手机怎么设置高清通话功能)

    华为手机怎么设置锁屏(华为手机怎么设置高清通话功能)

  • 红米手机如何截长图(红米手机如何截长屏图片)

    红米手机如何截长图(红米手机如何截长屏图片)

  • 支付宝人脸识别怎么关闭(支付宝人脸识别怎么切换摄像头)

    支付宝人脸识别怎么关闭(支付宝人脸识别怎么切换摄像头)

  • 苹果11pro有3dtouch吗(苹果11Pro有口罩识别嘛)

    苹果11pro有3dtouch吗(苹果11Pro有口罩识别嘛)

  • 华为mate20是曲面屏吗(华为曲面屏mate20pro)

    华为mate20是曲面屏吗(华为曲面屏mate20pro)

  • iwatch一二三代的区别(iwatch二代和三代的区别)

    iwatch一二三代的区别(iwatch二代和三代的区别)

  • lndal30华为什么型号(华为lndal30价格多少)

    lndal30华为什么型号(华为lndal30价格多少)

  • vivox23可以遥控空调吗(vivox23可以使用万能遥控器吗)

    vivox23可以遥控空调吗(vivox23可以使用万能遥控器吗)

  • 小米9充电发热怎么回事(小米9充电发热严重怎么办)

    小米9充电发热怎么回事(小米9充电发热严重怎么办)

  • xs原装充电器太慢了(iphone xs原装充电器)

    xs原装充电器太慢了(iphone xs原装充电器)

  • 艾叶泡脚的方法(艾叶泡脚的方法和注意事项)

    艾叶泡脚的方法(艾叶泡脚的方法和注意事项)

  • 城建税和教育费附加减免政策
  • 税控盘没有清卡,反写怎么办
  • 交通运输印花税怎么申报
  • 进口增值税可以抵税吗
  • 增值税专用发票电子版
  • 退回多打货款分录
  • 营业收入利润率多少合适
  • 采购工程物资会议纪要
  • 学校管理费是什么意思
  • 养牛场增值税的税率是多?
  • 变更财务负责人在网上变更流程
  • 小规模纳税人代理记账流程
  • 借壳上市是什么意思?融资
  • 增值税电子发票没有发票专用章
  • 给客户打折账务处理
  • 重庆增值税税率调整
  • 历年亏损企业开什么发票
  • 持有至到期投资账务处理
  • 人工装卸怎么办营业执照
  • 广告公司文化事业费怎么交
  • 软件存在的意义
  • PHP:mb_http_input()的用法_mbstring函数
  • 企业职工福利费的扣除标准是多少?
  • 图文详解:台盆柜安装的全过程
  • php面向对象编程学生类
  • 电和电能是什么关系
  • 企业购入设备涉及的税种
  • 房地产预售收入如何缴纳所得税
  • php strlen函数
  • 如何修改家里的wifi密码
  • 职工工伤住院费用记什么科目
  • 自然保护绘画
  • 稳岗补贴怎么发放给员工
  • php操作excel
  • 专票如何申领
  • layui 安卓
  • js遇到的问题
  • 公司采购一直没走对公付款怎么处理
  • 个人社保进费用,还要报个税么
  • phpcms怎么用
  • 织梦商城网站源码
  • pos机到账流水算个人收入吗
  • 代开运输发票会不会造成重复征税
  • 小企业会计准则适用于哪些企业
  • 资产合计是期末余额吗
  • 汇兑损益一级科目
  • mysql数据表分区
  • 政府补助如何确定收入
  • 咨询服务业优惠政策
  • 事业单位未取得相关证书不予受理
  • 收到所得税退税怎么做账务处理
  • 视同销售的账务处理如何做?
  • 软件企业确认收入
  • 固定资产售后回租融资租赁利息可以抵扣进项税额么
  • 挂靠地址如果被查了应该怎么处理?
  • 转账支票怎么填写会计凭证
  • 暂估材料发票长期不到
  • 获取sqlsession
  • 表空间 数据库
  • mysql 死锁解决
  • 服务器 安装win10
  • win8怎么彻底删除软件
  • linux svn操作
  • RHEL5 Apache+Tomcat整合,同时支持jsp与php
  • ubuntu系统如何设置永不休眠
  • win7玩穿越火线电脑应该怎么设置
  • macos 安装win7
  • Win10 Redstone版Build 14251现身 正式版将在7月份发布
  • 实例讲解命局与大运流年作用
  • 贴吧热门评论
  • 深入理解ffmpeg pdf
  • 动态修改ip
  • python访问地址
  • jQuery EasyUI datagrid在翻页以后仍能记录被选中行的实现代码
  • SQLite之SQLiteStatement
  • 噼里啪啦财务公司加盟
  • 广东省地方税务局历任局长
  • 电子税务局网上实名认证流程
  • 一般纳税人税务事项告知书在哪里打
  • 2016年营改增房屋租赁
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设