# 模型转换 ## 导出模型(ONNX) 导出edsr onnx可以参考:https://github.com/sanghyun-son/EDSR-PyTorch/blob/master/src/main.py 在main.py加上如下代码,可以正常导出onnx: ``` model = model.to('cpu') target_onnx_file = './edsr_baseline_x2_1.onnx' dummy_input = torch.randn(1, 3, 1080, 1920) idx_scale = 0 torch.onnx.export(model, (dummy_input, idx_scale), target_onnx_file, export_params=True, opset_version=11, do_constant_folding=True, dynamic_axes = {}, ) print(f"Export model onnx to {target_onnx_file} finished") ``` 这里固定onnx输入尺寸为:1x3x1080x1920 ## 动态onnx转静态 ``` onnxsim edsr_baseline_x2_1.onnx edsr_baseline_x2_1_sim.onnx --overwrite-input-shape=1,1,1080,1920 ``` ## 转换模型(ONNX -> Axera) 使用模型转换工具 `Pulsar2` 将 ONNX 模型转换成适用于 Axera 的 NPU 运行的模型文件格式 `.axmodel`,通常情况下需要经过以下两个步骤: - 生成适用于该模型的 PTQ 量化校准数据集 - 使用 `Pulsar2 build` 命令集进行模型转换(PTQ 量化、编译),更详细的使用说明请参考 [AXera Pulsar2 工具链指导手册](https://pulsar2-docs.readthedocs.io/zh-cn/latest/index.html) ### 量化数据集 准备量化图片若张,打包成Image.zip ### 模型转换 #### 修改配置文件 检查`config.json` 中 `calibration_dataset` 字段,将该字段配置的路径改为上一步下载的量化数据集存放路径 #### Pulsar2 build 参考命令如下: ``` pulsar2 build --input edsr_baseline_x2_1.onnx --config ./build_config_edsr.json --output_dir ./output --output_name edsr_baseline_x2_1.axmodel --target_hardware AX650 --compiler.check 0 也可将参数写进json中,直接执行: pulsar2 build --config ./build_config_edsr.json ```