NeuronBlocks是一个模块化NLP深度学习建模工具包,可以帮助工程师/研究者们快速构建NLP任务的神经网络模型。 该工具包的主要目标是将NLP中深度神经网络模型构建的开发成本降到最低,包括训练阶段和推断阶段。
NeuronBlocks包括 Block Zoo 和 Model Zoo 两个重要组件,其整体框架如下图所示。
- 在 Block Zoo 中, 我们提供了常用的神经网络组件作为模型架构设计的构建模块。
- 在 Model Zoo 中, 我们提供了 JSON配置文件 形式的一系列经典NLP深度学习模型。
- English
- 中文
- 句子分类
- 情感分析
- 问答匹配
- 文本蕴含
- 序列标注
- 阅读理解
- 基于知识蒸馏的模型压缩
- 更多……
用户可以选择 Model Zoo 中的示例模型(JSON配置文件)开启模型训练,或者利用 Block Zoo 中的神经网络模块构建新的模型,就像玩乐高积木一样。
注: NeuronBlocks支持 Python 3.6及以上
-
Clone本项目:
git clone https://github.com/Microsoft/NeuronBlocks
-
安装Python依赖包:
pip install -r requirements.txt
-
安装PyTorch ( NeuronBlocks支持 PyTorch 0.4.1 及以上):
对于 Linux ,运行以下命令:
pip install "torch>=0.4.1"
对于 Windows ,建议按照PyTorch官方安装教程通过Conda安装PyTorch。
通过以下示例快速入门NeuronBlocks。对于Windows,建议使用PowerShell工具运行命令。
提示: 在下文中, PROJECTROOT表示本项目的根目录。
# 训练
cd PROJECT_ROOT
python train.py --conf_path=model_zoo/demo/conf.json
# 测试
python test.py --conf_path=model_zoo/demo/conf.json
# 预测
python predict.py --conf_path=model_zoo/demo/conf.json
对于预测,NeuronBlocks 提供了两种预测的形式: 交互式和批量式。
- 交互式: 交互式模式预测提供了交互界面,用户可以根据输入提示信息每次输入一个样本并实时得到模型前向计算出的结果,输入 "exit" 时退出交互预测模式。
# use the above example
# interactive prediction
python predict.py --conf_path=model_zoo/demo/conf.json --predict_mode='interactive'
- 批量式: 对于批量样本预测的需求,NeuronBlocks 提供批量预测模式,其接受一个包含批量样本的文件作为输入,并且将模型前向计算的结果写回这个文件。
# use the above example
# batch prediction
python predict.py --conf_path=model_zoo/demo/conf.json --predict_mode='batch' --predict_data_path=dataset/demo/predict.tsv
更多细节, 请查看Tutorial_zh_CN.md 和 Code documentation。
使用用神经网络模型解决NLP任务时面临以下挑战的工程师和研究者们:
- 很多框架可以选择,且框架学习成本高;
- 繁重的编程工作,大量细节使其难以调试;
- 快速迭代的模型架构,使工程师们很难完全理解其背后的数学原理;
- 模型代码优化需要深厚的专业知识;
- 平台兼容性要求,需要额外的编程工作才能使模型运行在不同的平台上,如Linux/Windows, GPU/CPU。
利用NeuronBlocks进行NLP神经网络模型训练的优势包括:
- 模型构建:用户只需要配置简单的JSON文件,就能够构建模型和调整参数,大大减少了模型实现的工作量;
- 模型分享:可以通过分享JSON配置文件来分享模型,使模型共享变得非常容易。对于不同的任务或模型,用户只需维护一个通用的源码库;
- 代码重用:可以在各任务与模型间共享神经网络模块,减少重复的编程工作;
- 平台灵活性:NeuronBlocks可以在Linux和Windows机器上运行,支持CPU和GPU,也支持像Philly和PAI这样的GPU管理平台;
CPU 预测 Single-GPU 预测 Multi-GPU 预测 CPU 训练 ✓ ✓ ✓ Single-GPU 训练 ✓ ✓ ✓ Multi-GPU 训练 ✓ ✓ ✓ - 模型可视化:NeuronBlocks提供了一个模型可视化工具,用于观察模型结构及检查JSON配置的正确性
- 可扩展性:NeuronBlocks鼓励用户贡献新的神经网络模块或者新的模型。
NeuronBlocks以开放的模式运行。它由 微软 STCA NLP Group 设计和开发,也非常欢迎来自学术界和工业界的人士参与贡献。更多详细信息,请查看Contributing.md。
- 模型压缩,对诸如BERT, OpenAI Transformer之类的复杂模型进行知识蒸馏。基于Teacher-Student的知识蒸馏是模型压缩的一个常用方法。
- 多语言支持
- 命名实体识别模型支持
- 多任务训练支持
我们鼓励感兴趣的用户一起加入我们贡献code.
NeuronBlocks -- Building Your NLP DNN Models Like Playing Lego, at https://arxiv.org/abs/1904.09535.
@article{gong2019neuronblocks,
title={NeuronBlocks--Building Your NLP DNN Models Like Playing Lego},
author={Gong, Ming and Shou, Linjun and Lin, Wutao and Sang, Zhijie and Yan, Quanjia and Yang, Ze, Cheng, Feixiang and Jiang, Daxin},
journal={arXiv preprint arXiv:1904.09535},
year={2019}
}
- OpenPAI: 作为开源平台,提供了完整的 AI 模型训练和资源管理能力,能轻松扩展,并支持各种规模的私有部署、云和混合环境。
- Samples for AI: 一个深度学习样例与项目集合。它包括大量基于不同框架的经典深度学习算法和应用,对于初学者来说是很好的入门深度学习的工具。
Copyright (c) Microsoft Corporation. All rights reserved.
Licensed under the MIT License.
如有任何问题,请联系:[email protected]
如果您有微信,也可以添加工具包的官方账号: