【模型部署入门 一】:Pytorch图像分类模型转换ImageNet1000类预训练模型转ONNX

本文主要是介绍【模型部署入门 一】:Pytorch图像分类模型转换ImageNet1000类预训练模型转ONNX,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

入门学习主要是跟随同济子豪兄,很感谢该博主,本博客代码主体是子豪兄的,我只是总结加工整理记录。

子豪兄对应学习视频链接地址为:ImageNet1000类预训练模型转ONNX

我自己总结的教程中代码使用任何python编译环境都可以直接打开使用,子豪兄视屏教程中的源码需要使用Jupyter打开,关于Jupyter的安装及使用,推荐参考博客:Jupyter Notebook的安装及使用教程

目录

  • 一、安装配置环境
    • 1.1 安装Pytorch
    • 1.2 安装ONNX
    • 1.3 安装推理引擎ONNX Runtime
    • 1.4 安装其它包
    • 1.5 检验是否安装成功
    • 1.6 检验CUDA是否被调用
  • 二、ONNX官网
  • 三、ImageNet1000类预训练模型转ONNX
  • 四、可视化网络结构
  • 五、总结

一、安装配置环境

如果还没有安装CUDA,CUDNN,推荐安装教程:安装CUDA+CUDNN教程

1.1 安装Pytorch

pip install torch==1.8.1+cu111 torchvision==0.9.1+cu111 torchaudio==0.8.1 -f https://download.pytorch.org/whl/torch_stable.html

1.2 安装ONNX

pip install onnx -i https://pypi.tuna.tsinghua.edu.cn/simple

1.3 安装推理引擎ONNX Runtime

pip install onnxruntime -i https://pypi.tuna.tsinghua.edu.cn/simple

1.4 安装其它包

pip install numpy pandas matplotlib tqdm opencv-python pillow -i https://pypi.tuna.tsinghua.edu.cn/simple

1.5 检验是否安装成功

import torch
print('PyTorch 版本', torch.__version__)import onnx
print('ONNX 版本', onnx.__version__)import onnxruntime as ort
print('ONNX Runtime 版本', ort.__version__)

1.6 检验CUDA是否被调用

import torch# 检查GPU是否可用
if torch.cuda.is_available():print("PyTorch is using GPU")
else:print("PyTorch is using CPU")# 检查当前使用的GPU设备的索引
try:device_index = torch.cuda.current_device()print("Current GPU index: ", device_index)
except RuntimeError:print("No GPU available, using CPU")# 检查当前系统中可用的GPU设备数量
num_devices = torch.cuda.device_count()
print("Number of available GPUs: ", num_devices)

如果电脑GPU能被正常调用,运行代码后的输出如下:

在这里插入图片描述

二、ONNX官网

ONNX官网地址:ONNX

打开后的样子如下:

在这里插入图片描述

查看算子版本:

在这里插入图片描述

在这里插入图片描述

三、ImageNet1000类预训练模型转ONNX

下面代码中有详细注释,学者可直接运行使用。

import torch
from torchvision import models
import onnx## 有GPU就用GPU,无就用CPU
device = torch.device("cuda:0" if torch.cuda.is_available() else 'cpu')
print(torch.cuda.is_available())
print(device)## 载入ImageNet预训练Pytorch图像分类模型
model = models.resnet18(pretrained=True)      # 从PyTorch的模型库中加载一个预训练的ResNet-18模型。pretrained=True表示加载的模型已经在ImageNet数据集上进行了预训练
model = model.eval().to(device)               # 调用eval()方法将模型设置为评估模式。在评估模式下,模型的某些层(如Dropout层和BatchNorm层)会改变行为。然后,to(device)方法将模型移动到指定的设备上## 构造一个输入图像Tensor
x = torch.randn(1,3,256,256).to(device)
print(x.shape)     # torch.Size([1, 3, 256, 256])## 输入Pytorch模型推理预测,获得1000个类别的预测结果
output = model(x)  # 将随机张量x输入到模型中运行前向推理  output就是1000个类别的预测分数
print(output)
print(output.shape)     # torch.Size([1, 1000])## Pytorch模型转ONNX格式
with torch.no_grad():torch.onnx.export(model,                      # 要转换的模型x,                          # 模型的任意一组输入 张量的维度一定要和模型指定输入的维度一致'resnet18_imagenet.onnx',  # 导出的ONNX文件名,自定义名称opset_version = 11,         # ONNX 算子集版本,ONNC算子官网地址:https://onnx.ai/input_names = ['input'],    # 输入Tensor的名称   # 自定义名称output_names = ['output']   # 输出Tensor的名称   # 自定义名称)## 验证导出的onnx模型是否导出成功
onnx_model = onnx.load('resnet18_imagenet.onnx')   # 读取上一步导出的ONNX模型
onnx.checker.check_model(onnx_model)               # 检测模型格式是否正确print("恭喜你,ONNX模型载入成功!")## 以可读形式打印计算图
print(onnx.helper.printable_graph(onnx_model.graph))## 网页端打开
# 网址:https://netron.app/

运行上面代码后会在此代码的同级目录下生成一个.onnx文件,如下:

在这里插入图片描述

四、可视化网络结构

可视化网络结构,使用Netron,网址:Netron

打开后的样子如下:

在这里插入图片描述

打开本地网络结构有两种方法,一种是如上图所示,通过页面的open model选项打开,另一种是将.onnx文件直接拖到Netron页面中即可打开,打开后的样子如下:

在这里插入图片描述

通过上面方法就可以在Netron中直观的查看网络结构。

五、总结

以上就是Pytorch图像分类模型转换ImageNet1000类预训练模型转ONNX的详细过程,此系列持续更新中。

总结不易,多多支持,谢谢!

这篇关于【模型部署入门 一】:Pytorch图像分类模型转换ImageNet1000类预训练模型转ONNX的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

PyTorch中的词嵌入层(nn.Embedding)详解与实战应用示例

《PyTorch中的词嵌入层(nn.Embedding)详解与实战应用示例》词嵌入解决NLP维度灾难,捕捉语义关系,PyTorch的nn.Embedding模块提供灵活实现,支持参数配置、预训练及变长... 目录一、词嵌入(Word Embedding)简介为什么需要词嵌入?二、PyTorch中的nn.Em

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

从入门到进阶讲解Python自动化Playwright实战指南

《从入门到进阶讲解Python自动化Playwright实战指南》Playwright是针对Python语言的纯自动化工具,它可以通过单个API自动执行Chromium,Firefox和WebKit... 目录Playwright 简介核心优势安装步骤观点与案例结合Playwright 核心功能从零开始学习

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

MySQL 主从复制部署及验证(示例详解)

《MySQL主从复制部署及验证(示例详解)》本文介绍MySQL主从复制部署步骤及学校管理数据库创建脚本,包含表结构设计、示例数据插入和查询语句,用于验证主从同步功能,感兴趣的朋友一起看看吧... 目录mysql 主从复制部署指南部署步骤1.环境准备2. 主服务器配置3. 创建复制用户4. 获取主服务器状态5