首页 > 其他分享 >学大模型必看!手把手带你从零微调大模型!

学大模型必看!手把手带你从零微调大模型!

时间:2024-12-14 17:27:45浏览次数:6  
标签:必看 AI 模型 微调 yaml 学大 lora 代码

前言

今天分享一篇技术文章,你可能听说过很多大模型的知识,但却从未亲自使用或微调过大模型。

今天这篇文章,就手把手带你从零微调一个大模型。

大模型微调本身是一件非常复杂且技术难度很高的任务,因此本篇文章仅从零开始,手把手带你走一遍微调大模型的过程,并不会涉及过多技术细节。

希望通过本文,你可以了解微调大模型的流程。

1,微调简介

微调大模型需要非常高的电脑配置,比如GPU环境,相当于你在已经预训练好的基础上再对大模型进行一次小的训练。

但是不用担心,本篇文章会使用阿里魔塔社区提供的集成环境来进行,无需使用你自己的电脑配置环境。

你只需要有浏览器就可以完成。

本次微调的大模型是零一万物的 Yi 开源大语言模型,当然微调其他大模型的过程和原理也有差不多。

这里说明一下,阿里魔塔社区对于新用户提供了几十小时的免费GPU资源进行使用,正好可以来薅一波羊毛,学习一下大模型的微调

话不多说,直接开始。

2. 账号和环境准备

首先你需要注册和登录魔搭的账号:modelscope.cn/home

注册完成后,登录这个模型网址:

www.modelscope.cn/models/01ai…****.

然后按照下面的箭头操作。

![外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传](https://img-home.csdnimg.cn/images/20230724024159.png?origin_url=https%3A%2F%2Fp9-xtjj-sign.byteimg.com%2Ftos-cn-i-73owjymdk6%2F1fb0b1c66fd94095b9629ef3946278ef~tplv-73owjymdk6-jj-mark%3A0%3A0%3A0%3A0%3Aq75.awebp%3Frk3s%3Df64ab15b%26x-expires%3D1723461596%26x-signature%3DY%252FEygjDnqYPRRpcY
f%252BKR3KiMGBU%253D&pos_id=img-zsMmGqIi-1723266302004)

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

选择完方式二:GPU环境后,点击“启动”。

启动大概需要2分钟,等GPU环境启动好以后点击"查看NoteBook"进入。

魔塔社区内置了JupyterLab的功能,你进入之后,可以找到 Notebook 标签,新建一个Notebook(当然你在terminal 里执行也没问题)。

如下箭头所示,点击即可创建一个新的 Notebook 页面。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

增添一个代码块,并且执行以下命令(点击左侧的运行按钮运行该代码块,下同,这一步是安装依赖库)。

css 代码解读复制代码!pip3 install --upgrade pip!pip3 install bitsandbytes>=0.39.0

拉取 LLaMA-Factory,过程大约需要几分钟

bash 代码解读复制代码!git clone --depth 1 https://github.com/hiyouga/LLaMA-Factory.git

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

接下来需要去 Launcher > Terminal 执行(按照图片剪头指示操作)。

安装依赖的软件,这步需要的时间比较长。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

shell 代码解读复制代码# ⚠️下面两行命令在刚启动的Terminal中执行⚠️cd LLaMA-Factorypip3 install -e ".[torch,metrics]"

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

等以上所有步骤完成后,再进行下面的操作。

3. 下载模型

零一万物的 Yi 开源大语言模型的权重可以在HuggingFace和ModelScope上找到,这里我选择从ModelScope上下载。

零一万物的所有开源模型链接在这里:

www.modelscope.cn/organizatio…

模型下载需要一定的时间,这里选择了最小的Yi-1.5-6B-chat模型进行实验。

模型的说明在这里:

www.modelscope.cn/models/01ai…

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

Yi-1.5-6B-chat模型大小大约12G,下载大约需要10分钟(取决于网速)。

接下来,你通过下面的命令就可以在 notebook 里执行下载(在 terminal也一样,如果需要在terminal执行需要去掉前面的!)。

bash 代码解读复制代码!git clone https://www.modelscope.cn/01ai/Yi-1.5-6B-Chat.git

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

