mindformers

mindformers

全流程大模型开发套件

MindFormers是基于MindSpore的大模型开发套件,提供全流程开发能力。支持LLama2、GLM2、BERT等主流Transformer模型和文本生成、图像分类等任务。具备并行训练、灵活配置、自动优化等特性,可实现从单卡到集群的无缝扩展。提供高阶API和预训练权重自动下载,便于AI计算中心快速部署。

MindSporeTransformers大模型自然语言处理计算机视觉Github开源项目

Welcome to MindSpore Transformers (MindFormers)

I. Introduction

The goal of the MindSpore Transformers suite is to build a comprehensive development kit for large model training, fine-tuning, evaluation, inference, and deployment: It provides mainstream pre-trained Transformer models and state-of-the-art downstream task applications in the industry, covering rich parallel features. It aims to help users easily achieve large model training and innovative research and development.

Based on MindSpore's built-in parallel technology and modular design, the MindSpore Transformers suite has the following features:

  • Seamless transition from single card to large-scale cluster training with one line of code;
  • Flexible and easy-to-use personalized parallel configuration;
  • Automatic topology awareness, efficiently integrating data parallel and model parallel strategies;
  • One-click start of single-card/multi-card training, fine-tuning, evaluation, and inference processes for any task;
  • Supports users to configure any module in a modular way, such as optimizers, learning strategies, network assembly, etc.;
  • Provides advanced and easy-to-use interfaces such as Trainer, pipeline, and AutoClass;
  • Provides pre-set SOTA weight automatic download and loading functions;
  • Supports seamless migration and deployment in artificial intelligence computing centers;

If you have any suggestions for MindSpore Transformers, please contact us through issues, and we will handle them promptly.

The currently supported model list is as follows:

ModelTask (task name)Model (model name)
LLama2text_generationllama2_7b <br>llama2_13b <br>llama2_7b_lora <br>llama2_13b_lora <br>llama2_70b
GLM2text_generationglm2_6b<br>glm2_6b_lora
CodeGeex2text_generationcodegeex2_6b
LLamatext_generationllama_7b <br>llama_13b <br>llama_7b_lora
GLMtext_generationglm_6b<br>glm_6b_lora
Bloomtext_generationbloom_560m<br>bloom_7.1b <br>
GPT2text_generationgpt2_small <br>gpt2_13b <br>
PanGuAlphatext_generationpangualpha_2_6_b<br>pangualpha_13b
BLIP2contrastive_language_image_pretrain<br> zero_shot_image_classificationblip2_stage1_vit_g
CLIPcontrastive_language_image_pretrain<br> zero_shot_image_classificationclip_vit_b_32<br>clip_vit_b_16 <br>clip_vit_l_14<br>clip_vit_l_14@336
BERTmasked_language_modeling<br>text_classification <br>token_classification <br>question_answeringbert_base_uncased <br>txtcls_bert_base_uncased<br>txtcls_bert_base_uncased_mnli <br>tokcls_bert_base_chinese<br>tokcls_bert_base_chinese_cluener <br>qa_bert_base_uncased<br>qa_bert_base_chinese_uncased
T5translationt5_small
samsegment_anythingsam_vit_b <br>sam_vit_l <br>sam_vit_h
MAEmasked_image_modelingmae_vit_base_p16
VITimage_classificationvit_base_p16
Swinimage_classificationswin_base_p4w7

The currently supported model list in research is as follows:

ModelTask (task name)Model (model name)
skyworktext_generationskywork_13b
Baichuan2text_generationbaichuan2_7b <br>baichuan2_13b <br>baichuan2_7b_lora <br>baichuan2_13b_lora
Baichuantext_generationbaichuan_7b <br>baichuan_13b
Qwentext_generationqwen_7b
Wizardcodertext_generationwizardcoder_15b
Internlmtext_generationInternlm_7b
ziyatext_generationziya_13b

II. mindformers Installation

  • Method 1: Linux source code compilation installation

Source code compilation installation is supported. Users can execute the following commands to install the package

git clone -b dev https://gitee.com/mindspore/mindformers.git cd mindformers bash build.sh
  • Method 2: Docker image

Docker download command

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

Create container

# --device is used to control the NPU card number and range of the specified container # -v is used to map directories outside the container # --name is used to customize the container 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

三、版本匹配关系

版本对应关系MindFormersMindPetMindSporePython芯片备注
版本号dev1.0.22.23.9Ascend 910A/B开发分支(非稳定版本)
版本号0.81.0.22.23.9Ascend 910A/B发布版本分支

四、快速使用

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

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

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

  • 准备工作

    • 步骤1:克隆mindformers
    git clone -b dev https://gitee.com/mindspore/mindformers.git cd mindformers
    • 步骤2:准备相应任务的数据集,请参考docs目录下各模型的README.md文档准备相应数据集

    • 步骤3:修改配置文件configs/{model_name}/run_{model_name}_***.yaml中数据集路径

    • 步骤4:如果要使用分布式训练,则需提前生成RANK_TABLE_FILE

    # 不包含8本身,生成0~7卡的hccl json文件 python mindformers/tools/hccl_tools.py --device_num [0,8)
  • 单卡启动:统一接口启动,根据模型CONFIG完成任意模型的单卡训练、微调、评估、推理流程

# 训练启动,run_status支持train、finetuen、eval、predict四个关键字,以分别完成模型训练、评估、推理功能,默认使用配置文件中的run_mode python run_mindformer.py --config {CONFIG_PATH} --run_mode {train/finetune/eval/predict}
  • 多卡启动:scripts脚本启动,根据模型CONFIG完成任意模型的单卡/多卡训练、微调、评估、推理流程
