yolact模型推理导出ONNX环境搭建

2024-04-26 03:18

本文主要是介绍yolact模型推理导出ONNX环境搭建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文使用的anaconda安装版本是:

anaconda下keras&tensorflow @ubuntu18.04开发环境安装_tugouxp的专栏-CSDN博客前面尝试在windows10上安装keras&tensorflow开发环境,总体上感觉还是比较麻烦的,今天抽时间在ubuntu18.04上安装了一把,很快就搞定了回归训练的模型,发现anaconda对Linux环境是比较友好的,以后可以在Linux下干活了。现在简要介绍一下搭建环境并执行回归训练用例的过程下载anaconda我选择的版本是https://repo.anaconda.com/archive/Anaconda3-2020.11-Linux-x86_64.shhttps:/https://blog.csdn.net/tugouxp/article/details/120464891?spm=1001.2014.3001.5502yolact下载地址:

git clone https://github.com/dbolya/yolact.git

安装环境:

cd yolact,执行

conda env create -f environment.yml

下载模型权重:

运行测试用例:

python eval.py --trained_model=weights/yolact_base_54_800000.pth --score_threshold=0.15 --top_k=15 --images=/home/czl/images/:/home/czl/out

添加上--cuda=False也于事无补。

python -m eval --trained_model=./weights/yolact_darknet53_54_800000.pth --cuda=False --score_threshold=0.4 --top_k=15 --display --image=/home/caozilong/darknet/data/dog.jpg:output3.jpg

似乎走到的死胡同。

由于我们下载的是非GPU版本的pytorch,所以出现了上图中的错误,接下来换一套CPU版本的yolact环境尝试一下,yolact CPU版本的实现在另一个地址:

git clone -b add-evaluation-without-cuda-support https://github.com/ar90n/yolact.git

 将权重文件拷贝过来:

执行conda activate yolact-env激活anaconda yolact环境,再次执行命令:

python -m eval --trained_model=./weights/yolact_darknet53_54_800000.pth --cuda=False --score_threshold=0.4 --top_k=15 --display --image=/home/caozilong/darknet/data/dog.jpg:output3.jpg

命令成功执行,输出的图片为output3.jpg,打开后结果如下:

换一张图片测试:

python -m eval --trained_model=./weights/yolact_darknet53_54_800000.pth --cuda=False --score_threshold=0.4 --top_k=15 --display --image=/home/caozilong/Workspace/ncnn-origin/ncnn/build/examples/beauty.jpg:girl.jpeg

 针对这张图片的召回率和精度有些问题,只框出了一位美女,并且手机也识别错了。

图像:

car.jpeg

导出ONNX模型

根据网上的资料,将代码修改后导出ONNX模型:

diff --git a/eval.py b/eval.py
index e295093..10675d2 100644
--- a/eval.py
+++ b/eval.py
@@ -569,17 +569,19 @@ def evalimage(net:Yolact, path:str, save_path:str=None):batch = FastBaseTransform()(frame.unsqueeze(0))preds = net(batch)-    img_numpy = prep_display(preds, frame, None, None, undo_transform=False)
-    
-    if save_path is None:
-        img_numpy = img_numpy[:, :, (2, 1, 0)]
+    torch.onnx._export(net, batch, "yolact.onnx", export_params=True, keep_initializers_as_inputs=True, opset_version=11)-    if save_path is None:
-        plt.imshow(img_numpy)
-        plt.title(path)
-        plt.show()
-    else:
-        cv2.imwrite(save_path, img_numpy)
+    # img_numpy = prep_display(preds, frame, None, None, undo_transform=False)
+
+    # if save_path is None:
+        # img_numpy = img_numpy[:, :, (2, 1, 0)]
+
+    # if save_path is None:
+        # plt.imshow(img_numpy)
+        # plt.title(path)
+        # plt.show()
+    # else:
+        # cv2.imwrite(save_path, img_numpy)def evalimages(net:Yolact, input_folder:str, output_folder:str):if not os.path.exists(output_folder):
diff --git a/yolact.py b/yolact.py
index c1a5b3f..d45d2c0 100644
--- a/yolact.py
+++ b/yolact.py
@@ -23,7 +23,8 @@ if torch.cuda.is_available():torch.cuda.current_device()# As of March 10, 2019, Pytorch DataParallel still doesn't support JIT Script Modules
-use_jit = not torch.cuda.is_available() or torch.cuda.device_count() <= 1
+#use_jit = not torch.cuda.is_available() or torch.cuda.device_count() <= 1
+use_jit = Falseif not use_jit:print('Multiple GPUs detected! Turning off JIT.')@@ -616,7 +617,7 @@ class Yolact(nn.Module):else:pred_outs['conf'] = F.softmax(pred_outs['conf'], -1)-            return self.detect(pred_outs)
+            return pred_outs

之后运行命令:

python -m eval --trained_model=./weights/yolact_darknet53_54_800000.pth --cuda=False --score_threshold=0.4 --top_k=15 --display --image=/home/caozilong/car.jpeg:car.jpeg

最终生成了ONNX格式的YOLACT模型文件:

端侧部署

将上一步生成的yolact.onnx模型部署到某款NPU上,仿真端跑出的结果,与原来相比,精度略有损失.

而且看trunk目标,显然存在这个区域内识别除了两个目标,从打印也可以看出来:

 可以看到,还有一个置信度为57%的目标被识别出来,这就很奇怪了,从绘制的框可以看出,很明显两个框的IOU已经非常非常高了,几乎重合,不仔细看几乎看不出来是两个框,为何NMS去重时没有去掉其中一个呢?

