AIMET Quantization Aware Training¶
Overview¶
In cases where PTQ techniques are not sufficient for mitigating quantization error, users can use quantization-aware training (QAT). QAT models the quantization noise during training and allows the model to find better solutions than post-training quantization. However, the higher accuracy comes with the usual costs of neural network training, i.e. longer training times, need for labeled data and hyperparameter search.
QAT workflow¶
The QAT workflow is largely similar to the flow for using Quantization Simulation for inference. The only difference is that a user can take the sim.model and use it in their training pipeline in order to fine-tune model parameters while taking quantization noise into account. The user’s training pipeline will not need to change in order to train the sim.model compared to training the original model.
A typical pipeline is as follows:
Create a QuantSim sim object from a pretrained model.
Calibrate the sim using representative data samples to come up with initial encoding values for each quantizer node.
Pass the sim.model into a training pipeline to fine-tune the model parameters.
Evaluate the sim.model using an evaluation pipeline to check whether model accuracy has improved.
Export the sim to generate a model with updated weights and no quantization nodes, along with the accompanying encodings file containing quantization scale/offset parameters for each quantization node.
Observe that as compared to QuantSim inference, step 3 is the only addition when performing QAT.
QAT modes¶
There are two variants of QAT, referred to as QAT without Range Learning and QAT with Range Learning.
In QAT without Range Learning, encoding values for activation quantizers are found once in the beginning during the calibration step after QuantSim has been instantiated, and are not updated again subsequently throughout training.
In QAT with Range Learning, encoding values for activation quantizers are initially set during the calibration step, but are free to update during training, allowing a more optimal set of scale/offset quantization parameters to be found as training takes place.
In both variants, parameter quantizer encoding values will continue to update in accordance with the parameters themselves updating during training.