import torch
import cfg
from model_VGG import advancedEAST
def pth2onnx(input_file, output_file):
model = advancedEAST()
state_dict = {k.replace('module.', ''): v for k, v in torch.load(
input_file, map_location='cpu').items()}
model.load_state_dict(state_dict)
model.eval()
input_names = ["input_1"]
output_names = ["output_1"]
dynamic_axes = {'input_1': {0: '-1'}, 'output_1': {0: '-1'}}
size = cfg.max_predict_img_size
dummy_input = torch.randn(1, 3, size, size)
torch.onnx.export(
model,
dummy_input,
output_file,
input_names=input_names,
output_names=output_names,
dynamic_axes = dynamic_axes,
verbose=True,
opset_version=11)
if __name__ == "__main__":
input_file = cfg.pth_path if cfg.pth_path else 'saved_model/3T736_latest.pth'
output_file = cfg.train_task_id + '.onnx'
pth2onnx(input_file, output_file)