Project Icon

SwiftInfer

AI 推理和服务

SwiftInfer 采用基于 TensorRT 的 Streaming-LLM 技术,提升长文本输入处理的有效性。借助 Attention Sink 技术,避免模型在注意力窗口变动时发生故障,确保在生产环境中的高效运行,非常适合对推理效率和稳定性要求高的大模型应用。

SwiftInfer 项目介绍

项目概述

SwiftInfer 是一个基于 TensorRT 实现的工具,旨在为大规模语言模型(LLM)的推理提供无限输入长度的支持。其核心技术来源于 Streaming-LLM,这是一种利用“注意力水槽”技术防止模型在注意力窗口移动时崩溃的方法。最初,Streaming-LLM 是用 PyTorch 实现的,而 SwiftInfer 则进一步提供了生产级别的 TensorRT 实现。这一实现是构建在最近发布的 TensorRT-LLM 项目基础上的。

快速开始

安装指南

SwiftInfer 依赖于 TensorRT-LLM 的 API 来构建模型和进行推理。由于 TensorRT-LLM 的 API 变化较快,SwiftInfer 将当前版本绑定在 42af740db51d6f11442fd5509ef745a4c043ce51 这次提交上(版本为 v0.6.0)。未来会根据 API 的稳定性进行升级。

如果你已经构建了 TensorRT-LLM V0.6.0,只需执行以下命令即可安装 SwiftInfer:

git clone https://github.com/hpcaitech/SwiftInfer.git
cd SwiftInfer
pip install .
使用 Docker 安装 TensorRT-LLM

通过 Docker,可以按照 TensorRT-LLM 提供的安装指南来安装所需版本。具体命令为:

git clone https://github.com/hpcaitech/SwiftInfer.git
cd SwiftInfer
pip install .
不使用 Docker 安装 TensorRT-LLM

在没有 Docker 的情况下,可以使用自动化脚本安装 TensorRT-LLM。需要确保系统已安装一些基本的包,例如 python、CUDA 工具包、cuDNN 等,且 TensorRT 版本需大于等于 9.1.0,CUDA 工具包版本需大于等于 12.2。

接着执行以下安装操作:

ARCH=$(uname -m)
if [ "$ARCH" = "arm64" ];then ARCH="aarch64";fi
if [ "$ARCH" = "amd64" ];then ARCH="x86_64";fi
if [ "$ARCH" = "aarch64" ];then OS="ubuntu-22.04"; else OS="linux";fi
wget https://developer.nvidia.com/downloads/compute/machine-learning/tensorrt/secure/9.1.0/tars/tensorrt-9.1.0.4.$OS.$ARCH-gnu.cuda-12.2.tar.gz
tar xzvf tensorrt-9.1.0.4.linux.x86_64-gnu.cuda-12.2.tar.gz
PY_VERSION=$(python -c 'import sys; print(".".join(map(str, sys.version_info[0:2])))')
PARSED_PY_VERSION=$(echo "${PY_VERSION//./}")
pip install TensorRT-9.1.0.4/python/tensorrt-*-cp${PARSED_PY_VERSION}-*.whl
export TRT_ROOT=$(realpath TensorRT-9.1.0.4)

要保证 nvcc 配置正确,可以通过 nvcc --version 来验证配置。

然后,可以通过以下命令安装 TensorRT-LLM 及 SwiftInfer:

git clone https://github.com/hpcaitech/SwiftInfer.git
cd SwiftInfer
TRT_ROOT=xxx NCCL_ROOT=xxx CUDNN_ROOT=xxx pip install .

运行 Llama 示例

要运行 Llama 模型的示例,需要先克隆 Hugging Face 上的相关仓库,比如 meta-llama/Llama-2-7b-chat-hf 或其他 Llama 变体。然后通过以下命令构建 TensorRT 引擎(需要将 <model-dir> 替换为实际模型路径):

cd examples/llama

python build.py \
--model_dir <model-dir> \
--dtype float16 \
--enable_context_fmha \
--use_gemm_plugin float16 \
--max_input_len 2048 \
--max_output_len 1024 \
--output_dir ./output/7B-streaming-8k-1k-4-2000/trt_engines/fp16/1-gpu/ \
--max_batch_size 1

下载 MT-Bench 数据:

mkdir mt_bench_data
wget -P ./mt_bench_data https://raw.githubusercontent.com/lm-sys/FastChat/main/fastchat/llm_judge/data/mt_bench/question.jsonl

最后,使用以下命令运行 Llama 示例:

python ../run_conversation.py \
--max_input_length 2048 \
--max_output_len 1024 \
--tokenizer_dir <model-dir> \
--engine_dir ./output/7B-streaming-8k-1k-4-2000/trt_engines/fp16/1-gpu/ \
--input_file ./mt_bench_data/question.jsonl \
--streaming_llm_start_size 4 \
--only_n_first 5

运行后,可以看到模型生成的输出。

性能基准

SwiftInfer 已通过与原始 PyTorch 版本的 Streaming-LLM 进行基准测试。使用的硬件包括 Nvidia H800 GPU(80GB)、Intel® Xeon® Platinum 8468 CPU 及 2TB 内存。在二十次会话中,SwiftInfer 显示出显著的性能优势,并将继续努力提高性能和适配更新版本的 TensorRT API。

项目规划

  • 完成基于 TRT-LLM 的注意力实现
  • 适配 KV 缓存
  • 适配提前终止
  • 修复连续张量问题
  • 支持多轮对话的 Llama 示例

鸣谢

在开发过程中,SwiftInfer 受到了 Streaming-LLM 项目的启发,并参考了多种开源材料和学术贡献,特此鸣谢。

项目侧边栏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号