将yolov8权重文件转为onnx格式并在c#中使用

yolo模型转ONNX

在yolov8中,我们将训练结果的.pt权重文件转换为onnx格式只需要使用ultralytics库中的YOLO类,使用pip安装ultralytics库,然后执行下面python代码

from ultralytics import YOLO

# 加载YOLOv8模型
model = YOLO("best.pt")

# 将模型导出为ONNX格式
success = model.export(format="onnx", simplify=True)

# 检查是否成功导出
assert success

 此程序就会加载当前根目录下的best.pt并转换为ONNX格式进行导出

 C#中使用ONNX

创建一个.NET 8.0的项目,因为自己写比较繁琐,我们直接使用封装好的Nuget包YoloDotNet

地址:NuGet Gallery | YoloDotNet 1.2.0

安装Nuget包命令

NuGet\Install-Package YoloDotNet -Version 1.2.0

这个包比较大,安装时间可能有点久,耐心等待!!!

 安装完成后,我们通过如下代码读取ONNX文件,下面代码中创建yolo实例有两个构造函数的参数,第一个就是onnx文件的地址,第二个就是你是否使用GPU来进行识别,如果你的电脑有装英伟达的GPU并且按照了cuda,就设置为true。我的电脑没有,所有只能使用cpu来跑,因此我设置为false

new Yolo(@"D:\best.onnx", false);

 然后就是读取你的图片,调用yolo的RunObjectDetection,将图片作为第一个参数,第二个参数就是识别的阈值

using var image = Image.Load<Rgba32>(@"D:\testphoto\1.jpg");
var results = yolo.RunObjectDetection(image, 0.3); 

 如果你的模型不是目标检测,而是图像分类或者其他,可以使用yolo的其他方法

 然后就是将识别图片结果保存本地了,下面是示例的所有代码

class Program
{
    public static void Main(string[] args)
    {
        using var yolo = new Yolo(@"D:\best.onnx", false);
        using var image = Image.Load<Rgba32>(@"D:\testphoto\1.jpg");
        var results = yolo.RunObjectDetection(image, 0.3); 

        image.Draw(results);
        image.Save(@"D:\testphoto\2.jpg");
    }
}

 下图是我识别出的结果

 这个模型是我上一篇博客中使用python网络爬虫爬取的400多张皮卡丘图片继续标注后,训练出来的模型,我已经将原图和标注文件已经上面演示的.pt权重文件和onnx文件都上传到资源中,有需要的可自取👇

 https://download.csdn.net/download/weixin_65243968/88856521

  • 6
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱吃香蕉的阿豪

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值