ZhiLight

ZhiLight

A highly optimized LLM inference acceleration engine for Llama and its variants.

Stars: 444

Visit
 screenshot

ZhiLight is a highly optimized large language model (LLM) inference engine developed by Zhihu and ModelBest Inc. It accelerates the inference of models like Llama and its variants, especially on PCIe-based GPUs. ZhiLight offers significant performance advantages compared to mainstream open-source inference engines. It supports various features such as custom defined tensor and unified global memory management, optimized fused kernels, support for dynamic batch, flash attention prefill, prefix cache, and different quantization techniques like INT8, SmoothQuant, FP8, AWQ, and GPTQ. ZhiLight is compatible with OpenAI interface and provides high performance on mainstream NVIDIA GPUs with different model sizes and precisions.

README:

ZhiLight大模型推理引擎

ZhiLight ✨is a highly optimized LLM inference engine developed by Zhihu and ModelBest Inc. The "Zhi" in its name stands for Zhihu. ZhiLight can accelerate the inference of models like Llama and its variants, especially on PCIe-based GPUs. Compared to mainstream open-source inference engines, for example, vllm, it has significant performance advantages.

🎉🎉 Main Features

  • Asynchronous OpenAI compatible interface adapted from vllm
  • Custom defined tensor and unified global memory management
  • 🔥 Encode and all-reduce overlap, we named "dual streams"
    • Support Int8-quantized all-reduce to further reduce all-reduce cost.
  • Host all-reduce based on SIMD instructions
  • Optimized fused kernels, qkv, residual & layernorm etc.
  • 🔥 Fused batch attention for decoding based on tensor core instructions
  • Support TP and PP on one node, TP is recommended
  • Support dynamic batch
  • Support flash attention prefill
  • Support chunked prefill
  • Support prefix cache
  • Support Native INT8/SmoothQuant/FP8/AWQ/GPTQ quantization
  • Support Marlin kernel for GPTQ
  • Support MoE, DeepseekV2 MoE and DeepseekV2 MLA
  • Support Llama/Llama2, Mixtral, Qwen2 series and similar models

🔧 Basic Usage

# Concurrently compile the wheel package, and turn off the unit test
CMAKE_BUILD_PARALLEL_LEVEL=32 TESTING=0 python setup.py bdist_wheel

# Compile with ninja backend
CMAKE_GENERATER="Ninja" python setup.py bdist_wheel

# Install directly
cd ./ZhiLight && pip install -e .

# Start OpenAI compatible server
python -m zhilight.server.openai.entrypoints.api_server [options]

✈️ Docker Image

ZhiLight only depends on the CUDA runtime, cuBLAS, NCCL, and a few Python packages in requirements.txt. You can use the image below for running or building it. You can also directly refer to docker/Dockerfile.

docker pull ghcr.io/zhihu/zhilight/zhilight:0.4.8-cu124

📈 Performance Notes

We conducted performance reviews on various mainstream NVIDIA GPUs with different model sizes and precisions. For dense models ranging from 2B to 110B parameters on PCIe devices, ZhiLight demonstrates significant performance advantages compared to mainstream open-source inference engines.

Test Description:

  • Test purpose is to demonstrate performance, applicable scenarios and limitations
  • Test dataset contains approximately 3.7k prompts
  • Test metrics include:
    • QPS: Queries Per Second
    • TTFT (Time To First Token): First token generation latency
    • TPOT (Time Per Output Token): Generation latency per output token
  • Test environments include:
    • AD102 PCIe : Consumer-grade GPU for experimental research
    • A800: Data center GPU for production deployment
  • Test models include:
    • Large-scale models: Qwen1.5-110B, Qwen2-72B, LLama-3.1-70B
    • Medium-scale models: Qwen2.5-14B, Llama-3.1-8B, Minicpm-2B
  • Compared inference engines include:
    • vLLM
    • SGLang
    • ZhiLight

MiniCPM-2B-sft-bf16

  • NVIDIA AD102 PCIe * 1
Inference Engine QPS TTFT Mean TTFT P95 TPOT Mean TPOT P95
vLLM 1.67 527.55 1062.96 16.71 31.95
SGLang 1.67 466.19 1181.5 33.96 59.44
ZhiLight 1.67 434.64 989.03 26.1 61.14

Qwen2-72B-Instruct-GPTQ-Int4

  • NVIDIA AD102 PCIe * 4
Inference Engine QPS TTFT Mean TTFT P95 TPOT Mean TPOT P95
vLLM 0.18 3493.97 6852.07 35.47 61.74
SGLang 0.18 2276.1 3820.7 38.12 65.16
ZhiLight 0.18 1111.8 1882.5 26.75 41.81
  • NVIDIA A800 * 4
Inference Engine QPS TTFT Mean TTFT P95 TPOT Mean TPOT P95
vLLM 0.18 1457.65 2136.5 22.14 28.96
SGLang 0.36 1113.06 1850.57 30.41 43.65
ZhiLight 0.18 1227.37 1968.95 31.95 48.53

Qwen1.5-110B-Chat-GPTQ-Int4

  • NVIDIA AD102 PCIe * 4
Inference Engine QPS TTFT Mean TTFT P95 TPOT Mean TPOT P95
vLLM 0.09 3085.74 4274.03 30.34 44.08
SGLang 0.09 2418.56 3187.73 31.39 53.1
ZhiLight 0.18 1671.38 2669.82 39.68 64.35
  • NVIDIA A800 * 4
Inference Engine QPS TTFT Mean TTFT P95 TPOT Mean TPOT P95
vLLM 0.09 1899.07 2719.59 23.8 33.02
SGLang 0.18 1514.49 2135.75 28.5 47.28
ZhiLight 0.1 1574.85 2086.8 27.07 38.82

more benchmarks can be found in benchmarks.md

License

Apache License 2.0

Contributors

For Tasks:

Click tags to check more tools for each tasks

For Jobs:

Alternative AI tools for ZhiLight

Similar Open Source Tools

For similar tasks

For similar jobs