Back to Transformers

AQLM

docs/source/en/quantization/aqlm.md

5.8.03.1 KB
Original Source
<!--Copyright 2024 The HuggingFace Team. All rights reserved. Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. ⚠️ Note that this file is in Markdown but contain specific syntax for our doc-builder (similar to MDX) that may not be rendered properly in your Markdown viewer. -->

AQLM

Additive Quantization of Language Models (AQLM) quantizes multiple weights together and takes advantage of interdependencies between them. AQLM represents groups of 8-16 weights as a sum of multiple vector codes.

AQLM also supports fine-tuning with LoRA with the PEFT library, and is fully compatible with torch.compile for even faster inference and training.

Run the command below to install the AQLM library with kernel support for both GPU and CPU inference and training. AQLM only works with Python 3.10+.

bash
pip install aqlm[gpu,cpu]

Load an AQLM-quantized model with [~PreTrainedModel.from_pretrained].

python
from transformers import AutoTokenizer, AutoModelForCausalLM

quantized_model = AutoModelForCausalLM.from_pretrained(
    "ISTA-DASLab/Mixtral-8x7b-AQLM-2Bit-1x16-hf",
    dtype="auto", 
    device_map="auto"
)

Configurations

AQLM quantization setups vary mainly in the number of codebooks used, as well as codebook sizes in bits. The most popular setups and supported inference kernels are shown below.

KernelNumber of codebooksCodebook size, bitsNotationAccuracySpeedupFast GPU inferenceFast CPU inference
TritonKNKxN-Up to ~0.7x
CUDA1161x16BestUp to ~1.3x
CUDA282x8OKUp to ~3.0x
NumbaK8Kx8GoodUp to ~4.0x

Resources

Run the AQLM demo notebook for more examples of how to quantize a model, push a quantized model to the Hub, and more.

For more example demo notebooks, visit the AQLM repository.