当前位置: 首页 > article >正文

LLMs:MindFormers的简介、安装和使用方法、案例应用

LLMs:MindFormers的简介、安装和使用方法、案例应用

目录

MindFormers的简介

1、MindFormers的特点

2、支持模型:LLaMA3.1、GLM4、Qwen2、InternLM2、DeepSeekV2、Baichuan2

MindFormers的安装和使用方法

1、安装

版本匹配关系

兼容性说明

源码编译安装

2、使用方法

T1、单机多卡:默认8卡启动、仅设置使用卡数、自定义启动

使用示例

T2、多机多卡

使用示例

T3、单卡启动

MindFormers的案例应用

1、基础案例

LLMs之GLM-4:基于国产硬件华为Atlas针对GLM-4-9B实现模型全参微调(单机8卡)→模型推理(单卡多batch推理)

LLMs之Llama-3.1:基于国产硬件华为Atlas针对Llama 3.1-8B/70B实现模型全参微调(单机多卡训练/多机多卡训练)→模型推理(单机推理/多机推理)→基于MindIE的服务化推理(单卡)


MindFormers的简介

2024年1月发布,MindSpore Transformers套件的目标是构建一个大模型训练、微调、评估、推理、部署的全流程开发套件,提供业内主流的Transformer类预训练模型和SOTA下游任务应用,涵盖丰富的并行特性。期望帮助用户轻松的实现大模型训练和创新研发

Gitee地址:mindformers: MindSpore Transformers套件的目标是构建一个大模型训练、推理、部署的全流程套件: 提供业内主流的Transformer类预训练模型, 涵盖丰富的并行特性。 期望帮助用户轻松的实现大模型训练。文档:https://mindformers.readthedocs.io/zh-cn/latest/

1、MindFormers的特点

MindSpore Transformers套件基于MindSpore内置的并行技术和组件化设计,具备如下特点:

  • 一行代码实现从单卡到大规模集群训练的无缝切换;
  • 提供灵活易用的个性化并行配置;
  • 能够自动进行拓扑感知,高效地融合数据并行和模型并行策略;
  • 一键启动任意任务的单卡/多卡训练、微调、评估、推理流程;
  • 支持用户进行组件化配置任意模块,如优化器、学习策略、网络组装等;
  • 提供Trainer、pipeline、AutoClass等高阶易用性接口
  • 提供预置SOTA权重自动下载及加载功能;
  • 支持人工智能计算中心无缝迁移部署;

2、支持模型:LLaMA3.1、GLM4、Qwen2、InternLM2、DeepSeekV2、Baichuan2

MindFormers已支持大部分模型的LoRA微调以及LoRA权重合并功能,具体可参考各模型文档启动模型的LoRA微调任务。

当前MindFormers支持的模型列表如下:

模型参数序列预训练微调推理LoRA对话评估
LLaMA27B4KgeneratePPL
13B4KgeneratePPL
70B4KgeneratePPL
LLaMA38B8K-generate--
70B8Kgenerate--
LLaMA3.18B8K-docs--
70B8K-docs--
Baichuan27B4K-generatePPL
13B4K-generatePPL
GLM26B2K-generatePPL / Rouge
GLM36B2K-generate--
GLM3-32K6B32K-generate--
GLM49B8K-generate--
CogVLM2-Video13B2K-docs--
CogVLM2-Image19B4K--docs---
Qwen7B8K-docsC-Eval
14B8K-docsC-Eval
Qwen1.50.5B8K--docs--
1.8B8K--docs--
4B8K--docs--
7B32Kdocs--
14B32Kdocs--
32B8K--docs--
72B32Kdocs--
Qwen20.5B32K-docs--
1.5B32K-docs--
7B32K-docs--
57B-A14B8K--docs--
57B32Kdocs--
72B128K-docs--
QwenVL9.6B2K-generate--
InternLM7B2K-generatePPL
20B2K-generatePPL
InternLM27B2K-generate--
20B4K--generate--
Yi6B2K-generate-
34B4Kgenerate-
Mixtral8x7B32Kdocs-
DeepSeek Coder33B4K-docs-
DeepSeek Coder1.57B4K-docs---
DeepSeekV2236B4Kdocs---
CodeLlama34B4KgenerateHumanEval
GPT213B2KgeneratePPL
Whisper1.5B------

