Transformers documentation
Overview
Overview
Quantization lowers the memory requirements of loading and using a model by storing the weights in a lower precision while trying to preserve as much accuracy as possible. Weights are typically stored in full-precision (fp32) floating point representations, but half-precision (fp16 or bf16) are increasingly popular data types given the large size of models today. Some quantization methods can reduce the precision even further to integer representations, like int8 or int4.
Transformers supports many quantization methods, each with their pros and cons, so you can pick the best one for your specific use case. Some methods require calibration for greater accuracy and extreme compression (1-2 bits), while other methods work out of the box with on-the-fly quantization.
Use the Space below to help you pick a quantization method depending on your hardware and number of bits to quantize to.
Quantization Method | On the fly quantization | CPU | CUDA GPU | ROCm GPU | Metal (Apple Silicon) | Intel GPU | Torch compile() | Bits | PEFT Fine Tuning | Serializable with π€Transformers | π€Transformers Support | Link to library |
---|---|---|---|---|---|---|---|---|---|---|---|---|
AQLM | π΄ | π’ | π’ | π΄ | π΄ | π΄ | π’ | 1/2 | π’ | π’ | π’ | https://github.com/Vahe1994/AQLM |
AWQ | π΄ | π’ | π’ | π’ | π΄ | π’ | ? | 4 | π’ | π’ | π’ | https://github.com/casper-hansen/AutoAWQ |
bitsandbytes | π’ | π‘ | π’ | π‘ | π΄ | π‘ | π΄ | 4/8 | π’ | π’ | π’ | https://github.com/bitsandbytes-foundation/bitsandbytes |
compressed-tensors | π΄ | π’ | π’ | π’ | π΄ | π΄ | π΄ | 1/8 | π’ | π’ | π’ | https://github.com/neuralmagic/compressed-tensors |
EETQ | π’ | π΄ | π’ | π΄ | π΄ | π΄ | ? | 8 | π’ | π’ | π’ | https://github.com/NetEase-FuXi/EETQ |
GGUF / GGML (llama.cpp) | π’ | π’ | π’ | π΄ | π’ | π΄ | π΄ | 1/8 | π΄ | See Notes | See Notes | https://github.com/ggerganov/llama.cpp |
GPTQModel | π΄ | π’ | π’ | π’ | π’ | π’ | π΄ | 2/3/4/8 | π’ | π’ | π’ | https://github.com/ModelCloud/GPTQModel |
AutoGPTQ | π΄ | π΄ | π’ | π’ | π΄ | π΄ | π΄ | 2/3/4/8 | π’ | π’ | π’ | https://github.com/AutoGPTQ/AutoGPTQ |
HIGGS | π’ | π΄ | π’ | π΄ | π΄ | π΄ | π’ | 2/4 | π΄ | π’ | π’ | https://github.com/HanGuo97/flute |
HQQ | π’ | π’ | π’ | π΄ | π΄ | π΄ | π’ | 1/8 | π’ | π΄ | π’ | https://github.com/mobiusml/hqq/ |
optimum-quanto | π’ | π’ | π’ | π΄ | π’ | π΄ | π’ | 2/4/8 | π΄ | π΄ | π’ | https://github.com/huggingface/optimum-quanto |
FBGEMM_FP8 | π’ | π΄ | π’ | π΄ | π΄ | π΄ | π΄ | 8 | π΄ | π’ | π’ | https://github.com/pytorch/FBGEMM |
torchao | π’ | π’ | π’ | π΄ | π‘ | π΄ | 4/8 | π’π΄ | π’ | https://github.com/pytorch/ao | ||
VPTQ | π΄ | π΄ | π’ | π‘ | π΄ | π΄ | π’ | 1/8 | π΄ | π’ | π’ | https://github.com/microsoft/VPTQ |
FINEGRAINED_FP8 | π’ | π΄ | π’ | π΄ | π΄ | π΄ | π΄ | 8 | π΄ | π’ | π’ | |
SpQR | π΄ | π΄ | π’ | π΄ | π΄ | π΄ | π’ | 3 | π΄ | π’ | π’ | https://github.com/Vahe1994/SpQR/ |
Resources
If you are new to quantization, we recommend checking out these beginner-friendly quantization courses in collaboration with DeepLearning.AI.
- Quantization Fundamentals with Hugging Face
- [Quantization in Depth](https://www.deeplearning.ai/short-courses/quantization-in-depth