这是RISC-V跑大模型系列的第二篇文章,主要教大家如何将LLaMA移植到RISC-V环境里。
1)最新版Python
2)确保机器有足够的内存加载完整模型(7B模型需要13~15G)
3)下载原版LLaMA模型和扩展了的中文模型
LLaMA原版模型:
https://ipfs.io/ipfs/Qmb9y5GCkTG7ZzbBWMu2BXwMkzyCKcUjtEKPpgdZ7GEFKm/
从LLaMA原版模型地址上下载下述文件(我们使用的是7B):
最后文件下载完成后的结果如下:
1)这一步需要下载llama.cpp,请输入以下命令进行下载和编译:
git clone https://github.com/ggerganov/llama.cpp && cd llama.cpp && make
2)将第二步下载的文件移到llama.cpp/models/下,使用命令:
python3 convert-pth-to-ggml.py models/7B/ 0
3)将.pth模型权重转换为ggml的FP32格式,生成文件路径为models/7B/ggml-model-f32.bin。
4)运行./main二进制文件,-m命令指定Q4量化模型(也可加载ggml-FP16的模型)。以下是解码参数:
./main models/7B/ggml-model-f32.bin --color -f prompts/alpaca.txt -ins -c 256 --temp 0.2 -n 128 --repeat_penalty 1.3
参数解释:
-ins | 启动类ChatGPT对话交流的运行模式 |
-f | 指定prompt模板,alpaca模型请加载prompts/alpaca.txt |
-c | 控制上下文的长度,值越大越能参考更长的对话历史(默认:512) |
-n | 控制回复生成的最大长度(默认:128) |
-t | 控制batch size(默认:8),可适当增加 |
--repeat_penalty | 控制线程数量(默认:4),可适当增加 |
--temp | 控制线程数量(默认:4),可适当增加 |
--top_p, top_k |
控制解码采样的相关数据 |
本篇教程到这里就结束了。是不是觉得LLaMA的速度比较慢而且不支持中文,没关系,在下一期中,我们会为LLaMA扩充中文,并优化加速LLaMA,记得继续关注我们哦。
另外,RISC -V跑大模型系列文章计划分为四期:
1. RISC -V跑大模型(一)
2. RISC-V 跑大模型(二):LLaMA零基础移植教程(本篇)
3. LLaMA扩充中文+优化加速(计划)
4. 更多性能优化策略。(计划)
审核编辑 黄宇
全部0条评论
快来发表一下你的评论吧 !