这一步,耐心等待下载完成即可。

4. 微调Yi模型实战

等以上所有步骤完成后,准备工作就做好了,现在可以开始准备微调了。

⚠️注意:虽然本篇文章仅仅是简单的过一遍微调的流程,但是不要低估他的难度。微调跑起来很容易,但是跑出很好的结果非常的难。

开源社区有许多非常优秀的专门用于微调代码库具体的你可以参考这里:

github.com/01-ai/Yi-1.…

站在巨人的肩膀上开始这次实战,这里选择llama_factory。

LLaMA Factory是一款开源低代码大模型微调框架,集成了业界广泛使用的微调技术。llama_factory 的介绍可以在这里查看:

github.com/hiyouga/LLa…

下面这份零基础AI大模型学习资料已经上传网盘,朋友们如果需要可以下方链接即可免费领取↓↓↓

点击领取 《AI大模型&人工智能&入门进阶学习资源包》

在这里插入图片描述

5. 开始微调

a. 创建微调训练相关的配置文件

在左侧的文件列表,Llama-Factory的文件夹里,打开examples\train_qlora(注意不是 train_lora)下提供的llama3_lora_sft_awq.yaml,复制一份并重命名为yi_lora_sft_bitsandbytes.yaml。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

这个文件里面写着和微调相关的关键参数。

打开这个文件,将第一行model_name_or_path更改为你下载模型的位置。

shell 代码解读复制代码### modelmodel_name_or_path: <你下载的模型位置,不要带括号,比如我写了../Yi-1.5-6B-Chat>

同样修改其他行的内容,下面是我的修改,你可以逐行对比一下,有不一致或缺少的就添加一下。

sql 代码解读复制代码### modelmodel_name_or_path: ../Yi-1.5-6B-Chatquantization_bit: 4### methodstage: sftdo_train: truefinetuning_type: loralora_target: all### datasetdataset: identitytemplate: yicutoff_len: 1024max_samples: 1000overwrite_cache: truepreprocessing_num_workers: 16### outputoutput_dir: saves/yi-6b/lora/sftlogging_steps: 10save_steps: 500plot_loss: trueoverwrite_output_dir: true### trainper_device_train_batch_size: 1gradient_accumulation_steps: 8learning_rate: 1.0e-4num_train_epochs: 3.0lr_scheduler_type: cosinewarmup_ratio: 0.1bf16: true# ddp_timeout: 180000000### evalval_size: 0.1per_device_eval_batch_size: 1eval_strategy: stepseval_steps: 500

从上面的配置文件中可以看到,本次微调的数据集是 identity。

那这个文件里面写着什么呢?

你可以打开这个文件看一下:github.com/hiyouga/LLa…

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

微调数据集是“自我认知”,也就是说当你问模型“你好你是谁”的时候,模型会告诉你我叫name由author开发。

如果你把数据集更改成你自己的名字,那你就可以微调一个属于你自己的大模型。

这一步,你可以将 identity.json 中的 {{name}} 字段替换为你的名字来微调一个属于自己的大模型。

保存刚才对于 yi_lora_sft_bitsandbytes.yaml 文件的更改,回到终端terminal。

在 LLaMA-Factory 目录下,输入以下命令启动微调脚本(大概需要10分钟)

bash 代码解读复制代码llamafactory-cli train examples/train_qlora/yi_lora_sft_bitsandbytes.yaml

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

看到进度条就是开始微调了。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

运行过程大概需要10分钟,当你看到下面这个界面的时候,微调过程就结束了。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

6. 推理测试

微调后的模型有什么不同的地方呢?

这里加载微调后模型进行推理,测试微调前后变化。

参考Llama-Factory文件夹中,examples\inference下提供的llama3_lora_sft.yaml,复制一份,并重命名为 yi_lora_sft.yaml

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

将内容更改为,并且保存(一定记得保存)****。

bash 代码解读复制代码model_name_or_path: <和之前一样,你下载的模型位置,比如我写了../Yi-1.5-6B-Chat>adapter_name_or_path: saves/yi-6b/lora/sfttemplate: yifinetuning_type: lora

