1️⃣ 本项目来自 SMILELab-FL , 我们主要致力于联邦自然语言处理的发展;
2️⃣ FedLab-NLP
是一款轻量级、可自由定制联邦学习过程并面向于自然语言处理的代码框架;
3️⃣ FedLab-NLP
主要实现基于 FedLab 和 HuggingFace,能完成自然语言预训练大模型在联邦学习场景下工作;
4️⃣ 任何使用问题可以联系 📧 [email protected]
我们建议按照如下的文件结构来使用FedLab-NLP
:
data: 存放数据集,注意该数据集需要已经经过 iid/niid 划分的联邦数据集;
pretrained: 在nlp文件夹里存储从huggingface中下载的预训练模型,如`bert-base-uncased`;
code: 在该文件夹下面使用`FedLab-NLP`;
output: 存储模型输出的记录等。
目录组织如下:
├── workspace
│ └── data
| | ├── fedglue
| | └── fedner
│ ├── pretrained
│ │ ├── nlp
│ │ └── cv
│ ├── output
│ └── code
│ └── FedLab-NLP
运行路径生成:
mkdir workspace
cd workspace
mkdir data
mkdir code
mkdir pretrained
cd pretrained
mkdir nlp
cd ..
cd code
建议运行环境的python
版本为3.7+
,我们建议使用pytorch
版本为1.10+
git clone [email protected]:Trustworthy-DL/FedLab-NLP.git
cd FedLab-NLP
pip install -r resquirements.txt
支持 fedavg
联邦学习算法
bash fed_run.sh {your_file_path}/workspace {task_name} fedavg 10001 {server_gpu_id} {client1_gpu_id} {client2_gpu_id}
支持 centralized
集中训练学习算法
bash cen_run.sh {your_file_path}/workspace {task_name} centralized 10001 {server_gpu_id}