KV Cache(Key-Value Cache)是一种缓存技术,通过存储键值对的形式来复用计算结果,以达到提高性能和降低内存消耗的目的。在大规模训练和推理中,随着batch_size和sequence_length的不断增长,KV Cache占用的内存开销也快速增大,甚至会超过模型本身;而对KV Cache进行INT8量化可以大幅度减少模型运行中的内存消耗,降低模型部署成本。
KV Cache量化支持的层:torch.nn.Linear,原始数据类型为float32和float16。KV Cache量化样例请参见获取更多样例。
该特性只有Atlas A2训练系列产品/Atlas 800I A2推理产品、Atlas 推理系列产品支持。
KV Cache量化接口调用流程如图1所示。
如果用户需要支持更多算子类型,或者用户自定义了其他操作,则可以使用QuantCalibrationOp接口,进行构图,然后进行量化校准,并输出量化因子文件。
1
|
import amct_pytorch as amct |
建议使用原始待量化的模型和测试集,在PyTorch环境下推理,验证环境、推理脚本是否正常。
推荐执行该步骤,请确保原始模型可以完成推理且精度正常;执行该步骤时,可以使用部分测试集,减少运行时间。
1
|
user_do_inference_torch(ori_model, test_data, test_iterations) |
1 2 3 4 5 |
config_file = './tmp/config.json' amct.create_quant_cali_config(config_file=config_file, model=ori_model, quant_layers=None, config_defination="./configs/quant.cfg") |
校准过程中如果提示[IFMR]: Do layer xxx data calibration failed!错误信息,则请参见校准执行过程中提示“[IFMR]: Do layer xxx data calibration failed!”解决。
1
|
user_do_inference_torch(calibration_model, calibration_data, batch_num) |