Pytorch模型转onnx模型2

import io
import numpy as np
import torch
import torch.onnx
from model.nets.yolo4 import YoloBody
from conf.my_conf import anchors_path, classes_path, model_path_train


weight_file = '../data/weights/Epoch75-Total_Loss1.3492-Val_Loss3.9141.pth'
image_path = '../data/img/wastebag/0004.jpg'
onnx_file_name = '../data/weights/Yolo.onnx'
batch_size = 1
num_anchors, num_classes = 3, 2
IN_IMAGE_H = 416
IN_IMAGE_W = 416


model = YoloBody(num_anchors, num_classes)
device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")

# 加快模型训练的效率
model_dict = model.state_dict()
pretrained_dict = torch.load(weight_file, map_location=device)
pretrained_dict = {k: v for k, v in pretrained_dict.items() if np.shape(model_dict[k]) == np.shape(v)}
model_dict.update(pretrained_dict)
model.load_state_dict(model_dict)

dummy_input1 = torch.randn((1, 3, IN_IMAGE_H, IN_IMAGE_W), requires_grad=True)
input_names = ["input"]  # onnx输入接口的名字,需要与模型输入结果对应
output_names = ["output0", "output1", "output2"]  # onnx输出接口的名字,需要与模型输出结果对应
dynamic_axes = {"input": {0: "batch_size"}, "output0": {0: "batch_size"}, "output1": {0: "batch_size"}, "output2": {0: "batch_size"}}


torch.onnx.export(model,
                  dummy_input1,
                  onnx_file_name,
                  export_params=True,
                  opset_version=11,
                  do_constant_folding=True,
                  input_names=input_names,
                  output_names=output_names,
                  dynamic_axes=dynamic_axes)

注:要修改num_anchors, num_classes, IN_IMAGE_H, IN_IMAGE_W,input_names, output_names
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容