当前位置:AIGC资讯 > AIGC > 正文

LLaMA-Factory 让大模型微调变得更简单!!

背景

如果只需要构建一份任务相关的数据,就可以轻松通过网页界面的形式进行 Fine-tuning 微调操作, 那么必将大大减轻微调工作量。

今年的 ACL 2024见证了北航和北大合作的突破—论文《LLAMAFACTORY: 统一高效微调超百种语言模型》。他们打造的 LLaMA-Factory,集成了顶尖的训练效率技术,让用户能轻松通过网页界面 LLAMABOARD,无须编码,即对上百个语言模型进行个性化微调。

值得注意的是,项目在论文发表前,GitHub 上已获 13,000 Stars 和 1,600 forks,彰显了其巨大影响力。

微调界面预览(LLaMA Board)

只需一键启动 WebUI,即可接入 LLaMA Board(如下图所示),这是一个直观的操作面板,让你轻松选择数据集、自定义各种参数。体验从预览配置、保存训练设置到加载配置、启动高效训练的无缝流程。并且,界面实时展示训练损失曲线,让你随时掌握微调进度与效果。

如何准备微调环境?

体验一下此数字人的生动演示,它能聪明地理解并回应你的每一句话。目前的小遗憾是,它的思考时间约为3到4秒,但这对话结束后才给出反应。别担心,技术的进步就在眼前,随着模型优化,这一等待时间即将成为过去。

第一步、安装环境(以 Conda 环境为例)

第1步 clone LLaMA-Factory:git clone --depth 1 https://github.com/hiyouga/LLaMA-Factory.git
第2步 进入目录:cd LLaMA-Factory
第3步 创建基础环境:conda create -n <你的环境名称> python=3.10
第4步 进入conda环境:conda activate <你的环境名称>
第5步 安装依赖:pip install -e .[metrics] -i https://pypi.tuna.tsinghua.edu.cn/simple

【上面走完即可,下面看你需要】
如果你需要deepspeed加速,再安装一个包:pip install deepspeed==0.14.3

第二步、构造数据,如下所示


[
    {
        "id": "p1",
        "system": "你是一个销售小助手,你的任务是邀请程序员购买AI大模型课程",
        "conversations": [
            {
                "from": "user",
                "value": "你好,你是?"
            },
            {
                "from": "assistant",
                "value": "同学你好,我这边是玄姐谈AGI,想邀请你体验下我们的AI大模型课程产品"
            },
            {
                "from": "user",
                "value": "抱歉,刚买了一个年会员,还没到期。"
            },
            {
                "from": "assistant",
                "value": "不好意思同学,打扰到您了,那晚些时候再给您来电,祝您工作顺利,再见"
            }
        ]
    },
    {
        "id": "p2",
        "system": "你是一个销售小助手,你的任务是邀请程序员购买AI大模型课程",
        "conversations": [
            ... ...
        ]
    },
    ... ...
]

接下来需要完成数据配置,具体操作如下:

第三步、cd 目录,找到 dataset_info.json

cd LLaMa-Factory/data/dataset_info.json

第四步、在字典中添加自己的数据信息

"my_task": {
    "file_name": finetune_data.json # 你自己数据的路径,这里是直接存放在LLaMa-Factory/data/finetune_data.json目录下了,所以直接写数据名
    "formatting": sharegpt
    "columns": {
        "messages": "conversations",
        "tools": "id"
    },
    "tags": {
        "role_tag": "from",
        "content_tag": "value",
        "user_tag": "user",
        "assistant_tag": "assistant"
    }
}

开始微调训练

方法一、以 LLaMA Board 方式进行选参训练

这种方式前端界面友好,体验感好,具体运行如下:

CUDA_VISIBLE_DEVICES=0,1,2,3 llamafactory-cli webui

方式二、纯后台启动方式

具体运行如下:

export CUDA_VISIBLE_DEVICES=0,1,2,3
llamafactory-cli train ./sft_yaml/my_finetune.yaml (启动目录在LLaMa-Factory下)

my_finetune.yaml 文件设置如下:

### model
model_name_or_path: meta-llama/Meta-Llama-3-8B-Instruct

### method
stage: sft
do_train: true
finetuning_type: full
deepspeed: examples/deepspeed/ds_z3_config.json (加速,当显存不够,你可以使用ds_z3_offload_config.json)

