import torch
import argparse
import numpy as np
from mmdet.apis import init_detector
input_names = ['input']
output_names = ['seg_preds', 'cate_labels', 'cate_scores']
def pth2onnx(args, fake_input):
model = init_detector(args.config, args.pth_path, device='cpu')
model.forward = model.simple_test
torch.onnx.export(model, fake_input, args.out,
input_names=input_names,
output_names=output_names,
verbose=False,
opset_version=11)
if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('--config', help='model config')
parser.add_argument('--out', help='onnx output name')
parser.add_argument('--pth_path', help='model pth path')
parser.add_argument('--shape', type=int, nargs='+', help='input image size hxw')
args = parser.parse_args()
assert len(args.shape) == 2
fake_input = torch.randn(1, 3, args.shape[0], args.shape[1])
pth2onnx(args, fake_input)