nebula-dfl.com | nebula-dfl.eu | federatedlearning.inf.um.es
NEBULA (previously known as Fedstellar1) is a cutting-edge platform designed to facilitate the training of federated models within both centralized and decentralized architectures. It streamlines the development, deployment, and management of federated applications across physical and virtualized devices.
NEBULA is currently developed by Enrique TomΓ‘s MartΓnez BeltrΓ‘n, Alberto Huertas CeldrΓ‘n, Fernando Torres Vega, and Juan JesΓΊs Torralba Mateos in collaboration with the University of Murcia, armasuisse, and the University of Zurich.
NEBULA boasts a modular architecture that consists of three core elements:
- Frontend: A user-friendly interface for setting up experiments and monitoring progress.
- Controller: An orchestrator that ensures efficient operation management.
- Core: The fundamental component deployed on each device to handle federated learning processes.
- Decentralized: Train models without a central server, leveraging decentralized federated learning.
- Privacy-preserving: Maintain data privacy by training on-device and only sharing model updates.
- Topology-agnostic: Support for various network topologies including star, ring, and mesh.
- Model-agnostic: Compatible with a wide range of machine learning algorithms, from deep learning to traditional methods.
- Network communication: Secure and efficient device communication with features like compression, network failure tolerance, and condition simulation.
- Trustworthiness: Ensure the integrity of the learning process by verifying the reliability of the federation.
- Security: Implement security mechanisms to protect the learning process from adversarial attacks.
- Real-time monitoring: Provides live performance metrics and visualizations during the learning process.
- π₯ Healthcare: Train models on medical devices such as wearables, smartphones, and sensors.
- π Industry 4.0: Implement on industrial devices like robots, drones, and constrained devices.
- π± Mobile services: Optimize for mobile devices including smartphones, tablets, and laptops.
- π‘οΈ Military: Apply to military equipment such as drones, robots, and sensors.
- π Vehicular scenarios: Utilize in vehicles including cars, trucks, and drones.
To start using NEBULA, follow our detailed Installation Guide and User Manual. For any queries or contributions, check out our Contribution Guide.
We welcome contributions from the community to enhance NEBULA. If you are interested in contributing, please follow the next steps:
- Fork the repository
- Create a new branch with your feature or bug fix (
git checkout -b feature/your-feature). - Commit your changes (
git commit -am 'Add new feature'). - Push to the branch (
git push origin feature/your-feature). - Create a new Pull Request.
If you use NEBULA (or Fedstellar) in a scientific publication, we would appreciate using the following citations:
@article{MartinezBeltran:DFL:2023,
title = {{Decentralized Federated Learning: Fundamentals, State of the Art, Frameworks, Trends, and Challenges}},
author = {Mart{\'i}nez Beltr{\'a}n, Enrique Tom{\'a}s and Quiles P{\'e}rez, Mario and S{\'a}nchez S{\'a}nchez, Pedro Miguel and L{\'o}pez Bernal, Sergio and Bovet, G{\'e}r{\^o}me and Gil P{\'e}rez, Manuel and Mart{\'i}nez P{\'e}rez, Gregorio and Huertas Celdr{\'a}n, Alberto},
year = 2023,
volume = {25},
number = {4},
pages = {2983-3013},
journal = {IEEE Communications Surveys & Tutorials},
doi = {10.1109/COMST.2023.3315746},
preprint = {https://arxiv.org/abs/2211.08413}
}
@article{MartinezBeltran:fedstellar:2024,
title = {{Fedstellar: A Platform for Decentralized Federated Learning}},
author = {Mart{\'i}nez Beltr{\'a}n, Enrique Tom{\'a}s and Perales G{\'o}mez, {\'A}ngel Luis and Feng, Chao and S{\'a}nchez S{\'a}nchez, Pedro Miguel and L{\'o}pez Bernal, Sergio and Bovet, G{\'e}r{\^o}me and Gil P{\'e}rez, Manuel and Mart{\'i}nez P{\'e}rez, Gregorio and Huertas Celdr{\'a}n, Alberto},
year = 2024,
volume = {242},
issn = {0957-4174},
pages = {122861},
journal = {Expert Systems with Applications},
doi = {10.1016/j.eswa.2023.122861},
preprint = {https://arxiv.org/abs/2306.09750}
}
@inproceedings{MartinezBeltran:fedstellar_demo:2023,
title = {{Fedstellar: A Platform for Training Models in a Privacy-preserving and Decentralized Fashion}},
author = {Mart{\'i}nez Beltr{\'a}n, Enrique Tom{\'a}s and S{\'a}nchez S{\'a}nchez, Pedro Miguel and L{\'o}pez Bernal, Sergio and Bovet, G{\'e}r{\^o}me and Gil P{\'e}rez, Manuel and Mart{\'i}nez P{\'e}rez, Gregorio and Huertas Celdr{\'a}n, Alberto},
year = 2023,
month = aug,
booktitle = {Proceedings of the Thirty-Second International Joint Conference on Artificial Intelligence, {IJCAI-23}},
publisher = {International Joint Conferences on Artificial Intelligence Organization},
pages = {7154--7157},
doi = {10.24963/ijcai.2023/838},
note = {Demo Track},
editor = {Edith Elkind}
}
@article{MartinezBeltran:DFL_mitigating_threats:2023,
title = {{Mitigating Communications Threats in Decentralized Federated Learning through Moving Target Defense}},
author = {Mart{\'i}nez Beltr{\'a}n, Enrique Tom{\'a}s and S{\'a}nchez S{\'a}nchez, Pedro Miguel and L{\'o}pez Bernal, Sergio and Bovet, G{\'e}r{\^o}me and Gil P{\'e}rez, Manuel and Mart{\'i}nez P{\'e}rez, Gregorio and Huertas Celdr{\'a}n, Alberto},
year = 2024,
journal = {Wireless Networks},
doi = {10.1007/s11276-024-03667-8}
preprint = {https://arxiv.org/abs/2307.11730}
}
Distributed under the GNU AGPLv3 License. See LICENSE for more information.
- Community Edition β released under the GNU Affero GPL v3.0.
- Enterprise Edition β proprietary license & premium support available.
Contact enriquetomas@um.es and alberto.huertas@um.es for commercial terms.
We would like to thank the following projects for their contributions which have helped shape NEBULA:
- PyTorch Lightning for the training loop and model management
- Tensorboard for the visualization tools and monitoring capabilities
- Different datasets (nebula/core/datasets) and models (nebula/core/models) for testing and validation purposes
- FastAPI for the RESTful API
- Fedstellar platform and p2pfl library
- Adversarial Robustness Toolbox (ART) for the implementation of adversarial attacks
- Opacus for differential privacy training support
- AI Fairness 360 (AIF360) for fairness metric definitions
- HolisticAI for trustworthiness and fairness metric definitions
- D3.js for the network visualizations
NEBULA uses Opacus for differential privacy training:
- Yousefpour, A., Shilov, I., Sablayrolles, A., Testuggine, D., Prasad, K., Malek, M., Nguyen, J., Ghosh, S., Bharadwaj, A., Zhao, J., Cormode, G., & Mironov, I. (2021). Opacus: User-Friendly Differential Privacy Library in PyTorch. arXiv:2109.12298. Licensed under Apache License 2.0: https://github.com/meta-pytorch/opacus/blob/main/LICENSE
NEBULA implements some trustworthiness and fairness metrics following definitions documented in external toolkits:
-
AI Fairness 360 (AIF360). AI Fairness 360 [Software]. https://github.com/Trusted-AI/AIF360. Licensed under Apache License 2.0: https://github.com/Trusted-AI/AIF360/blob/main/LICENSE
-
Holistic AI. HolisticAI [Software]. https://github.com/holistic-ai/holisticai. Licensed under Apache License 2.0: https://github.com/holistic-ai/holisticai/blob/main/LICENSE
NEBULA preprocesses these datasets for experiments, including splitting, scaling, encoding, label mapping, filtering, and/or sample limiting depending on the dataset.
-
Becker, B. & Kohavi, R. (1996). Adult [Dataset]. UCI Machine Learning Repository. https://doi.org/10.24432/C5XW20. Licensed under CC BY 4.0: https://creativecommons.org/licenses/by/4.0/
-
Blackard, J. (1998). Covertype [Dataset]. UCI Machine Learning Repository. https://doi.org/10.24432/C50K5N. Licensed under CC BY 4.0: https://creativecommons.org/licenses/by/4.0/
-
Wolberg, W., Mangasarian, O., Street, N., & Street, W. (1993). Breast Cancer Wisconsin (Diagnostic) [Dataset]. UCI Machine Learning Repository. https://doi.org/10.24432/C5DW2B. Licensed under CC BY 4.0: https://creativecommons.org/licenses/by/4.0/
-
Stolfo, S., Fan, W., Lee, W., Prodromidis, A., & Chan, P. (1999). KDD Cup 1999 Data [Dataset]. UCI Machine Learning Repository. https://doi.org/10.24432/C51C7N. Licensed under CC BY 4.0: https://creativecommons.org/licenses/by/4.0/
Footnotes
-
Fedstellar was our first version of the platform. We have redesigned the previous functionalities and added new capabilities based on our research. The platform is now called NEBULA and is available as an open-source project. β©
