PyTorch加载预训练目标检测模型实现物体检测,同时将预训练模型转换为ONNX模型文件(过程详解)

21 篇文章 9 订阅

B站视频讲解

GitHub源码

目标检测
PyTorch实现一个简单的图像分类(代码详细)
PyTorch 训练之后的网络模型.pth转.onnx文件并对图像进行预测
使用pytorch实现预训练模型迁移学习中的目标检测

本文主要是直接利用PyTorch官方提供的预训练目标检测模型对物体进行检测,在此之前使用pytorch实现预训练模型迁移学习中的目标检测 已经提及使用官方提供的预训练目标检测模型进行迁移训练自己的目标检测模型,这篇文章之所以再次提及主要是更加仔细的对其进行实现以及ONNX模型文件的转换,为后面目标检测模型在QT中基于OpenCV的使用打下基础。

1.直接加载预训练目标检测模型进行物体检测 

注:如果不进行ONNX模型文件的转换的话,ssdlite320_mobilenet_v3_largessd300_vgg16fcos_resnet50_fpn 模型都是可以图像或者实时检测的,但是如果要转换为ONNX模型文件的话,其中ssdlite320_mobilenet_v3_largessd300_vgg16 会转换失败,会报以下错误(未解决):因此,本文只对fcos_resnet50_fpn 模型转换为ONNX文件。

onnxruntime.capi.onnxruntime_pybind11_state.Fail: [ONNXRuntimeError] : 
1 : FAIL : Non-zero status code returned while running TopK node. Name:
'TopK_2830' Status Message: k argument [16] should not be greater than 
specified axis dim value [0]

关于这个问题的讨论:https://github.com/microsoft/onnxruntime/issues/12669

FCOS2020

FCOS2019

注:关于NMS算法读者直接在B站上搜索即可知道其原理(过滤掉重叠的框,根据指定的阈值iou_threshold,如果一个框和当前类别置信度最大的框重叠比例大于等于iou_threshold就丢弃该框,保留置信度最大的框)

2.加载ONNX目标检测模型进行物体检测

目标检测拓展
两款IP Camera+YOLOV3进行目标检测(手机摄像头作为电脑摄像头使用)
使用pytorch实现预训练模型迁移学习中的目标检测
使用MobileNet_SSD进行目标检测
Opencv实现目标检测
目标检测算法(开端)
图像分类,图像识别,目标检测之间的区别
基于darknet框架+yolov3训练自己的数据集
windows平台使用CMake工具对darknet的编译以及安装过程+yolov3+图像检测+摄像头检测+视频检测+手机作为摄像头进行检测(详解)
两款IP Camera+YOLOV3进行目标检测(手机摄像头作为电脑摄像头使用)
YOLO-V3实时检测实现(opencv+python实现)——改进——>更加的易懂
YOLO-V3实时检测实现(opencv+python实现)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值