Project Icon

xFasterTransformer

高效的大规模语言模型推理优化方案

xFasterTransformer是一个为X86平台优化的大规模语言模型(LLM)推理解决方案,支持多插槽和节点的分布式运行,适用于大型模型推理。它提供C++和Python API,支持例如ChatGLM、Llama、Baichuan等流行的LLM模型,并可通过PyPI、Docker或从源代码进行安装。项目附带详细文档、API使用示例、基准测试代码和Web演示,确保用户能充分利用其高性能和高扩展性。

xFasterTransformer 项目介绍

xFasterTransformer 是一种在 X86 平台上对大型语言模型(LLM)进行极致优化的解决方案。这与在 GPU 平台上的 FasterTransformer 类似。项目的设计允许其在多插槽和多节点上分布式工作,从而支持在更大模型上的推理。此外,xFasterTransformer 提供了 C++ 和 Python 的 API,从高级接口到低级接口,便于集成和使用。

项目概述

随着大型语言模型(LLM)的快速发展,它们在许多人工智能场景中的应用越来越广泛。xFasterTransformer 针对主流且流行的 LLM 模型在 Xeon 平台上进行了优化。它充分利用 Xeon 硬件的能力,实现单插槽和多插槽/多节点上的 LLM 推理的高性能和高可扩展性。

xFasterTransformer 提供了一系列 API,包括 C++ 和 Python,供终端用户将其直接集成到他们自己的解决方案或服务中。同时,xFasterTransformer 还提供了丰富的示例代码,展示了如何使用这些 API,并提供了基准测试代码和脚本以展示性能。此外,它还提供了流行 LLM 模型的网络演示。

模型支持矩阵

模型名称框架支持C++ 支持分布式支持
ChatGLM支持支持支持
ChatGLM2支持支持支持
ChatGLM3支持支持支持
GLM4支持支持支持
Llama支持支持支持
Llama2支持支持支持
Llama3支持支持支持
Baichuan支持支持支持
Baichuan2支持支持支持
QWen支持支持支持
QWen2支持支持支持
SecLLM(YaRN-Llama)支持支持支持
Opt支持支持支持
Deepseek-coder支持支持支持
gemma支持支持支持
gemma-1.1支持支持支持
codegemma支持支持支持

数据类型支持列表

xFasterTransformer 支持多种数据类型,以适应不同的性能需求:

  • FP16
  • BF16
  • INT8
  • W8A8
  • INT4
  • NF4
  • BF16_FP16
  • BF16_INT8
  • BF16_W8A8
  • BF16_INT4
  • BF16_NF4
  • W8A8_INT8
  • W8A8_int4
  • W8A8_NF4

文档资源

xFasterTransformer的文档和Wiki提供了以下资源:

  • xFasterTransformer 的介绍。
  • C++ 和 PyTorch 接口的全面 API 参考。
  • xFasterTransformer 的实际 API 使用示例。

安装指南

xFasterTransformer 提供了多种安装方式:

从 PyPI 安装

pip install xfastertransformer

使用 Docker 安装

docker pull intel/xfastertransformer:latest

运行 Docker 命令(假设模型文件在 /data/ 目录):

docker run -it \
    --name xfastertransformer \
    --privileged \
    --shm-size=16g \
    -v /data/:/data/ \
    -e "http_proxy=$http_proxy" \
    -e "https_proxy=$https_proxy" \
    intel/xfastertransformer:latest

注意:如果在多排名模式下运行时出现"总线错误",请增大 --shm-size。默认的 Docker 会限制共享内存大小为 64MB,而我们的实现使用了许多共享内存以实现更好的性能。

从源码构建

准备环境

手动方式:

  • PyTorch v2.3 (使用 PyTorch API 时需要安装,但使用 C++ API 时不需要)。
pip install torch --index-url https://download.pytorch.org/whl/cpu

对于 GPU,xFT 需要从 torch==2.3.0+cpu.cxx11.abi 获取 ABI=1,因为 DPC++ 需要 ABI=1。

安装依赖库

请安装 libnuma 包:

  • CentOS: yum install libnuma-devel
  • Ubuntu: apt-get install libnuma-dev
如何构建

使用 'CMake' 进行构建:

