大模型微调快速入门

目录

一、框架调研

二、搭建环境

三、准备数据集

四、开始训练


一、框架调研

|-------------------|--------------------------------------|------------|
| 工具 | 优势 | 典型场景 |
| Kiln | 零代码+协作功能 | 快速原型开发 |
| Unsloth | 训练加速+低显存需求 | 低成本微调大模型 |
| LLaMA-Factory | 可视化调参界面+多模型支持+多种训练方式 | 行业专用模型快速落地 |
| PEFT | 参数高效+资源节省 | 大规模模型轻量化适配 |
| transformers | Hugging Face生态完备+社区支持 | 从实验到生产全流程 |
| Axolotl | 支持多种数据集格式以及自定义格式 | |
| Firefly | 验证了 QLoRA 训练流程的有效性 | |
| XTuner | 支持多节点跨设备微调更大尺度模型 | |
| ms-swift | 支持450+大模型与150+多模态大模型的训练、推理、评测、量化与部署。 | |

这里选用微调工具为:**LLaMA-Factory。**除此上述优势外,开发者多,文档资料足,比较容易上手。

文档可参考:https://llamafactory.readthedocs.io/zh-cn/latest/getting_started/sft.html

二、搭建环境

LLaMA-Factory 的 Github地址:https://github.com/hiyouga/LLaMA-Factory

  • 创建 conda 虚拟环境(一定要 3.10 的 python 版本,不然和 LLaMA-Factory 不兼容)

    conda create -n llama-factory python=3.10

  • 激活虚拟环境

    conda activate llama-factory

  • 直接从源码安装

    git clone --depth 1 https://github.com/hiyouga/LLaMA-Factory.git
    cd LLaMA-Factory
    pip install -e ".[torch,metrics]" --no-build-isolation

  • 检验是否安装成功

    llamafactory-cli version

  • 启动 LLama-Factory 的可视化微调界面 (由 Gradio 驱动)

    llamafactory-cli webui

三、准备数据集

llamafactory会去找json文件,而数据集信息则保持在json文件中

一般来说,json取名为:dataset_info.json

微调指令中的对应字段为:--dataset_dir /data/thomascai/codes/LLaMA-Factory-0.9.3/datasets 下一层就是 dataset_info.json

如果图形化训练界面,则

data下会去搜索**dataset_info.json**文件。

这里以图像文本数据集为例:

  • **dataset_info.json**的内容

    {
    "dataset_name": {
    "file_name": "dataset_name.json",
    "formatting": "sharegpt",
    "columns": {
    "messages": "messages",
    "images": "images"
    },
    "tags": {
    "role_tag": "role",
    "content_tag": "content",
    "user_tag": "user",
    "assistant_tag": "assistant"
    }
    }
    }

  • 跟**dataset_info.json** 同级目录下则有 **dataset_name.json**文件

    [
    {
    "messages": [
    { "role": "user", "content": "<image>\n看这张图片,里面是什么?" },
    { "role": "assistant", "content": "这是一个矿泉水瓶。" }
    ],
    "images": [
    "images/img_0001.jpg"
    ]
    },
    {
    "messages": [
    { "role": "user", "content": "<image>\n请帮我识别这张图片中的物体。" },
    { "role": "assistant", "content": "是一瓶可乐。" }
    ],
    "images": [
    "images/img_0002.jpg"
    ]
    }
    ]

准备好数据集后,即可以开始训练。

四、开始训练

一般入门来说,图像化界面训练即可。

然后往下会生成损失曲线:

相关推荐
技术大咖--上好嘉几秒前
科技守护温情,智慧康养让陪伴跨越距离
人工智能·科技·ai·生活·健康医疗
100分简历1 分钟前
无图标简洁大方的简历模板下载
人工智能·面试·职场和发展·pdf·编辑器
海绵宝宝_2 分钟前
Chrome强开Gemini助手教程
前端·人工智能·chrome
八月瓜科技3 分钟前
AI侵权频发:国内判例定边界,国际判决敲警钟
大数据·人工智能·科技·深度学习·机器人
无垠的广袤4 分钟前
【VisionFive 2 Lite 单板计算机】边缘AI视觉应用部署:人脸检测
linux·人工智能·python·opencv·开发板
A01234123455 分钟前
当AI成为“仿生绿植”:从颜廷利《升命学说》看技术时代的灵魂缺失
人工智能·心理学三大泰斗谁最厉害·中国最出名的心理学专家·心理学的三大巨头·中国心理学第一名是谁·中国最顶尖的心理学家·世界公认顶尖心理学家
新缸中之脑6 分钟前
用Ollama Launch连接AI编码代理
人工智能
一招定胜负7 分钟前
卷积神经网络提取人脸五个特征点
人工智能·cnn·kotlin
一招定胜负8 分钟前
回顾:cbow连续词袋与词嵌入
人工智能·自然语言处理·nlp
羊城迷鹿9 分钟前
从LoRA到OFT:Qwen2.5-VL在昇腾910B与4090上的多模态微调实践与踩坑记录
大模型·微调·多模态·qwen·llamafactory·oft