mindspore-lab / mindformers

Apache License 2.0
143 stars 20 forks source link

欢迎来到MindSpore Transformers(MindFormers)

一、介绍

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

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

如果您对MindSpore Transformers有任何建议,请通过issue与我们联系,我们将及时处理。

目前支持的模型列表如下:

模型 任务(task name) 模型(model name)
LLama2 text_generation llama2_7b
llama2_13b
llama2_7b_lora
llama2_13b_lora
llama2_70b
GLM2 text_generation glm2_6b
glm2_6b_lora
CodeGeex2 text_generation codegeex2_6b
LLama text_generation llama_7b
llama_13b
llama_7b_lora
GLM text_generation glm_6b
glm_6b_lora
Bloom text_generation bloom_560m
bloom_7.1b
GPT2 text_generation gpt2_small
gpt2_13b
PanGuAlpha text_generation pangualpha_2_6_b
pangualpha_13b
BLIP2 contrastive_language_image_pretrain
zero_shot_image_classification
blip2_stage1_vit_g
CLIP contrastive_language_image_pretrain
zero_shot_image_classification
clip_vit_b_32
clip_vit_b_16
clip_vit_l_14
clip_vit_l_14@336
BERT masked_language_modeling
text_classification
token_classification
question_answering
bert_base_uncased
txtcls_bert_base_uncased
txtcls_bert_base_uncased_mnli
tokcls_bert_base_chinese
tokcls_bert_base_chinese_cluener
qa_bert_base_uncased
qa_bert_base_chinese_uncased
T5 translation t5_small
sam segment_anything sam_vit_b
sam_vit_l
sam_vit_h
MAE masked_image_modeling mae_vit_base_p16
VIT image_classification vit_base_p16
Swin image_classification swin_base_p4w7

目前在research中支持的模型列表如下:

模型 任务(task name) 模型(model name)
skywork text_generation skywork_13b
Baichuan2 text_generation baichuan2_7b
baichuan2_13b
baichuan2_7b_lora
baichuan2_13b_lora
Baichuan text_generation baichuan_7b
baichuan_13b
Qwen text_generation qwen_7b
Wizardcoder text_generation wizardcoder_15b
Internlm text_generation Internlm_7b
ziya text_generation ziya_13b

二、mindformers安装

支持源码编译安装,用户可以执行下述的命令进行包的安装

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

docker下载命令

docker pull swr.cn-central-221.ovaijisuan.com/mindformers/mindformers0.8.0_mindspore2.2.0:aarch_20231025

创建容器

# --device用于控制指定容器的运行NPU卡号和范围
# -v 用于映射容器外的目录
# --name 用于自定义容器名称

docker run -it -u root \
--ipc=host \
--network host \
--device=/dev/davinci0 \
--device=/dev/davinci1 \
--device=/dev/davinci2 \
--device=/dev/davinci3 \
--device=/dev/davinci4 \
--device=/dev/davinci5 \
--device=/dev/davinci6 \
--device=/dev/davinci7 \
--device=/dev/davinci_manager \
--device=/dev/devmm_svm \
--device=/dev/hisi_hdc \
-v /etc/localtime:/etc/localtime \
-v /usr/local/Ascend/driver:/usr/local/Ascend/driver \
-v /var/log/npu/:/usr/slog \
-v /usr/local/bin/npu-smi:/usr/local/bin/npu-smi \
--name {请手动输入容器名称} \
swr.cn-central-221.ovaijisuan.com/mindformers/mindformers0.8.0_mindspore2.2.0:aarch_20231025 \
/bin/bash

三、版本匹配关系

版本对应关系 MindFormers MindPet MindSpore Python 芯片 备注
版本号 dev 1.0.2 2.2 3.9 Ascend 910A/B 开发分支(非稳定版本)
版本号 0.8 1.0.2 2.2 3.9 Ascend 910A/B 发布版本分支

四、快速使用

MindFormers套件对外提供两种使用和开发形式,为开发者提供灵活且简洁的使用方式和高阶开发接口。

方式一:使用已有脚本启动

用户可以直接clone整个仓库,按照以下步骤即可运行套件中已支持的任意configs模型任务配置文件,方便用户快速进行使用和开发:

# 训练启动,run_status支持train、finetuen、eval、predict四个关键字,以分别完成模型训练、评估、推理功能,默认使用配置文件中的run_mode
python run_mindformer.py --config {CONFIG_PATH} --run_mode {train/finetune/eval/predict}
# 8卡分布式运行, DEVICE_RANGE = [0,8), 不包含8本身
cd scripts
bash run_distribute.sh RANK_TABLE_FILE CONFIG_PATH DEVICE_RANGE RUN_MODE
RANK_TABLE_FILE: 由mindformers/tools/hccl_tools.py生成的分布式json文件
CONFIG_PATH: 为configs文件夹下面的{model_name}/run_*.yaml配置文件
DEVICE_ID: 为设备卡,范围为0~7
DEVICE_RANGE: 为单机分布式卡的范围, 如[0,8]为8卡分布式,不包含8本身
RUN_MODE: 为任务运行状态,支持关键字 train\finetune\eval\predict\export

方式二:调用API启动

详细高阶API使用教程请参考:MindFormers大模型使用教程

五、贡献

欢迎参与社区贡献,可参考MindSpore贡献要求Contributor Wiki

六、许可证

Apache 2.0许可证