原来NMS去重的前提是识别的是同一类目标,如果目标不是同一类,即便两个框完全一样,也是都要数出来的.根据上图的打印可以看出,这个范围识别出来的两个目标class id是不同的,分别是3和8,这就不足为奇了。

如何提高精度:

RGB数据送入网络前,要经过前处理归一化,之后再进行量化,所以,送入网络的是量化的数据。这里面可以操作的是归一化参数,上面的推理,我们默认使用了归一化参数为 0 和 0.0039,这样0-256范围的RGB数据经过处理后变为了0-1区间,效果既然不好,我们重新调整参数,另一个普遍被使用的归一化系数(实际上由训练的数据集决定)为:103.94, 116.78, 123.68. 0.017423.我们用它进行尝试:

置信度大大提高,狗的的识别出现了误识别情况,这可能和我导出的模型有关了。

关于这些归一化参数的来源,可以参考原始代码的config.py文件,可能yolact算法是基于imagenet数据集训练的吧。

pytorch模型格式

.pt,pth,.pkl是pytorch框架支持的输出模型格式,上面介绍的模型用的就是.pth格式的模型文件,如同onnx模型一样,.pth模型也是权重和模型结构描述保存在同一个文件中的。利用netron工具,可以直接打开.pth格式的模型文件,比如,github中的yolact模型实际上提供好几个模型文件,它们的主要区别是模型主干结构不同.

貌似对PTH的支持并不友好,实际上,netron官网给出的支持列表并不包含.pth文件,而是给出的.pt文件,.pt文件是可以看到层间的连接关系的.

这样也可以理解一个问题,就是芯原微的部署工具不支持.pth,但是支持.pt,.pth的模型需要先转换成.pt,才能被部署工具导入,或许原因就在于此吧。

使用其余模型进行推理:

python -m eval --trained_model=./weights/yolact_base_54_800000.pth --cuda=False --score_threshold=0.4 --top_k=15 --display --image=/home/caozilong/car.jpeg:car.jpeg

 模型文件yolact_im700_54_800000.pth

python -m eval --trained_model=./weights/yolact_im700_54_800000.pth --cuda=False --score_threshold=0.4 --top_k=15 --display --image=/home/caozilong/car.jpeg:car.jpeg

yolact_resnet50_54_800000.pth

python -m eval --trained_model=./weights/yolact_resnet50_54_800000.pth --cuda=False --score_threshold=0.4 --top_k=15 --display --image=/home/caozilong/car.jpeg:car.jpeg


结束~! 

这篇关于yolact模型推理导出ONNX环境搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/936576

相关文章

python项目环境切换的几种实现方式

《python项目环境切换的几种实现方式》本文主要介绍了python项目环境切换的几种实现方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 如何在不同python项目中,安装不同的依赖2. 如何切换到不同项目的工作空间3.创建项目

C++多线程开发环境配置方法

《C++多线程开发环境配置方法》文章详细介绍了如何在Windows上安装MinGW-w64和VSCode,并配置环境变量和编译任务,使用VSCode创建一个C++多线程测试项目,并通过配置tasks.... 目录下载安装 MinGW-w64下载安装VS code创建测试项目配置编译任务创建 tasks.js

使用C#导出Excel数据并保存多种格式的完整示例

《使用C#导出Excel数据并保存多种格式的完整示例》在现代企业信息化管理中,Excel已经成为最常用的数据存储和分析工具,从员工信息表、销售数据报表到财务分析表,几乎所有部门都离不开Excel,本文... 目录引言1. 安装 Spire.XLS2. 创建工作簿和填充数据3. 保存为不同格式4. 效果展示5

Java领域模型示例详解

《Java领域模型示例详解》本文介绍了Java领域模型(POJO/Entity/VO/DTO/BO)的定义、用途和区别,强调了它们在不同场景下的角色和使用场景,文章还通过一个流程示例展示了各模型如何协... 目录Java领域模型(POJO / Entity / VO/ DTO / BO)一、为什么需要领域模

MongoDB搭建过程及单机版部署方法

《MongoDB搭建过程及单机版部署方法》MongoDB是一个灵活、高性能的NoSQL数据库,特别适合快速开发和大规模分布式系统,本文给大家介绍MongoDB搭建过程及单机版部署方法,感兴趣的朋友跟随... 目录前言1️⃣ 核心特点1、文档存储2、无模式(Schema-less)3、高性能4、水平扩展(Sh

深入理解Redis线程模型的原理及使用

《深入理解Redis线程模型的原理及使用》Redis的线程模型整体还是多线程的,只是后台执行指令的核心线程是单线程的,整个线程模型可以理解为还是以单线程为主,基于这种单线程为主的线程模型,不同客户端的... 目录1 Redis是单线程www.chinasem.cn还是多线程2 Redis如何保证指令原子性2.

一篇文章彻底搞懂macOS如何决定java环境

《一篇文章彻底搞懂macOS如何决定java环境》MacOS作为一个功能强大的操作系统,为开发者提供了丰富的开发工具和框架,下面:本文主要介绍macOS如何决定java环境的相关资料,文中通过代码... 目录方法一:使用 which命令方法二:使用 Java_home工具(Apple 官方推荐)那问题来了,

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

idea+spring boot创建项目的搭建全过程

《idea+springboot创建项目的搭建全过程》SpringBoot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,:本文主要介绍idea+springb... 目录一.idea四种搭建方式1.Javaidea命名规范2JavaWebTomcat的安装一.明确tomcat