回到刚刚结束微调的终端Terminal,运行下面的推理命令(同样在Llama-Factory目录下运行)。

bash 代码解读复制代码llamafactory-cli chat examples/inference/yi_lora_sft.yaml

稍微等待一下模型加载,然后就可以聊天了。

可以看到模型的自我身份认知被成功的更改了。

自我身份认知更改成为数据集规定的样子了,同时也保持了通用对话能力。

那么,和没有经过微调之前的模型对比有什么差别呢?

重复上面的步骤,将llama3.yaml复制并重命名为yi.yaml,将内容更改为以下的内容,并保存(一定记得保存)

makefile 代码解读复制代码model_name_or_path: ../Yi-1.5-6B-Chattemplate: chatml

回到终端Terminal,运行下面的推理命令:

bash 代码解读复制代码llamafactory-cli chat examples/inference/yi.yaml

可以提问和刚才同样的问题,看到模型的原始回答。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

基于本实验,你就完成了一个简单的微调,完整的走了一遍模型的微调过程,是不是还挺简单的?

在大模型时代,我们如何有效的去学习大模型?

现如今大模型岗位需求越来越大,但是相关岗位人才难求,薪资持续走高,AI运营薪资平均值约18457元,AI工程师薪资平均值约37336元,大模型算法薪资平均值约39607元。
在这里插入图片描述

掌握大模型技术你还能拥有更多可能性

• 成为一名全栈大模型工程师,包括Prompt,LangChain,LoRA等技术开发、运营、产品等方向全栈工程;

• 能够拥有模型二次训练和微调能力,带领大家完成智能对话、文生图等热门应用;

• 薪资上浮10%-20%,覆盖更多高薪岗位,这是一个高需求、高待遇的热门方向和领域;

• 更优质的项目可以为未来创新创业提供基石。

可能大家都想学习AI大模型技术,也_想通过这项技能真正达到升职加薪,就业或是副业的目的,但是不知道该如何开始学习,因为网上的资料太多太杂乱了,如果不能系统的学习就相当于是白学。为了让大家少走弯路,少碰壁,这里我直接把都打包整理好,希望能够真正帮助到大家_。

零基础入门AI大模型

今天贴心为大家准备好了一系列AI大模型资源,包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。

有需要的小伙伴,可以点击下方链接免费领取【保证100%免费

点击领取 《AI大模型&人工智能&入门进阶学习资源包》

1.学习路线图

在这里插入图片描述

第一阶段: 从大模型系统设计入手,讲解大模型的主要方法;

第二阶段: 在通过大模型提示词工程从Prompts角度入手更好发挥模型的作用;

第三阶段: 大模型平台应用开发借助阿里云PAI平台构建电商领域虚拟试衣系统;

第四阶段: 大模型知识库应用开发以LangChain框架为例,构建物流行业咨询智能问答系统;

第五阶段: 大模型微调开发借助以大健康、新零售、新媒体领域构建适合当前领域大模型;

第六阶段: 以SD多模态大模型为主,搭建了文生图小程序案例;

第七阶段: 以大模型平台应用与开发为主,通过星火大模型,文心大模型等成熟大模型构建大模型行业应用。

2.视频教程

网上虽然也有很多的学习资源,但基本上都残缺不全的,这是我自己整理的大模型视频教程,上面路线图的每一个知识点,我都有配套的视频讲解。

在这里插入图片描述

在这里插入图片描述

(都打包成一块的了,不能一一展开,总共300多集)

3.技术文档和电子书

这里主要整理了大模型相关PDF书籍、行业报告、文档,有几百本,都是目前行业最新的。
在这里插入图片描述

4.LLM面试题和面经合集

这里主要整理了行业目前最新的大模型面试题和各种大厂offer面经合集。
在这里插入图片描述

标签:必看,AI,模型,微调,yaml,学大,lora,代码
From: https://blog.csdn.net/weixin_49895216/article/details/144432655

