This document describes evaluation of optimized checkpoints for transformer models Bert-base-uncased for NL Classification tasks 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 transformers_nlclassifier_quanteval.py \
--model_name_or_path <MODEL_NAME> \
--task_name <TASK> \
--per_device_eval_batch_size 4 \
--output_dir <OUT_DIR> \
-
example
python transformers_nlclassifier_quanteval.py --model_name_or_path bert-base-uncased --task_name rte --per_device_eval_batch_size 4 --output_dir ./evaluation_result
-
supported keyword of task_name supported are "rte","stsb","mrpc","cola","sst2","qnli","qqp","mnli"
-
supported model_name_or_path are "bert-base-uncased", "google/mobilebert-uncased", "microsoft/MiniLM-L12-H384-uncased", "distilbert-base-uncased", "roberta-base"
python transformers_qa_quanteval.py \
--model_name_or_path <MODEL_NAME> \
--dataset_name <DATASET_NAME> \
--per_device_eval_batch_size 4 \
--output_dir <OUT_DIR>
-
example
python transformers_qa_quanteval.py --model_name_or_path bert-base-uncased --dataset_name squad --per_device_eval_batch_size 4 --output_dir ./evaluation_result
-
supported model_name_or_path are "bert-base-uncased", "google/mobilebert-uncased", "microsoft/MiniLM-L12-H384-uncased", "distilbert-base-uncased", "roberta-base"
-
supported dataset_name is "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 Bert for GLUE dataset:
Configuration | CoLA (corr) | SST-2 (acc) | MRPC (f1) | STS-B (corr) | QQP (acc) | MNLI (acc) | QNLI (acc) | RTE (acc) | GLUE |
FP32 | 58.76 | 93.12 | 89.93 | 88.84 | 90.94 | 85.19 | 91.63 | 66.43 | 83.11 |
W8A8 | 56.93 | 91.28 | 90.34 | 89.13 | 90.78 | 81.68 | 91.14 | 68.23 | 82.44 |