(function() { var utmInheritingDomain = "appstore.com", utmRegExp = /(&|\?)utm_[A-Za-z]+=[A-Za-z0-9]+/gi, links = document.getElementsByTagName("a"), utms = [ "utm_medium={{URL - utm_medium}}", "utm_source={{URL - utm_source}}", "utm_campaign={{URL - utm_campaign}}" ]; for (var index = 0; index < links.length; index += 1) { var tempLink = links[index].href, tempParts; if (tempLink.indexOf(utmInheritingDomain) > 0) { tempLink = tempLink.replace(utmRegExp, ""); tempParts = tempLink.split("#"); if (tempParts[0].indexOf("?") < 0 ) { tempParts[0] += "?" + utms.join("&"); } else { tempParts[0] += "&" + utms.join("&"); } tempLink = tempParts.join("#"); } links[index].href = tempLink; } }());
  • October 23, 2023
  • 3 min read

Unlocking Efficiency of Serving LLMs with Activation-aware Weight Quantization (AWQ) on Friendli Engine

Unlocking Efficiency of Serving LLMs with Activation-aware Weight Quantization (AWQ) on Friendli Engine thumbnail

As mentioned in our previous article, Activation-Aware Weight Quantization (AWQ) is a technique that optimizes the efficiency of a neural network without compromising its accuracy. Unlike traditional weight quantization methods, AWQ leverages a deep understanding of the data distribution within neural networks during inference. In the calibration phase, it collects statistics on the specific activations a model generates when exposed to input data. These statistics enable the precise determination of quantization parameters, such as scale and offset, tailored to the data distribution.

AWQ strikes a harmonious balance between model efficiency and accuracy, making it an invaluable tool for deploying LLMs efficiently. What’s more, running AWQ-ed models is made seamless with Friendli Engine, a powerful LLM serving engine from FriendliAI. For example, one can run AWQ-ed LLMs (e.g., Llama 2 70B 4-bit on a single A100 80 GB GPU) natively on Friendli Engine.

Benchmark Accuracy Numbers: Unlocking the Potential of AWQ on Friendli Engine

The accuracy of AWQ-ed models on Friendli Engine is remarkable. We run the following benchmark tests with Llama-2–13b-chat (meta-llama/Llama-2–13b-chat-hf in Hugging Face).

4bit AWQ-ed Llama-2–13b-chat model running on Friendli Engine shows similar performance to the original Llama-2–13b-chat model-FriendliAI

As you can see, the 4bit AWQ-ed Llama-2–13b-chat model running on Friendli Engine shows similar performance to the original Llama-2–13b-chat model. These results underscore the effectiveness of AWQ-ed models running on Friendli Engine in maintaining or even improving model accuracy while significantly reducing the memory and computational requirements.

Running AWQ-ed Models on Friendli Engine: A Step-by-Step Guide

  1. Converting an Unquantized Model: To harness the power of AWQ, begin by converting your unquantized model to its quantized counterpart using the following commands:

    bash
    # Install friendli-client package.
    $ pip install "friendli-client[mllib]"
    
    # Start checkpoint conversion.
    $ friendli checkpoint convert \
        --model-name-or-path $MODEL_NAME_OR_PATH \
        --output-dir $OUTPUT_DIR \
        --data-type $DTYPE \
        --quantize \
        --quant-config-file $QUANT_CONFIG_FILE
    

    The content of file specified at $QUANT_CONFIG_FILE is as follows:

    yaml
    mode: awq
    device: cuda:0
    seed: 42
    calibration_dataset:
      path_or_name: lambada
      format: json
      split: validation
      lookup_column_name: text
      num_samples: 128
      max_length: 512
    awq_args:
      quant_bit: 4
      quant_group_size: 64
    

    This step ensures that your model is quantized using AWQ to reduce the model size for efficiency while preserving its accuracy.

  2. Running Friendli Engine: Once you have the quantized model checkpoint, load it into Friendli Engine, the versatile serving engine from FriendliAI.

    bash
    $ docker run --gpus=1 -v $LOCAL_CKPT_PATH:/model --network=host
    $PERIFLOW_CONTAINER_IMAGE /bin/bash -c "/root/launcher --web-server-port 6000
    --tokenizer-file-path /model/tokenizer.json --ckpt-path /model/model.h5 --dtype
    fp16 --quant-scheme awq --awq-group-size 64 --model-type llama --num-layers 40
    --num-heads 40 --head-size 128 --rotary-dim 128 --ff-intermediate-size 13824
    --max-length 4096 --vocab-size 32000 --eos-token 2"
    

    With the provided commands, Friendli Engine provides a seamless and efficient environment for serving your AWQ-ed models.

  3. Sending Inference Requests to the AWQ-ed model on Friendli Engine: With Friendli Engine up and running, you can now send inference requests to the server.

    bash
    $ curl -X POST http://0.0.0.0:6000/v1/completions \
      -H "Content-Type: application/json" \
      -d '{
        "prompt": "Say this is an example.\n",
        "max_tokens": 100,
        "temperature": 0.5,
        "top_p": 0.5,
        "stream": true
    }'
    

    Friendli Engine takes care of the heavy lifting, delivering high-performance inference serving while sparing you the complexities of deployment.

Stay Tuned for our Performance Numbers!

Running LLMs with AWQ on Friendli Engine enables users to achieve efficient LLM deployment. This powerful feature achieves remarkable efficiency gains without sacrificing accuracy. Stay tuned for our next article, where we’ll discuss performance that demonstrates the true potential of AWQ-ed models on Friendli Engine.


Written by

FriendliAI logo

FriendliAI Tech & Research


Share