llama.cpp的主要目标是在本地和云端的各种硬件上以最小的设置和最先进的性能实现LLM推理。是一个专为大型语言模型(LLM)设计的高性能推理框架,完全使用C和C++编写,没有外部依赖,这使得它可以很容易地被移植到不同的操作系统和硬件平台上。简化大型语言模型部署流程。
一、下载llama.cpp
1、访问其GitHub官方仓库:llama.cpp
data:image/s3,"s3://crabby-images/38f35/38f355f993159011e8a02a66b833eb16ef773aee" alt=""
2、在你的服务器指定路径下克隆仓库
bash
git clone https://github.com/ggerganov/llama.cpp.git
data:image/s3,"s3://crabby-images/5040a/5040a7ca25505a6875937724850f73211f2c44af" alt=""
3、安装llama.cpp所需环境
bash
pip install -r requirements.txt
data:image/s3,"s3://crabby-images/47f18/47f187bd74db61061a4785e0fc7545b970a889e8" alt=""
【注】如果你想使用其他方式安装(比如Docker),可以参考官方仓库的下面这个部分。
data:image/s3,"s3://crabby-images/2108b/2108b79647fcbf71d0a564ef44c4b202fa6e9fe6" alt=""
二、将大模型从HF格式转换为GGUF格式
1、在llama.cpp项目路径下会有一个convert_hf_to_gguf.py文件
2、执行命令进行格式转换(默认将模型转换为FP16的GGUF)
bash
python3 convert_hf_to_gguf.py <你模型所在路径>
3、模型格式转换成功后会提示GGUF格式的模型保存在了哪里
data:image/s3,"s3://crabby-images/56043/560436112c61bfc1e78766d21c5264d4be3dbd50" alt=""
4、除了可以将大模型转换为FP16的量化精度外,还可以做Q8_0量化(等多种)并导出为GGUF格式
bash
# 将模型量化为8位(使用Q8_0方法)
python convert_hf_to_gguf.py <你的模型所在路径> --outtype q8_0 --outfile <希望保存的路径>
如果你在转换格式的时候指定了量化参数,那么llama.cpp还会帮你做量化,下面是官方给出的Q4_0量化模型对比:
data:image/s3,"s3://crabby-images/032aa/032aa1bec1c6eb6d15a9d4b231b7f7e9508d844a" alt=""
llama.cpp不光支持4位量化,还支持下面多种量化。表中列出了量化前后模型性能和参数规模的bian
data:image/s3,"s3://crabby-images/b0bc4/b0bc4eb1d808f2a933b3c49ea1c30087dcb18005" alt=""
【注】 llama.cpp还提供了更多量化格式转换,说明可见下表:
data:image/s3,"s3://crabby-images/471c7/471c72ac340f12ecd7bc3374408247921cb5bd19" alt=""