相关文章

  • 一文搞懂AI大模型的四个核心技术
    前言在日新月异的生成式AI领域,几个核心的专业术语不仅频繁出现在讨论、报告和会议中,更是技术发展的关键驱动力。它们分别是:“PromptEngineering(提示工程)”、“FunctionCalling(函数调用)”、“RAG(检索增强生成)”和“Fine-tuning(微调)。•PromptEngineering(提示工程):提示......
  • 【转行大模型】大龄程序员转行AI大模型:可行性与建议!
    前言对于大龄程序员而言,转行到AI大模型领域是一个既充满挑战又极具吸引力的选择。在这个领域,您将有机会接触到最新的技术趋势,参与到前沿的项目中,并且有可能获得更高的薪酬。下面是一些具体的步骤和建议,帮助您顺利转型:一、为啥要转行做大模型?随着AI技术的快速发展,尤其是大......
  • 强化学习:SAC和SQL算法的mujoco模型文件
    SAC和SQL算法的项目地址:https://github.com/rail-berkeley/softlearningSAC和SQL算法的mujoco模型文件地址:https://github.com/rail-berkeley/softlearning/tree/master/models使用mujoco的查看器查看:python-mmujoco.viewer--mjcf=/path/to/some/mjcf.xml......
  • 一幅清晰、完整的大模型RAG 技术蓝图
    大型语言模型(LLMs)已经成为我们生活和工作的一部分,它们以惊人的多功能性和智能化改变了我们与信息的互动方式。前排提示,文末有大模型AGI-CSDN独家资料包哦!然而,尽管它们的能力令人印象深刻,但它们并非无懈可击。这些模型可能会产生误导性的“幻觉”,依赖的信息可能过时,处理......
  • 大模型+知识图谱在工业领域落地的4大场景
    对于AI技术,大家热聊的话题超90%都是围绕大模型,而知识图谱则是上一波AI浪潮中比较热门的技术。今天特邀行业专家,探讨关于大模型和知识图谱在工业领域的一些落地实践。主要分为四个部分展开:大模型和知识图谱的关系、大模型+知识图谱双擎的原理、大模型+知识图谱双擎的......
  • 【AI大模型】如何让大模型变得更聪明?基于时代背景的思考
    前言在以前,AI和大模型实际上界限较为清晰。但是随着人工智能技术的不断发展,基于大规模预训练模型的应用在基于AI人工智能的技术支持和帮助上,多个领域展现出了前所未有的能力。无论是自然语言处理、计算机视觉,还是语音识别,甚至是自动驾驶,AI模型的性能都取得了显著进步。然而......
  • 使用LLaMA-Factory对LLM大模型进行微调!训练专属于你的模型!
    前言如今也是出现了各种各样的大模型,如果想要针对性的让他扮演某个角色我们通常采用的是给他输入prompt(提示词)。但是如果遇到一些"思想钢印"较深的大模型,使用提示词洗脑可能效果并不好。那我们有没有其他方法来解决这个问题?当然有,那就是自行微调一个大模型!本篇文章,就带......
  • 面向小白开发者:动手学大模型应用开发教程(附教程)
    项目简介本项目是一个面向小白开发者的大模型应用开发教程,旨在基于阿里云服务器,结合个人知识库助手项目,通过一个课程完成大模型开发的重点入门,主要内容包括:大模型简介,何为大模型、大模型特点是什么、LangChain是什么,如何开发一个LLM应用,针对小白开发者的简单介绍;如何调用......
  • 使用本地大模型调用代码,根本就是一场骗局!
    通过大模型调用其他工具到底可不可行?ChatGPT或许能轻松搞定一切,但同样的需求落在本地大模型上,恐怕就要打个问号了。法国开发工程师EmilienLancelot尝试了多款号称具备工具调用功能的agent框架,来看看本地大模型到底能不能完成任务,但结果就像他总结的“一无所获”。是......
  • 资深AI技术专家20余年经验总结,零AI基础掌握大模型、扩散模型、多模态模型(附PDF)
    今天给大家系统地介绍了一本AIGC的各方面内容的书—《AIGC原理与实践:零基础学大语言模型、扩散模型和多模态模型》,这本书从基础知识到应用实践,从基本原理到案例分析,力求通过简洁明了的语言、清晰生动的例子,引导读者逐步掌握AIGC的精髓。内容简介本书旨在帮助没有任何人工......