当前位置: 首页 > news >正文

CANN/AMCT保存量化重训练模型

save_quant_retrain_model

【免费下载链接】amctAMCT是CANN提供的昇腾AI处理器亲和的模型压缩工具仓。项目地址: https://gitcode.com/cann/amct

产品支持情况

产品

是否支持

Ascend 950PR/Ascend 950DT

Atlas A3 训练系列产品 / Atlas A3 推理系列产品

Atlas A2 训练系列产品 / Atlas A2 推理系列产品

功能说明

量化感知训练接口,根据用户最终的重训练好的模型,插入AscendQuant、AscendDequant等算子,生成最终量化精度仿真模型以及量化部署模型。

函数原型

save_quant_retrain_model (config_file, model, record_file, save_path, input_data, input_names=None, output_names=None, dynamic_axes=None)

参数说明

参数名

输入/输出

说明

config_file

输入

含义:用户生成的量化感知训练配置文件,用于指定模型network中量化层的配置情况。

数据类型:string

model

输入

含义:已进行量化感知训练后的量化模型。

数据类型:torch.nn.Module

record_file

输入

含义:量化因子记录文件路径及名称。

数据类型:string

save_path

输入

含义:量化模型存放路径。该路径需要包含模型名前缀,例如./quantized_model/*model。

数据类型:string

input_data

输入

含义:模型的输入数据。一个torch.tensor会被等价为tuple(torch.tensor)。

数据类型:tuple

input_names

输入

含义:模型的输入的名称,用于保存的量化onnx模型中显示。

默认值:None

数据类型:list(string)

output_names

输入

含义:模型的输出的名称,用于保存的量化onnx模型中显示。

默认值:None

数据类型:list(string)

dynamic_axes

输入

含义:对模型输入输出动态轴的指定,例如对于输入inputs(NCHW),N、H、W为不确定大小,输出outputs(NL),N为不确定大小,则指定形式为:

{"inputs": [0,2,3], "outputs": [0]},其中0,2,3分别表示N,H,W所在位置的索引。

默认值:None

数据类型:dict<string, dict<python:int, string>> or dict<string, list(int)>

使用约束:int类型取值需要为非负数

返回值说明

调用示例

import amct_pytorch as amct # 建立待量化的网络图结构 model = build_model() model.load_state_dict(torch.load(state_dict_path)) input_data = tuple([torch.randn(input_shape)]) # 训练量化retrain模型,训练量化因子 train_model(quant_retrain_model, input_batch) # 推理量化retrain模型,导出量化因子 infer_model(quant_retrain_model, input_batch) # 插入量化API,将量化感知训练的模型存为ONNX文件 amct.save_quant_retrain_model( config_json_file, model, record_file, save_path="./results/model" input_data, input_names=['input'], output_names=['output'], dynamic_axes={'input':{0: 'batch_size'}, 'output':{0: 'batch_size'}})

落盘文件说明:

  • 精度仿真模型文件:ONNX格式的模型文件,模型名中包含fake_quant,可以在ONNX Runtime环境进行精度仿真。

  • 部署模型文件:ONNX格式的模型文件,模型名中包含deploy,经过ATC转换工具转换后可部署到AI处理器。

  • (可选)*.external文件,包括*deploy.external和*fakequant.external:

    只有保存的精度仿真模型以及部署模型文件大小>=2GB才会生成该类文件,且与压缩后的*.onnx模型文件生成在同级目录,用于保存Tensor中的数据,每个Tensor数据单独保存一份*.external文件,文件名与Tensor相同,例如_conv1.weight__deploy.external和_conv1.weight__fakequant.external。

    后续通过ATC工具加载压缩后的*.onnx部署模型文件进行模型转换时,会自动读取同级目录下*.external文件中的Tensor数据。

重新执行量化感知训练时,该接口输出的上述文件将会被覆盖。

【免费下载链接】amctAMCT是CANN提供的昇腾AI处理器亲和的模型压缩工具仓。项目地址: https://gitcode.com/cann/amct

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

http://www.jsqmd.com/news/785677/

相关文章:

  • CANN/cann-recipes-infer Kimi-K2-Thinking配置指南
  • JAVA TREE
  • cann/runtime 多设备编程
  • 卷积改进与轻量化:2026 生产级轻量:将 MobileOne 重新参数化块引入 YOLO 主干,iPhone 上实时运行
  • Kubernetes多集群管理与联邦:构建跨地域高可用架构
  • 异常类
  • 2026年4月技术好的升降窗品牌推荐,断桥窗沙一体内开窗/铝合金阳光房/系统推拉门/阳光房,升降窗厂家哪个好 - 品牌推荐师
  • 基于OpenAI API与Slack平台构建智能对话机器人的实践指南
  • Avast 阻止引用程序访问网络
  • 生产级AI系统不确定性管理:从量化到决策的工程实践
  • CANN竞赛仓Add算子测试报告
  • 在Windows 11上无缝运行Android应用:Windows Subsystem for Android完整指南
  • 2026年好用的免费在线去水印工具怎么选?免费一键去水印网站最新推荐 - 科技热点发布
  • 一键部署AI助手沙箱:OpenClaw计算机容器在ModelScope与HuggingFace的实战指南
  • 基于NGSI-LD的物联网数据质量评估与增强实践
  • EDA-设计规模爆炸
  • LeetCode 3629.通过质数传送到达终点的最少跳跃次数:埃式筛+BFS
  • 有没有哪家包间又带独立厕所环境又好
  • 文献计量分析揭示AI在金融与创业交叉领域的研究热点与趋势
  • 我的编程启程:从零基础出发,奔赴心之所向
  • 在NPU环境上适配HunyuanImage-3.0模型的推理
  • 3.MySQL数据表操作全解析,一篇吃透!
  • 2026年一键去水印工具怎么选?在线去水印操作教程及推荐排行 - 科技热点发布
  • AI模型公平性:从统计定义到工程实践的全面解析
  • 别追了,那个终点线会自己往后跑
  • 从围棋AI到决策教学:AI如何成为人类复杂决策的超级陪练
  • 魔兽争霸3终极兼容性解决方案:WarcraftHelper完整指南
  • AI公平性感知:个体特征如何影响用户对算法决策的公平判断
  • 5分钟掌握DeepSeek集成配置:从新手到专家的完整实战指南
  • 3.快乐数专题学习笔记——双指针法在LeetCode 202题中的应用