# 构建 xFasterTransformer
git clone https://github.com/intel/xFasterTransformer.git xFasterTransformer
cd xFasterTransformer
git checkout <latest-tag>
# 确保安装 torch,当运行 Python 示例时
mkdir build && cd build
cmake ..
make -j

使用 python setup.py

# 构建 xFasterTransformer 库和 C++ 示例。
python setup.py build

# 安装 xFasterTransformer 到 pip 环境。
# 注意:安装前请运行 `python setup.py build`!
python setup.py install

模型准备

xFasterTransformer 支持与 Huggingface 不同的模型格式,但它与 FasterTransformer 的格式兼容。

  1. 首先下载 Huggingface 格式的模型。
  2. 然后,使用 xfastertransformer 的模型转换模块将模型转换成 xFasterTransformer 格式。如果未提供输出目录,转换后的模型将被放置到 ${HF_DATASET_DIR}-xft
python -c 'import xfastertransformer as xft; xft.LlamaConvert().convert("${HF_DATASET_DIR}","${OUTPUT_DIR}")'

备注:由于可能存在模型文件与 transformers 版本之间的兼容性问题,请选择合适的 transformers 版本。

支持的模型转换列表:

  • LlamaConvert
  • YiConvert
  • GemmaConvert
  • ChatGLMConvert
  • ChatGLM2Convert
  • ChatGLM4Convert
  • OPTConvert
  • BaichuanConvert
  • Baichuan2Convert
  • QwenConvert
  • Qwen2Convert
  • DeepseekConvert

API 使用

有关更多详细信息,请参阅 API 文档和示例

Python API (PyTorch)

首先,请安装依赖项。

  • Python 依赖项
pip install -r requirements.txt

备注:由于可能存在模型文件与 transformers 版本之间的兼容性问题,请选择合适的 transformers 版本。

  • oneCCL(用于多排名)
    安装 oneCCL 并设置环境。请参阅 准备环境

xFasterTransformer 的 Python API 类似于 transformers,还支持 transformers 的 streamer 来实现流式输出。示例中,我们使用 transformers 将输入提示编码为 token ids。

import xfastertransformer
from transformers import AutoTokenizer, TextStreamer
# 假设 Huggingface 模型目录是 `/data/chatglm-6b-hf` 和转换后的模型目录是 `/data/chatglm-6b-xft`。
MODEL_PATH="/data/chatglm-6b-xft"
TOKEN_PATH="/data/chatglm-6b-hf"

INPUT_PROMPT = "Once upon a time, there existed a little girl who liked to have adventures."
tokenizer = AutoTokenizer.from_pretrained(TOKEN_PATH, use_fast=False, padding_side="left", trust_remote_code=True)
streamer = TextStreamer(tokenizer, skip_special_tokens=True, skip_prompt=False)

input_ids = tokenizer(INPUT_PROMPT, return_tensors="pt", padding=False).input_ids
model = xfastertransformer.AutoModel.from_pretrained(MODEL_PATH, dtype="bf16")
generated_ids = model.generate(input_ids, max_length=200, streamer=streamer)

C++ API

可以使用 SentencePiece 来标记和解标记文本。

#include <vector>
#include <iostream>
#include "xfastertransformer.h"
// ChatGLM 提示 "Once upon a time, there existed a little girl who liked to have adventures." 的 token ids
std::vector<int> input(
        {3393, 955, 104, 163, 6, 173, 9166, 104, 486, 2511, 172, 7599, 103, 127, 17163, 7, 130001, 130004});

// 假设转换后的模型目录是 `/data/chatglm-6b-xft`。
xft::AutoModel model("/data/chatglm-6b-xft", xft::DataType::bf16);

model.config(/*最大长度*/ 100, /*光束数*/ 1);
model.input(/*输入 token ids*/ input, /*批量大小*/ 1);

while (!model.isDone()) {
    std::vector<int> nextIds = model.generate();
}

std::vector<int> result = model.finalize();
for (auto id : result) {
    std::cout << id << " ";
}
std::cout << std::endl;

如何运行

建议预加载 libiomp5.so 以获得更好的性能。

  • [推荐方式] 如果安装了 xfastertransformer's Python wheel 包,则运行 export $(python -c 'import xfastertransformer as xft; print(xft.get_env())')
  • libiomp5.so 文件在成功构建 xFasterTransformer 后会在 3rdparty/mkl/lib 目录中。

