本节详细介绍训练后量化支持的量化层,接口调用流程和调用示例。
训练后量化支持量化的层以及约束如下,量化示例请参见样例列表。
支持的层类型 |
约束 |
---|---|
nn.Dense:全连接层 |
- |
nn.Conv2d:卷积层 |
dilation为1、group为1、filter维度为4;或者dilation为1、group不为1,group=channel、filter维度为4。 |
训练后量化接口调用流程如图1所示。
训练后量化主要包括如下几个步骤:
如下流程详细演示如何编写脚本调用AMCTAPI进行模型量化。
1 2 | import amct_mindspore as amct amct.set_logging_level(print_level='info', save_level='info') |
1 | ori_network = user_create_network() |
1 2 | param_dict = load_checkpoint(user_network_checkpoint) load_param_into_net(ori_network, param_dict) |
1 | ori_network.set_train(False) |
该步骤执行时,需要注意如下两点:
1 | user_do_inference(ori_network, test_data, test_iterations) |
1 2 3 4 5 6 7 | config_file = './tmp/config.json' skip_layers = [] fake_input_data = np.random.uniform(0.0, 1.0, size=ori_network_input_shape).astype(np.float32) amct.create_quant_config(config_file=config_file, network=ori_network, input_data=fake_input_data, skip_layers=skip_layers) |
1 2 3 4 | record_file = './tmp/record.txt' calibration_network = amct.quantize_model(config_file=config_file, network=ori_network, input_data=fake_input_data) |
该步骤执行时,需要注意:校准集及其预处理过程数据要与模型匹配,以保证量化的精度。
1 | user_do_inference(calibration_network, calibration_data) |
1 2 3 4 | quant_network_path = './results/user_network' amct.save_model(file_name=quant_network_path, network=calibration_network, input_data=fake_input_data) |