Project Icon

FedScale

可扩展的开源联邦学习(FL)引擎和基准测试平台

FedScale是一个可扩展的开源联邦学习(FL)引擎和基准测试平台,提供高级API用于实现FL算法,并在多种硬件和软件环境中进行大规模部署和评估。FedScale包括大规模的FL基准测试,涵盖图像分类、对象检测、语言建模和语音识别等任务,同时提供数据集真实模拟FL训练环境。用户可以通过简单的安装流程在Linux和MacOS上快速部署,并利用丰富的教程和数据集开展实验。

项目简介

FedScale 是一个可扩展的、开源的联邦学习(Federated Learning,简称FL)引擎和基准测试平台。该平台为实现FL算法提供了高级API,可以在各种不同的硬件和软件环境中大规模部署和评估这些算法。此外,FedScale 还包含一个大型联邦学习基准,涵盖了从图像分类、物体检测到语言建模和语音识别的一系列任务。同时,FedScale 提供了数据集,以便在实际部署FL时,能够真实地模拟FL训练环境。

快速开始

快速安装(Linux)

只需运行 install.sh 脚本:

source install.sh # 如果需要CUDA,请添加`--cuda`
pip install -e .

如果对conda/CUDA的不同版本有偏好,可以修改 install.sh

源码安装(Linux/MacOS)

如果已经安装 Anaconda 并克隆了 FedScale 项目,可以按照以下步骤:

cd FedScale

# MacOS 用户需将 ~/.bashrc 替换为 ~/.bash_profile
FEDSCALE_HOME=$(pwd)
echo export FEDSCALE_HOME=$(pwd) >> ~/.bashrc 
echo alias fedscale=\'bash $FEDSCALE_HOME/fedscale.sh\' >> ~/.bashrc 
conda init bash
. ~/.bashrc

conda env create -f environment.yml
conda activate fedscale
pip install -e .

如需使用GPU支持,请安装 NVIDIA 的 CUDA 10.2 或更高版本。

学习指南

安装好 FedScale 后,可以通过以下教程开始你的探索:

  1. 探索 FedScale 数据集
  2. 部署你的FL实验
  3. 实现一个FL算法
  4. 在智能手机上部署FL

FedScale 数据集

FedScale 包含超过20个大规模、异构的FL数据集,以及超过70种不同的模型,涵盖计算机视觉(CV)、自然语言处理(NLP)和其他任务。每个数据集都包含训练、验证和测试数据集。我们感谢这些原始数据集的贡献者。有关详细信息,请参阅 ./benchmark/dataset 目录和数据集的README文件。

FedScale 运行时

FedScale 运行时是一个可扩展的部署和评估平台,简化并标准化FL实验设置和模型评估。它是从我们之前的系统 Oort 演变而来的,该系统在每一轮中能够很好地扩展以模拟数千个客户端的FL训练。

请到 ./fedscale/cloud 目录,并按照README文件设置FL训练脚本,以及用于实际设备部署的 README

项目结构

项目根目录
|---- fedscale          # FedScale 源代码
  |---- cloud           # FedScale服务的核心
  |---- utils           # 辅助功能(例如,模型库和FL优化器)
  |---- edge            # 实际部署的后端(例如,移动设备)
  |---- dataloaders     # 基准数据集的数据加载器

|---- docker            # FedScale Docker和容器部署(例如,Kubernetes)
|---- benchmark         # FedScale 数据集和配置
  |---- dataset         # 基准数据集
  |---- configs         # 示例配置

|---- scripts           # 安装依赖项的脚本
|---- examples          # 实现新FL设计的示例
|---- docs              # FedScale 教程和API

参考文献

使用FedScale代码或数据学习更多信息时,请阅读或引用相关文献。

@inproceedings{fedscale-icml22,
  title={{FedScale}: Benchmarking Model and System Performance of Federated Learning at Scale},
  author={Fan Lai and Yinwei Dai and Sanjay S. Singapuram and Jiachen Liu and Xiangfeng Zhu and Harsha V. Madhyastha and Mosharaf Chowdhury},
  booktitle={International Conference on Machine Learning (ICML)},
  year={2022}
}

@inproceedings{oort-osdi21,
  title={Oort: Efficient Federated Learning via Guided Participant Selection},
  author={Fan Lai and Xiangfeng Zhu and Harsha V. Madhyastha and Mosharaf Chowdhury},
  booktitle={USENIX Symposium on Operating Systems Design and Implementation (OSDI)},
  year={2021}
}

贡献与沟通

如发现Bug或改善FedScale,欢迎提交问题或拉取请求。对于每次提交,请添加相应更改的单元测试,并确保通过运行 pytest fedscale/tests 的所有单元测试。如果有任何问题或建议,请加入我们的Slack频道或给我们发送电子邮件。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号