单排名运行

FasterTransformer 将自动检查 MPI 环境,或者可以使用 SINGLE_INSTANCE=1 环境变量强制停用 MPI。

多排名运行

命令行

使用 MPI 在多排名模式下运行,请先安装 oneCCL。

  • oneCCL 安装指南

    • 如果您已从源码构建 xfastertransformer,oneCCL 在编译时已安装在 3rdparty 中。
      source ./3rdparty/oneccl/build/_install/env/setvars.sh
      
    • [推荐方式] 使用提供的脚本从源码构建。
      cd 3rdparty
      sh prepare_oneccl.sh
      source ./oneccl/build/_install/env/setvars.sh
      
    • 通过安装 Intel® oneAPI Base Toolkit 安装 oneCCL。(注意:推荐使用 2023.x 及以下版本。) 并通过以下命令设置环境:
      source /opt/intel/oneapi/setvars.sh
      
  • 本地示例。

    # 或者手动设置 export LD_PRELOAD=libiomp5.so
    export $(python -c 'import xfastertransformer as xft; print(xft.get_env())')
    OMP_NUM_THREADS=48 mpirun \
      -n 1 numactl -N 0  -m 0 ${RUN_WORKLOAD} : \
      -n 1 numactl -N 1  -m 1 ${RUN_WORKLOAD} 
    
示例代码

有关更多详细信息,请参考示例。

Python

model.rank 可以获取进程的排名,model.rank == 0 是主节点。
对于从节点,在加载模型后,只需要调用 model.generate()。输入和生成配置将自动同步。

model = xfastertransformer.AutoModel.from_pretrained("/data/chatglm-6b-xft", dtype="bf16")

# 从节点
while True:
    model.generate()
C++

model.getRank() 可以获取进程的排名,model.getRank() == 0 是主节点。
对于从节点,可以输入任何值到 model.config()model.input,因为主节点的值将被同步。

xft::AutoModel model("/data/chatglm-6b-xft", xft::DataType::bf16);

// 从节点
while (1) {
    model.config();
    std::vector<int> input_ids;
    model.input(/*输入 token ids*/ input_ids, /*批量大小*/ 1);

    while (!model.isDone()) {
        model.generate();
    }
}

网络演示

项目仓库中提供了一个基于 Gradio 的网络 Demo。现在支持 ChatGLM、ChatGLM2 和 Llama2 模型。

  • 准备模型

  • 安装依赖项

    pip install -r examples/web_demo/requirements.txt
    

    注意:由于可能存在模型文件与 transformers 版本之间的兼容性问题,请选择合适的 transformers 版本。

  • 运行与模型对应的脚本。网络服务器启动后,打开输出的 URL 即可使用该演示。请指定模型和标记器目录路径以及数据类型。transformers 的标记器用于文本编码和解码,因此 ${TOKEN_PATH} 是 Huggingface 模型目录。本演示还支持多排名。

# 推荐预加载 `libiomp5.so` 以获得更好的性能。
# 或者手动设置 LD_PRELOAD=libiomp5.so,`libiomp5.so` 文件在成功构建 xFasterTransformer 后会在 `3rdparty/mkl/lib` 目录中。
export $(python -c 'import xfastertransformer as xft; print(xft.get_env())')
python examples/web_demo/ChatGLM.py \
                      --dtype=bf16 \
                      --token_path=${TOKEN_PATH} \
                      --model_path=${MODEL_PATH}

服务支持

vLLM

已创建 vLLM 的一个分支,以集成 xFasterTransformer 后端,并保持与官方 vLLM 的大多数功能兼容。详情请参见此链接

安装
pip install vllm-xft

注意:请不要同时在环境中安装 vllm-xftvllm。虽然包名不同,但它们实际上会相互覆盖。

OpenAI 兼容服务器

注意:需要预加载 libiomp5.so!

# 通过以下命令预加载 libiomp5.so 或者手动设置 LD_PRELOAD=libiomp5.so
export $(python -c 'import xfastertransformer as xft; print(xft.get_env())')

python -m vllm.entrypoints.openai.api_server \
        --model ${MODEL_PATH} \
        --tokenizer ${TOKEN_PATH} \
        --dtype bf16 \
        --kv-cache-dtype fp16 \
        --served-model-name xft \
        --port 8000 \
        --trust-remote-code

