量化感知训练简易配置文件
retrain_config_caffe.proto文件参数说明如表1所示,该文件所在目录为:AMCT安装目录/amct_caffe/proto/retrain_config_caffe.proto。
消息 |
是否必填 |
类型 |
字段 |
说明 |
---|---|---|---|---|
AMCTRetrainConfig |
- |
- |
- |
AMCT量化感知训练的简易配置。 |
repeated |
string |
skip_layers |
按层名跳过哪些层。全局参数,方便后续拓展其他特性场景下可同时跳过的层,比如下述拓展的quant_skip_layers参数,若后续又拓展了xxx_skip_layers参数,则通过skip_layers参数可以同时配置两个特性场景下需要跳过的层。而无需在quant_skip_layers和xxx_skip_layers参数中分别配置。 若同时配置了skip_layers和quant_skip_layers参数,则取两者并集。 |
|
repeated |
string |
skip_layer_types |
按层类型跳过哪些层(当前版本不支持)。全局参数,方便后续拓展其他特性场景下可同时跳过的层,比如下述拓展的quant_skip_types参数,若后续又拓展了xxx_skip_types参数,则通过skip_layer_types参数可以同时配置两个特性场景下需要跳过的层。而无需在quant_skip_types和xxx_skip_types参数中分别配置。 若同时配置了skip_layer_types和quant_skip_types参数,则取两者并集。 |
|
repeated |
RetrainOverrideLayer |
override_layer_configs |
按层名重写哪些层,即对哪些层进行差异化压缩。 例如全局量化配置参数配置的初始上下限值为[-0.6,0.6],可以通过该参数对部分层进行差异化量化,可以配置为[-0.3,0.3]。 参数优先级为:
|
|
repeated |
RetrainOverrideLayerType |
override_layer_types |
按层类型重写哪些层,即对哪些层进行差异化压缩。 例如全局量化配置参数配置的初始上下限值为[-0.6,0.6],可以通过该参数对部分层进行差异化量化,可以配置为[-0.3,0.3]。 参数优先级为:
|
|
optional |
uint32 |
batch_num |
量化使用的batch数量。 |
|
required |
RetrainDataQuantConfig |
retrain_data_quant_config |
量化感知训练数据量化配置参数。全局量化配置参数。 参数优先级为:override_layer_configs>override_layer_types>retrain_data_quant_config/retrain_weight_quant_config |
|
required |
RetrainWeightQuantConfig |
retrain_weight_quant_config |
量化感知训练权重量化配置参数。全局量化配置参数。 参数优先级为:override_layer_configs>override_layer_types>retrain_data_quant_config/retrain_weight_quant_config |
|
repeated |
string |
quant_skip_layers |
按层名跳过不需要量化的层。量化场景下使用的参数。 若同时配置了skip_layers和quant_skip_layers参数,则取两者并集。 |
|
repeated |
string |
quant_skip_types |
按层类型跳过不需要量化的层(当前版本不支持)。量化场景下使用的参数。 若同时配置了skip_layer_types和quant_skip_types参数,则取两者并集。 |
|
RetrainDataQuantConfig |
- |
- |
- |
量化感知训练数据量化参数配置。 |
- |
ULQuantize |
ulq_quantize |
数据量化算法,目前仅支持ulq。 |
|
ULQuantize |
- |
- |
- |
ULQ量化算法配置。算法介绍请参见ULQ数据量化算法。 |
optional |
ClipMaxMin |
clip_max_min |
初始化的上下限值,如果不配置,默认用ifmr进行初始化。 |
|
optional |
bool |
fixed_min |
是否下限不学习且固定为0。默认ReLu后为true,其他为false。 |
|
ClipMaxMin |
- |
- |
- |
初始上下限。 |
required |
float |
clip_max |
初始上限值。 |
|
required |
float |
clip_min |
初始下限值。 |
|
RetrainWeightQuantConfig |
- |
- |
- |
量化感知训练权重量化参数配置。 |
- |
ARQRetrain |
arq_retrain |
权重量化算法,目前仅支持arq。 |
|
ARQRetrain |
- |
- |
- |
ARQ量化算法配置。算法介绍请参见ARQ权重量化算法。 |
required |
bool |
channel_wise |
是否做channel wise的arq。 |
|
RetrainOverrideLayer |
- |
- |
- |
重写的层配置。 |
required |
string |
layer_name |
层名。 |
|
required |
RetrainDataQuantConfig |
retrain_data_quant_config |
重写的数据层量化参数。 |
|
required |
RetrainWeightQuantConfig |
retrain_weight_quant_config |
重写的权重层量化参数。 |
|
RetrainOverrideLayerType |
- |
- |
- |
重写的层类型配置。 |
required |
string |
layer_type |
层类型。 |
|
required |
RetrainDataQuantConfig |
retrain_data_quant_config |
重写的数据层量化参数。 |
|
required |
RetrainWeightQuantConfig |
retrain_weight_quant_config |
重写的权重层量化参数。 |
基于该文件构造的量化感知训练简易配置文件quant.cfg样例如下所示:
# global quantize parameter retrain_data_quant_config: { ulq_quantize: { clip_max_min: { clip_max: 6.0 clip_min: -6.0 } } } retrain_weight_quant_config: { arq_retrain: { channel_wise: true } } skip_layers: "conv_1" override_layer_types : { layer_type: "InnerProduct" retrain_weight_quant_config: { arq_retrain: { channel_wise: false } } } override_layer_configs : { layer_name: "fc_5" retrain_weight_quant_config: { arq_retrain: { channel_wise: false } } }