Yolov5s/kneron/yolov5_export.py
2026-03-11 16:13:59 +08:00

81 lines
3.0 KiB
Python

import os
import torch
import sys
import yaml
import argparse
from yolov5_runner import Yolov5Runner
def save_weight(num_classes):
current_path=os.getcwd()
par_path = os.path.dirname(current_path)
sys.path.append(os.path.join(par_path, 'yolov5'))
from models.yolo import Model
num_classes = num_classes
device=torch.device('cpu')
ckpt = torch.load(path, map_location=device)
model = Model(yaml_path, nc=num_classes)
ckpt['model'] = {k: v for k, v in ckpt['model'].float().state_dict().items() if k in model.state_dict() and model.state_dict()[k].shape == v.shape}
model.load_state_dict(ckpt['model'])
torch.save(model.state_dict(),pt_path,_use_new_zipfile_serialization=False)
def export_onnx(input_h, input_w, num_classes):
onnx_batch_size, onnx_img_h, onnx_img_w = 1, input_h, input_w
yolov5_model = Yolov5Runner(model_path=pt_path, yaml_path=yaml_path, grid20_path=grid20_path, grid40_path=grid40_path, grid80_path=grid80_path, num_classes=num_classes, imgsz_h=onnx_img_h, imgsz_w=onnx_img_w, conf_thres=0.001, iou_thres=0.65, top_k_num=3000, vanish_point=0.0)
# Input
img = torch.zeros((onnx_batch_size, 3, onnx_img_h, onnx_img_w))
# img = img.type(torch.cuda.FloatTensor)
# Load PyTorch model
model = yolov5_model.yolov5_model
model.eval()
model.model[-1].export = True # set Detect() layer export=True
y = model(img) # dry run
# ONNX export
try:
import onnx
print('\nStarting ONNX export with onnx %s...' % onnx.__version__)
print('****onnx file****',onnx_export_file)
torch.onnx.export(model, img, onnx_export_file, verbose=False, opset_version=11, keep_initializers_as_inputs=True, input_names=['images'], output_names=['classes', 'boxes'] if y is None else ['output'])
# Checks
onnx_model = onnx.load(onnx_export_file) # load onnx model
onnx.checker.check_model(onnx_model) # check onnx model
print(onnx.helper.printable_graph(onnx_model.graph)) # print a human readable model
print('ONNX export success, saved as %s' % onnx_export_file)
except Exception as e:
print('ONNX export failure: %s' % e)
if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('--data', type=str, default='../yolov5/data/pretrained_paths_520.yaml', help='the path to pretrained model paths yaml file')
args = parser.parse_args()
with open(args.data) as f:
data_dict = yaml.load(f, Loader=yaml.FullLoader) # data dict
os.environ["CUDA_VISIBLE_DEVICES"] = '0'
num_classes = data_dict['nc']
input_w = data_dict['input_w']
input_h = data_dict['input_h']
grid_dir = data_dict['grid_dir']
grid20_path = data_dict['grid20_path']
grid40_path = data_dict['grid40_path']
grid80_path = data_dict['grid80_path']
path = data_dict['path']
pt_path=data_dict['pt_path']
yaml_path=data_dict['yaml_path']
onnx_export_file = data_dict['onnx_export_file']
save_weight(num_classes)
export_onnx(input_h, input_w, num_classes)