MindFormers的安装和使用方法

1、安装

版本匹配关系

当前支持的硬件为Atlas 800T A2训练服务器。

当前套件建议使用的Python版本为3.10。

MindFormersMindPetMindSporeCANN驱动固件镜像链接备注
1.3.01.0.42.4.0-driver-版本分支

当前MindFormers建议使用如上的软件配套关系。其中CANN和固件驱动的安装需与使用的机器匹配,请注意识别机器型号,选择对应架构的版本。

兼容性说明

MindFormers与MindSpore有如下兼容关系:

MindFormersMindSpore兼容性
1.3.02.3
1.2.02.4

源码编译安装

MindFormers目前支持源码编译安装,用户可以执行如下命令进行安装。

git clone -b r1.3.0 https://gitee.com/mindspore/mindformers.git
cd mindformers
bash build.sh

2、使用方法

MindFormers支持模型启动预训练、微调、推理、评测等功能,可点击支持模型中模型名称查看文档完成上述任务,以下为模型分布式启动方式的说明与示例。

MindFormers推荐使用分布式方式拉起模型训练、推理等功能,目前提供scripts/msrun_launcher.sh分布式启动脚本作为模型的主要启动方式,msrun特性说明可以参考msrun启动。 该脚本主要输入参数说明如下:

参数单机是否必选多机是否必选默认值说明
WORKER_NUM8所有节点中使用计算卡的总数
LOCAL_WORKER-8当前节点中使用计算卡的数量
MASTER_ADDR-127.0.0.1指定分布式启动主节点的ip
MASTER_PORT-8118指定分布式启动绑定的端口号
NODE_RANK-0指定当前节点的rank id
LOG_DIR-output/msrun_log日志输出路径,若不存在则递归创建
JOIN-False是否等待所有分布式进程退出
CLUSTER_TIME_OUT-7200分布式启动的等待时间,单位为秒

注:如果需要指定device_id启动,可以设置环境变量ASCEND_RT_VISIBLE_DEVICES,如要配置使用2、3卡则输入export ASCEND_RT_VISIBLE_DEVICES=2,3

T1、单机多卡:默认8卡启动、仅设置使用卡数、自定义启动

# 1. 单机多卡快速启动方式,默认8卡启动
bash scripts/msrun_launcher.sh "run_mindformer.py \
  --config {CONFIG_PATH} \
  --run_mode {train/finetune/eval/predict}"

# 2. 单机多卡快速启动方式,仅设置使用卡数即可
bash scripts/msrun_launcher.sh "run_mindformer.py \
  --config {CONFIG_PATH} \
  --run_mode {train/finetune/eval/predict}" WORKER_NUM

# 3. 单机多卡自定义启动方式
bash scripts/msrun_launcher.sh "run_mindformer.py \
  --config {CONFIG_PATH} \
  --run_mode {train/finetune/eval/predict}" \
  WORKER_NUM MASTER_PORT LOG_DIR JOIN CLUSTER_TIME_OUT

使用示例
# 单机多卡快速启动方式,默认8卡启动
bash scripts/msrun_launcher.sh "run_mindformer.py \
  --config path/to/xxx.yaml \
  --run_mode finetune"

# 单机多卡快速启动方式
bash scripts/msrun_launcher.sh "run_mindformer.py \
  --config path/to/xxx.yaml \
  --run_mode finetune" 8

# 单机多卡自定义启动方式
bash scripts/msrun_launcher.sh "run_mindformer.py \
  --config path/to/xxx.yaml \
  --run_mode finetune" \
  8 8118 output/msrun_log False 300

T2、多机多卡

