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 developed by Enrique TomΓ‘s MartΓnez BeltrΓ‘n 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.
- Blockchain integration: Support for blockchain technologies to enhance security and transparency.
- 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 GPLv3 License. See LICENSE
for more information.
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
- Web3 for the blockchain integration
- Fedstellar platform and p2pfl library
- Adversarial Robustness Toolbox (ART) for the implementation of adversarial attacks
- D3.js for the network visualizations
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. β©