训练后量化接口,根据量化因子记录文件record_file以及修改后的模型,插入AscendQuant、AscendDequant等算子,然后保存为可以在Onnx Runtime环境进行精度仿真的fake_quant模型,和可以在昇腾AI处理器做推理的部署模型。
save_model(modfied_onnx_file, record_file, save_path)
参数名 |
输入/返回值 |
含义 |
使用限制 |
---|---|---|---|
modfied_onnx_file |
输入 |
文件名,存储融合后模型的onnx格式。 |
数据类型:string |
record_file |
输入 |
量化因子记录文件路径及名称。 |
数据类型:string |
save_path |
输入 |
模型存放路径。 该路径需要包含模型名前缀,例如./quantized_model/*model。 |
数据类型:string |
无。
只有保存的精度仿真模型以及部署模型文件大小>=2GB才会生成该类文件,且与压缩后的*.onnx模型文件生成在同级目录,用于保存Tensor中的数据,每个Tensor数据单独保存一份*.external文件,文件名与Tensor相同,例如conv1.weight_deploy.external和conv1.weight_fakequant.external。
后续通过ATC工具加载压缩后的*.onnx部署模型文件进行模型转换时,会自动读取同级目录下*.external文件中的Tensor数据。
重新执行量化时,该接口输出的上述文件将会被覆盖。
1 2 3 4 5 6 7 8 9 |
import amct_pytorch as amct # 进行网络推理,期间完成量化 for i in batch_num: output = calibration_model(input_batch) # 插入API,将量化的模型存为onnx文件 amct.save_model(modfied_onnx_file="./tmp/modfied_model.onnx", record_file="./tmp/scale_offset_record.txt", save_path="./results/model") |