多机多卡执行脚本进行分布式训练需要分别在不同节点运行脚本,并将参数MASTER_ADDR设置为主节点的ip地址, 所有节点设置的ip地址相同,不同节点之间仅参数NODE_RANK不同。

# 多机多卡自定义启动方式
bash scripts/msrun_launcher.sh "run_mindformer.py \
 --config {CONFIG_PATH} \
 --run_mode {train/finetune/eval/predict}" \
 WORKER_NUM LOCAL_WORKER MASTER_ADDR MASTER_PORT NODE_RANK LOG_DIR JOIN CLUSTER_TIME_OUT

使用示例
# 节点0,节点ip为192.168.1.1,作为主节点,总共8卡且每个节点4卡
bash scripts/msrun_launcher.sh "run_mindformer.py \
  --config {CONFIG_PATH} \
  --run_mode {train/finetune/eval/predict}" \
  8 4 192.168.1.1 8118 0 output/msrun_log False 300

# 节点1,节点ip为192.168.1.2,节点0与节点1启动命令仅参数NODE_RANK不同
bash scripts/msrun_launcher.sh "run_mindformer.py \
  --config {CONFIG_PATH} \
  --run_mode {train/finetune/eval/predict}" \
  8 4 192.168.1.1 8118 1 output/msrun_log False 300

T3、单卡启动

MindFormers提供run_mindformer.py脚本作为单卡启动方法,该脚本可以根据模型配置文件,完成支持模型的单卡训练、微调、评估、推理流程。

# 运行run_mindformer.py的入参会覆盖模型配置文件中的参数
python run_mindformer.py --config {CONFIG_PATH} --run_mode {train/finetune/eval/predict}

MindFormers的案例应用

持续更新中……

1、基础案例

LLMs之GLM-4:基于国产硬件华为Atlas针对GLM-4-9B实现模型全参微调(单机8卡)→模型推理(单卡多batch推理)

LLMs之GLM-4:基于国产硬件华为Atlas针对GLM-4-9B实现模型全参微调(单机8卡)→模型推理(单卡多batch推理)-CSDN博客

LLMs之Llama-3.1:基于国产硬件华为Atlas针对Llama 3.1-8B/70B实现模型全参微调(单机多卡训练/多机多卡训练)→模型推理(单机推理/多机推理)→基于MindIE的服务化推理(单卡)

LLMs之Llama-3.1:基于国产硬件华为Atlas针对Llama 3.1-8B/70B实现模型全参微调(单机多卡训练/多机多卡训练)→模型推理(单机推理/多机推理)→基于MindIE的服务化推理-CSDN博客


http://www.kler.cn/a/391622.html

相关文章:

  • 主数据系统建设模式分析
  • Redis是单线程还是多线程?
  • 初识JVM HotSopt 的发展历程
  • 如何开放2375和2376端口供Docker daemon监听
  • 金融项目实战 06|Python实现接口自动化——日志、认证开户接口
  • opencv的NLM去噪算法
  • @RestController 源码解读:解决 Web 开发中 REST 服务的疑难杂症
  • Hbase入门
  • 树莓派安装FreeSWITCH
  • v-html 富文本中图片使用element-ui image-viewer组件实现预览,并且阻止滚动条
  • 23. 管理架构债务
  • 0基础跟德姆(dom)一起学AI 深度学习02-Pytorch基本使用
  • 力扣 LeetCode 142. 环形链表II(Day2:链表)
  • 负载均衡式在线oj项目开发文档2(个人项目)
  • Linux之进程
  • java:多态练习
  • filerchain是什么类
  • MongoDB增删改查,复杂查询案例分析
  • 精准监测,高效防护:特力康输电线路防山火新方案
  • Vue2+ElementUI:用计算属性实现搜索框功能
  • Python网络爬虫简介
  • 信令服务器设计之websocket
  • Spring Boot基础教学:Spring Boot 简介
  • 元器件封装
  • Linux系统编程学习 NO.11——进程的概念(2)
  • IntelliJ+SpringBoot项目实战(四)--快速上手数据库开发