# 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大模型使用教程

  • 准备工作

    • 步骤1:安装mindformers

    具体安装请参考第二章

    • 步骤2:准备数据

    准备相应任务的数据集,请参考docs目录下各模型的README.md文档准备相应数据集。

  • Trainer快速入门

    用户可以通过以上方式安装mindformers库,然后利用Trainer高阶接口执行模型任务的训练、微调、评估、推理功能。

    • Trainer训练/微调启动

    用户可使用Trainer.train或者Trainer.finetune接口完成模型的训练/微调/断点续训。

    import mindspore; mindspore.set_context(mode=0, device_id=0) from mindformers import Trainer cls_trainer = Trainer(task='image_classification', # 已支持的任务名 model='vit_base_p16', # 已支持的模型名 train_dataset="/data/imageNet-1k/train", # 传入标准的训练数据集路径,默认支持ImageNet数据集格式 eval_dataset="/data/imageNet-1k/val") # 传入标准的评估数据集路径,默认支持ImageNet数据集格式 # 示例1:开启训练复现流程 cls_trainer.train() # 示例2:加载集成的mae权重,开启微调流程 cls_trainer.finetune(finetune_checkpoint='mae_vit_base_p16') # 示例3:开启断点续训功能 cls_trainer.train(train_checkpoint=True, resume_training=True)
    • Trainer评估启动

    用户可使用Trainer.evaluate接口完成模型的评估流程。

    import mindspore; mindspore.set_context(mode=0, device_id=0) from mindformers import Trainer cls_trainer = Trainer(task='image_classification', # 已支持的任务名 model='vit_base_p16', # 已支持的模型名 eval_dataset="/data/imageNet-1k/val") # 传入标准的评估数据集路径,默认支持ImageNet数据集格式 # 示例1:开启评估已集成模型权重的复现流程 cls_trainer.evaluate() # 示例2:开启评估训练得到的最后一个权重 cls_trainer.evaluate(eval_checkpoint=True) # 示例3:开启评估指定的模型权重 cls_trainer.evaluate(eval_checkpoint='./output/checkpoint/rank_0/mindformers.ckpt')
    结果打印示例(已集成的vit_base_p16模型权重评估分数): Top1 Accuracy=0.8317
    • Trainer推理启动

    用户可使用Trainer.predict接口完成模型的推理流程。

    import mindspore; mindspore.set_context(mode=0, device_id=0) from mindformers import Trainer

cls_trainer = Trainer(task='image_classification', # 已支持的任务名 model='vit_base_p16') # 已支持的模型名 input_data = './cat.png' # 一张猫的图片

示例1:指定输入的数据完成模型推理

predict_result_d = cls_trainer.predict(input_data=input_data)

示例2:开启推理(自动加载训练得到的最后一个权重)

predict_result_b = cls_trainer.predict(input_data=input_data, predict_checkpoint=True)

示例3:加载指定的权重以完成推理

predict_result_c = cls_trainer.predict(input_data=input_data, predict_checkpoint='./output/checkpoint/rank_0/mindformers.ckpt') print(predict_result_d)


```text
结果打印示例(已集成的vit_base_p16模型权重推理结果):
{'label': 'cat', score: 0.99}
  • pipeline 快速入门

MindFormers套件为用户提供了已集成模型的pipeline推理接口,方便用户体验大模型推理服务。

  • pipeline 使用
# 以gpt2 small为例 import mindspore; mindspore.set_context(mode=0, device_id=0) from mindformers.pipeline import pipeline pipeline_task = pipeline(task="text_generation", model="gpt2") pipeline_result = pipeline_task("An increasing sequence: one,", do_sample=False, max_length=20) print(pipeline_result)
结果打印示例(已集成的gpt2模型权重推理结果): [{'text_generation_text': ['An increasing sequence: one, two, three, four, five, six, seven, eight,']}]
  • AutoClass 快速入门

MindFormers套件为用户提供了高阶AutoClass类,包含AutoConfig、AutoModel、AutoProcessor、AutoTokenizer四类,方便开发者进行调用。

  • AutoConfig 获取已支持的任意模型配置
from mindformers import AutoConfig # 获取gpt2的模型配置 gpt2_config = AutoConfig.from_pretrained('gpt2') # 获取vit_base_p16的模型配置 vit_base_p16_config = AutoConfig.from_pretrained('vit_base_p16')
  • AutoModel 获取已支持的网络模型
from mindformers import AutoModel # 利用from_pretrained功能实现模型的实例化(默认加载对应权重) gpt2 = AutoModel.from_pretrained('gpt2') # 利用from_config功能实现模型的实例化(默认加载对应权重) gpt2_config = AutoConfig.from_pretrained('gpt2') gpt2 = AutoModel.from_config(gpt2_config) # 利用save_pretrained功能保存模型对应配置 gpt2.save_pretrained('./gpt2', save_name='gpt2')
  • AutoProcessor 获取已支持的预处理方法
from mindformers import AutoProcessor # 通过模型名关键字获取对应模型预处理过程(实例化gpt2的预处理过程,通常用于Trainer/pipeline推理入参) gpt2_processor_a = AutoProcessor.from_pretrained('gpt2') # 通过yaml文件获取相应的预处理过程 gpt2_processor_b = AutoProcessor.from_pretrained('configs/gpt2/run_gpt2.yaml')
  • AutoTokenizer 获取已支持的tokenizer方法
from mindformers import AutoTokenizer # 通过模型名关键字获取对应模型预处理过程(实例化gpt2的tokenizer,通常用于Trainer/pipeline推理入参) gpt2_tokenizer = AutoTokenizer.from_pretrained('gpt2')

五、贡献

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

六、许可证

Apache 2.0许可证

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多