代码拉取完成,页面将自动刷新
import torch
import argparse
import onnx_graphsurgeon as gs
import onnx
from onnx import shape_inference
from models.models import Darknet
if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('--weights', type=str, default="./runs/train/yolor_p6/weights/best_overall.pt", help='weights path')
parser.add_argument('--cfg', type=str, default='cfg/yolor_p6_score.cfg', help='config path')
parser.add_argument('--output', type=str, default='yolor_p6.onnx', help='output ONNX model path')
parser.add_argument('--max_size', type=int, default=1280, help='max size of input image')
opt = parser.parse_args()
model_cfg = opt.cfg
model_weights = opt.weights
output_model_path = opt.output
max_size = opt.max_size
device = torch.device('cpu')
# Load model
model = Darknet(model_cfg, (max_size, max_size)).cuda()
model.load_state_dict(torch.load(model_weights, map_location=device)['model'])
model.to(device).eval()
img = torch.zeros((1, 3, max_size, max_size), device=device) # init img
print('Convert from Torch to ONNX')
# # Export the model
# torch.onnx.export(model, # model being run
# img, # model input (or a tuple for multiple inputs)
# output_model_path, # where to save the model (can be a file or file-like object)
# export_params=True, # store the trained parameter weights inside the model file
# opset_version=11, # the ONNX version to export the model to
# do_constant_folding=True, # whether to execute constant folding for optimization
# input_names = ['input'], # the model's input names
# output_names = ['output'], # the model's output names
# dynamic_axes={'input' : {0 : 'batch_size', 2: 'height', 3:'width'}, # variable length axes
# 'output' : {0 : 'batch_size', 1: 'n_boxes'}})
# # Export the model
torch.onnx.export(model, # model being run
img, # model input (or a tuple for multiple inputs)
output_model_path, # where to save the model (can be a file or file-like object)
export_params=True, # store the trained parameter weights inside the model file
opset_version=12, # the ONNX version to export the model to
do_constant_folding=True, # whether to execute constant folding for optimization
input_names = ['input'], # the model's input names
output_names = ['output'])
print('Remove unused outputs')
onnx_module = shape_inference.infer_shapes(onnx.load(output_model_path))
while len(onnx_module.graph.output) != 1:
for output in onnx_module.graph.output:
if output.name != 'output':
print('--> remove', output.name)
onnx_module.graph.output.remove(output)
graph = gs.import_onnx(onnx_module)
graph.cleanup()
graph.toposort()
graph.fold_constants().cleanup()
onnx.save_model(gs.export_onnx(graph), output_model_path)
print('Convert successfull !')
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。