对于多排名模式,请将 python -m vllm.entrypoints.slave 用作从节点,并让从节点的参数与主节点保持一致。

# 通过以下命令预加载 libiomp5.so 或者手动设置 LD_PRELOAD=libiomp5.so
export $(python -c 'import xfastertransformer as xft; print(xft.get_env())')

OMP_NUM_THREADS=48 mpirun \
        -n 1 numactl --all -C 0-47 -m 0 \
          python -m vllm.entrypoints.openai.api_server \
            --model ${MODEL_PATH} \
            --tokenizer ${TOKEN_PATH} \
            --dtype bf16 \
            --kv-cache-dtype fp16 \
            --served-model-name xft \
            --port 8000 \
            --trust-remote-code \
        : -n 1 numactl --all -C 48-95 -m 1 \
          python -m vllm.entrypoints.slave \
            --dtype bf16 \
            --model ${MODEL_PATH} \
            --kv-cache-dtype fp16

FastChat

xFasterTransformer 是 FastChat 的官方推理后端。有关更多详情,请参阅 FastChat 中的 xFasterTransformerFastChat 的服务

MLServer

提供了一个MLServer 的示例服务,它支持 REST 和 gRPC 接口以及自适应批处理功能,可以动态组合推理请求。

基准测试

提供了基准测试脚本,以快速获取模型推理性能。

  • 准备模型
  • 安装依赖项,包括 oneCCL 和 Python 依赖项。
  • 进入 benchmark 文件夹并运行 run_benchmark.sh。更多信息请参见基准测试 README

注意!!!:系统和 CPU 配置可能不同。为了获得最佳性能,请根据测试环境的实际情况尝试修改 OMP_NUM_THREADS、数据类型和内存节点号(使用 numactl -H 查看内存节点)。

技术支持

已接受论文

如果 xFT 对您的研究有帮助,请引用:

@article{he2024distributed,
  title={Distributed Inference Performance Optimization for LLMs on CPUs},
  author={He, Pujiang and Zhou, Shan and Li, Changqing and Huang, Wenhuan and Yu, Weifei and Wang, Duyi and Meng, Chen and Gui, Sheng},
  journal={arXiv preprint arXiv:2407.00029},
  year={2024}
}

@inproceedings{he2024inference,
  title={Inference Performance Optimization for Large Language Models on CPUs},
  author={He, Pujiang and Zhou, Shan and Huang, Wenhuan and Li, Changqing and Wang, Duyi and Guo, Bin and Meng, Chen and Gui, Sheng and Yu, Weifei and Xie, Yi},
  booktitle={ICML 2024 Workshop on Foundation Models in the Wild}
}

常见问题解答

  • :xFasterTransformer 可以运行在 Intel® Core™ CPU 上吗? :不可以。xFasterTransformer 需要支持 AMX 和 AVX512 指令集,而这些指令集在 Intel® Core™ CPU 上并不可用。

  • :xFasterTransformer 可以在 Windows 系统上运行吗? :没有对 Windows 的原生支持,且所有的兼容性测试只在 Linux 上进行,所以推荐使用 Linux。

  • :为什么在通过 oneAPI 安装最新版 oneCCL 后运行多排名模式时程序会卡住或退出,并出现错误? :请尝试将 oneAPI 降级到 2023.x 或以下版本,或使用提供的脚本从源码安装 oneCCL。

  • :为什么在使用两个 CPU 插槽运行程序时的性能明显低于在单个 CPU 插槽上运行时? :这样运行会导致程序进行许多不必要的跨插槽通信,严重影响性能。如果需要进行跨插槽部署,考虑在每个插槽上运行一个排名的多排名模式。

  • :为什么在单排名运行时性能正常,但使用 MPI 运行多个排名时性能非常慢且CPU利用率非常低? :这是因为通过 MPI 启动的程序读取了 OMP_NUM_THREADS=1,无法正确从环境中获取合适的值。需要根据实际情况手动设置 OMP_NUM_THREADS 的值。

  • :为什么在转换已支持的模型时仍然出现错误? :尝试将 transformer 降级到合适的版本,比如 requirements.txt 中指定的版本。这是因为不同版本的 Transformer 可能会更改某些变量的名称。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号