Skip to main content

Federated Learning Utility framework for Experimentation and research.

Project description

Coveralls PyPI - Python Version GitHub License

FGCS Docker

fluke: federated learning utility framework for experimentation and research

fluke is a Python package that provides a framework for federated learning research. It is designed to be modular and extensible, allowing researchers to easily implement and test new federated learning algorithms. fluke provides a set of pre-implemented state-of-the-art federated learning algorithms that can be used as a starting point for research or as a benchmark for comparison.

Installation

Pypi

fluke is a Python package that can be installed via pip. To install it, you can run the following command:

pip install fluke-fl

Clone the repository

You can also install fluke by cloning the repository and installing it in editable mode. This is useful if you want to contribute to the development of fluke or if you want to use the latest version of the code.

git clone https://github.com/makgyver/fluke.git
cd fluke
pip install -e .

[!WARNING] Due to a recent repository tree refactoring, if you cloned the repository before June 2025, you need to reclone it to get the latest version of the code.

🐳 Docker

You can use this library directly inside a Docker container — no installation needed on your local machine.

docker build -t fluke_container .

Then, you can run an interactive session with

docker run --rm fluke_container fluke [ARGS]

where ARGS are the arguments you want to pass to the fluke command as described in the next section.

Run a federated algorithm

To run an algorithm in fluke you need to create two configuration files:

  • EXP_CONFIG: the experiment configuration file (independent from the algorithm);
  • ALG_CONFIG: the algorithm configuration file;

Then, you can run the following command:

fluke federation EXP_CONFIG ALG_CONFIG

You can find some examples of these files in the configs folder of the repository.

Example

Let say you want to run the classic FedAvg algorithm on the MNIST dataset. Then, using the configuration files exp.yaml and fedavg.yaml, you can run the following command:

fluke federation path_to_folder/exp.yaml path_to_folder/fedavg.yaml

where path_to_folder is the path to the folder containing the configuration files.

Documentation

The documentation for fluke can be found here. It contains detailed information about the package, including how to install it, how to run an experiment, and how to implement new algorithms.

Tutorials

Tutorials on how to use fluke can be found here. In the following, you can find some quick tutorials to get started with fluke:

  • Getting started with fluke API Open in Colab
  • Run your algorithm in fluke Open in Colab
  • Use your own model with fluke Open in Colab
  • Add your dataset and use it with fluke Open in Colab
  • Add your custom evaluation metric in fluke Open in Colab

Contributing

If you have suggestions for how fluke could be improved, or want to report a bug, open an issue! We'd love all and any contributions.

For more, check out the Contributing Guide.

fluke @ ECML-PKDD 2024

fluke has been presented at the ECML-PKDD 2024 conference in the Workshop on Advancements in Federated Learning. The slides of the presentation are available here.

fluke @ ECAI 2025

On 25th October, we will deliver a tutorial on fluke at the 28th European Conference on Artificial Intelligence (ECAI). Here the website of the tutorial.

Citing fluke

fluke is a research tool, and we kindly ask you to cite it in your research papers if you use it. You can use the following BibTeX entry:

@article{fluke2025fgcs,
	title = {Fluke: Federated learning utility framework for experimentation and research},
	journal = {Future Generation Computer Systems},
	volume = {177},
	pages = {108241},
	year = {2026},
	issn = {0167-739X},
	doi = {https://doi.org/10.1016/j.future.2025.108241},
	url = {https://www.sciencedirect.com/science/article/pii/S0167739X25005357},
	author = {Mirko Polato}
}

Authors and main contributors

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fluke_fl-0.8.1.tar.gz (156.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fluke_fl-0.8.1-py3-none-any.whl (175.2 kB view details)

Uploaded Python 3

File details

Details for the file fluke_fl-0.8.1.tar.gz.

File metadata

  • Download URL: fluke_fl-0.8.1.tar.gz
  • Upload date:
  • Size: 156.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.10

File hashes

Hashes for fluke_fl-0.8.1.tar.gz
Algorithm Hash digest
SHA256 5325954c5f197196d9e1b3dfd953edd77f82b79753763b44ccdcf6d0aaa02682
MD5 97186f1c637ab376fbc27fa605288887
BLAKE2b-256 1004f8b7ac265ffc059c497210a67cf6fc9f14669bfe1eddef110d29138096d5

See more details on using hashes here.

File details

Details for the file fluke_fl-0.8.1-py3-none-any.whl.

File metadata

  • Download URL: fluke_fl-0.8.1-py3-none-any.whl
  • Upload date:
  • Size: 175.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.10

File hashes

Hashes for fluke_fl-0.8.1-py3-none-any.whl
Algorithm Hash digest
SHA256 100c11d2049acf77fc9412aacc18b2d71e15b57de5c46397486689ece4d7a892
MD5 cd2b8a7b0767321200f85b2656fbd3d5
BLAKE2b-256 e87aad1d38f53328e3e85d7d46fb3e782098b93d3553f143accb2bc25566d67e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page