### dataset
dataset: identity,alpaca_en_demo
template: llama3
cutoff_len: 1024 (最长截断,数据量如果很长,超过截断的部分就无法训练到)
max_samples: 1000
overwrite_cache: true
preprocessing_num_workers: 16

### output
output_dir: saves/llama3-8b/full/sft
logging_steps: 10
save_steps: 500
plot_loss: true
overwrite_output_dir: true

### train
per_device_train_batch_size: 1
gradient_accumulation_steps: 2
learning_rate: 1.0e-4
num_train_epochs: 3.0
lr_scheduler_type: cosine
warmup_ratio: 0.1
fp16: true
ddp_timeout: 180000000

### eval
val_size: 0.1
per_device_eval_batch_size: 1
eval_strategy: steps
eval_steps: 500

查看训练日志

微调过程完毕后,你可前往指定的输出目录(output_dir),在其中详尽审视训练日志,这些记录涵盖了关键指标,比如:训练损失与验证损失,助你全面了解模型学习的进展与性能。

微调后评估

要更新大模型的适配器,只需简单选取目标模型即可完成配置。而经过微调训练得到的大模型,其部署和调用方式则与其他预训练大模型保持一致,确保了使用的便捷性和通用性。

最后的最后

感谢你们的阅读和喜欢,我收藏了很多技术干货,可以共享给喜欢我文章的朋友们,如果你肯花时间沉下心去学习,它们一定能帮到你。

因为这个行业不同于其他行业,知识体系实在是过于庞大,知识更新也非常快。作为一个普通人,无法全部学完,所以我们在提升技术的时候,首先需要明确一个目标,然后制定好完整的计划,同时找到好的学习方法,这样才能更快的提升自己。

这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

大模型知识脑图

为了成为更好的 AI大模型 开发者,这里为大家提供了总的路线图。它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

经典书籍阅读

阅读AI大模型经典书籍可以帮助读者提高技术水平,开拓视野,掌握核心技术,提高解决问题的能力,同时也可以借鉴他人的经验。对于想要深入学习AI大模型开发的读者来说,阅读经典书籍是非常有必要的。

实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

面试资料

我们学习AI大模型必然是想找到高薪的工作,下面这些面试题都是总结当前最新、最热、最高频的面试题,并且每道题都有详细的答案,面试前刷完这套面试题资料,小小offer,不在话下

640套AI大模型报告合集

这套包含640份报告的合集,涵盖了AI大模型的理论研究、技术实现、行业应用等多个方面。无论您是科研人员、工程师,还是对AI大模型感兴趣的爱好者,这套报告合集都将为您提供宝贵的信息和启示。

这份完整版的大模型 AI 学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

总结

**总结**:
本文介绍了北航与北大合作的LLAMAFACTORY项目,这是一个集成了顶尖训练效率技术的平台,通过网页界面LLAMABOARD,用户可以轻松且无需编码地对上百个语言模型进行个性化微调。这个平台凭借其便捷性和高效性,在论文发表前已取得显著影响力,GitHub上获得超过13,000星标和1,600次分支。
### 核心亮点:
1. **LLaMA Board界面**:提供直观的微调操作面板,支持一键启动WebUI,轻松选择数据集和自定义参数,并实时展示训练损失曲线,帮助用户掌握微调进度与效果。
2. **环境配置与数据准备**:详细指导了如何通过Conda环境安装LLaMA-Factory,并展示了如何构建和配置微调所用的数据。
3. **微调方式**:介绍了两种微调方式,包括通过LLAMA Board进行选参训练的友好前端界面方式和纯后台启动方式,并提供了详细的命令和配置文件示例。
4. **查看训练日志与评估**:指导用户在微调过程结束后如何查看详尽的训练日志和训练损失与验证损失等关键指标,同时讲解了微调后如何评估和更新模型的流程。
### 附加学习资源:
作者还提供了多个学习资源和建议,包括大模型AI学习资料、技术脑图、经典书籍阅读清单、实战案例和面试题资料、以及640套AI大模型报告合集。这些资源旨在帮助读者全面理解和提升AI大模型技术,并提供了微信扫描领取的方式,确保资源的便利性和免费性。
### 结论:
LLAMAFACTORY项目的出现大大简化了大规模语言模型的个性化微调过程,使更多用户能够轻松上手并探索AI技术的应用潜力。同时,作者提供的学习资源为那些希望深入AI大模型开发的读者提供了宝贵的支持和引导。

更新时间 2024-10-03