使用LoRA方法在单个16G GPU上微调LLaMA模型

RayRay
LLaMA微调GPUVicuna语料库Github开源项目

llama-lora-fine-tuning

引言

大型语言模型(LLM)如LLaMA的微调一直是自然语言处理领域的一个热点话题。然而,由于这类模型参数量巨大,传统的微调方法往往需要强大的硬件支持。本文将介绍如何使用LoRA(Low-Rank Adaptation)方法,在单个16G GPU上对LLaMA模型进行高效微调,使得普通研究者也能参与到LLM的优化中来。

LoRA微调方法概述

LoRA是一种参数高效的微调技术,它通过只训练一小部分新增的低秩矩阵来适应下游任务,而保持预训练模型的大部分参数不变。这种方法大大降低了计算和内存需求,使得在有限资源下微调大型模型成为可能。

本项目基于FastChat,修改了LoRA训练代码,使用shareGPT语料库在16G显存的GPU上进行微调,内存占用约13G。主要技术要点包括:

  1. 使用LoRA方法只训练部分参数
  2. 采用半精度的llama-7b-hf作为基础模型
  3. 使用load_in_8bit加载基础模型
  4. 使用peft技术进行微调
  5. 使用bitsandbytes加速训练

环境配置

在开始微调之前,需要先配置好相关环境:

  1. 操作系统:centos或ubuntu
  2. GPU:NVIDIA P100或T4,16G及以上显存
  3. CUDA和conda环境

具体安装步骤如下:

  1. 克隆项目代码
git clone https://github.com/git-cloner/llama-lora-fine-tuning
cd llama-lora-fine-tuning
  1. 安装依赖包
conda create -n llama-lora python=3.10
conda activate llama-lora
pip3 install -r requirements.txt
  1. 安装其他必要组件,如pkg-config和libicu

准备LLaMA模型

微调需要使用LLaMA模型作为基础。你可以下载原始模型并转换为半精度,或直接下载转换好的半精度模型。

  1. 下载LLaMA模型
python -m llama.download --model_size 7B
  1. 转换为Hugging Face格式
python3 ./convert_llama_weights_to_hf.py --input_dir ./pyllama_data --model_size 7B --output_dir ./pyllama_data/output/7B

准备语料库

高质量的训练数据对模型微调至关重要。本项目使用shareGPT语料库,具体步骤如下:

  1. 下载shareGPT语料库
  2. 合并语料文件
  3. 将HTML转换为Markdown格式
  4. 移除不需要的语言(可选)
  5. 将长对话拆分成短对话

这些步骤可以通过项目提供的Python脚本完成。

模型微调

准备好模型和数据后,就可以开始微调过程:

CUDA_VISIBLE_DEVICES=0,1 \ deepspeed --num_gpus=2 fastchat/train/train_lora.py \ --deepspeed ./deepspeed-config.json \ --lora_r 8 \ --lora_alpha 16 \ --lora_dropout 0.05 \ --model_name_or_path ./pyllama_data/output/7B \ --data_path ./data/sharegpt_clean_split.json \ --fp16 True \ --output_dir ./output \ --num_train_epochs 1 \ --per_device_train_batch_size 14 \ --per_device_eval_batch_size 14 \ --gradient_accumulation_steps 1 \ --evaluation_strategy "no" \ --save_strategy "steps" \ --save_steps 2400 \ --save_total_limit 5 \ --learning_rate 2e-5 \ --weight_decay 0. \n --warmup_ratio 0.03 \ --lr_scheduler_type "cosine" \ --logging_steps 1 \ --model_max_length 512 \ --gradient_checkpointing True

在P100(16G)上微调时,内存占用约13.5G。单轮训练需要120小时左右,约5天时间。model_max_length参数会影响训练时间,设置为1024时训练时间约为2048的一半,但可能影响推理效果。

如果使用A100 GPU,单卡微调只需约16小时。

测试微调后的模型

微调完成后,trained LoRa peft模型包含adapter_config.json、adapter_model.bin和trainer_state.json三个文件。可以使用以下命令测试模型:

CUDA_VISIBLE_DEVICES=0 python generate.py --base_model ./model/llama-7b --lora_weights ./model/llama-peft

结论

通过LoRA技术,我们成功在单个16G GPU上对LLaMA模型进行了微调。这为研究者和开发者提供了一种经济实惠的方式来定制和优化大型语言模型。尽管训练时间较长,但相比传统方法大大降低了硬件门槛。未来,随着更多高效微调技术的出现,我们有望看到更多创新性的LLM应用。

本项目为LLM微调领域提供了宝贵的实践经验,希望能够启发更多研究者参与到这一激动人心的领域中来。同时,也期待社区能够基于此项目,开发出更多高效、实用的LLM微调方案。

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多