PyTorch Transformer model MiniLM-L12-H384-uncased for Natural Language Classification and Question Answering
This document describes evaluation of optimized checkpoints for transformer models MiniLM-L12-H384-uncased for NL Classification and Question Answering tasks.
Please install and setup AIMET (Torch GPU variant) before proceeding further.
NOTE
- All AIMET releases are available here: https://github.com/quic/aimet/releases
- This model has been tested using AIMET version 1.23.0 (i.e. set
release_tag="1.23.0"
in the above instructions). - This model is compatible with the PyTorch GPU variant of AIMET (i.e. set
AIMET_VARIANT="torch_gpu"
in the above instructions).
pip install datasets==2.4.0
pip install transformers==4.11.3
- Original full precision checkpoints without downstream training were downloaded through hugging face
- [Full precision model with downstream training weight files] are automatically downloaded using evaluation script
- [Quantization optimized model weight files] are automatically downloaded using evaluation script
- For NLP tasks, we use the General Language Understanding Evaluation (GLUE) benchmark dataset for evaluation.
- For Question Answering tasks, we use the Stanford Question Answering Dataset (SQuAD) benchmark dataset for evaluation.
- Dataset downloading is handled by evaluation script
python minilm_quanteval.py \
--model_config <MODEL_CONFIGURATION> \
--per_device_eval_batch_size 4 \
--output_dir <OUT_DIR> \
- example
python minilm_quanteval.py --model_config minilm_w8a8_rte --per_device_eval_batch_size 4 --output_dir ./evaluation_result
- supported values of model_config are "minilm_w8a8_rte","minilm_w8a8_stsb","minilm_w8a8_mrpc","minilm_w8a8_cola","minilm_w8a8_sst2","minilm_w8a8_qnli","minilm_w8a8_qqp","minilm_w8a8_mnli", "minilm_w8a8_squad"
The following configuration has been used for the above models for INT8 quantization:
- Weight quantization: 8 bits, symmetric quantization
- Bias parameters are not quantized
- Activation quantization: 8 bits, asymmetric quantization
- Model inputs are quantized
- TF range learning was used as quantization scheme
- Mask values of -6 was applied in attention layers
- Quantization aware training (QAT) was used to obtain optimized quantized weights, detailed hyperparameters listed in Yelysei Bondarenko, Markus Nagel, Tijmen Blankevoort, "Understanding and Overcoming the Challenges of Efficient Transformer Quantization", EMNLP 2021.
Below are the results of the Pytorch transformer model MiniLM for GLUE dataset:
Configuration | CoLA (corr) | SST-2 (acc) | MRPC (f1) | STS-B (corr) | QQP (acc) | MNLI (acc) | QNLI (acc) | RTE (acc) | GLUE |
FP32 | 57.78 | 92.32 | 89.01 | 88.73 | 90.70 | 85.04 | 91.52 | 70.76 | 83.23 |
W8A8 | 55.58 | 92.20 | 88.21 | 88.68 | 90.62 | 84.59 | 90.72 | 70.40 | 82.63 |