Skip to main content

No project description provided

Project description

FLEX-Clash

flex-clash is a Python library dedicated to adversarial attacks and defences in Federated Learning. It offers the state-of-the methods and features to ease the implementation of custom methods. It is intended to extend the FLEXible framework.

Details

This repository includes both:

  • Features to implement poisoning attacks in Federated Learning.
  • Features to implement defences in the aggregator in Federated Learning.
  • State-of-the-art defences implementedin FLEXible.

Folder structure

  • flexclash/data: which contains the features to poison the clients' data.
  • flexclash/model: which contains the features to poison the clients' model updates.
  • flexclash/pool: which contains the features to implement any defence in the aggregation operator as well as the state-of-the-art implemented defences.
  • notebooks: which contains explanatory notebooks showing how to implement poisoning attacks and use the implemented defences.
  • test: which contains the test for the implemented features.

Explanatory notebooks

  • Poisoning_data_FLEX.ipynb: A notebook showing how to implement data-poisoning attacks using flexclash including both byzantine and backdoor attacks.
  • Poisoning_model_FLEX.ipynb: A notebook showing how to implement model-poisoning attacks using flexclash.
  • Defences_FLEX.ipynb: A notebook showing how to employ defences against adversarial attacks using flexclash.

Features

In the following we detail the poisoning attacks implemented:

Attack Description Citation
Data poisoning It consists of poisoning a certain amount of data of certain clients randomly or according to certain criteria. Several examples are shown in the notebooks. Data Poisoning Attacks Against Federated Learning Systems
Model poisoning It consists of directly poisoning the weights of the model update that the client shares with the server. Deep Model Poisoning Attack on Federated Learning

In the following we detail the defences implemented:

Defence Description Citation
Median It is a robust-aggregation operator based on replacing the arithmetic mean by the median of the model updates, which choose the value that represents the centre of the distribution. Byzantine-robust distributed learning: Towards optimal statistical rates.
Trimmed mean It is a version of the arithmetic mean, consisting of filtering a fixed percentage of extreme values both below and above the data distribution. Byzantine-robust distributed learning: Towards optimal statistical rates.
MultiKrum It sorts the clients according to the geometric distances of their model updates. Hence, it employs an aggregation parameter, which specifies the number of clients to be aggregated (the first ones after being sorted) resulting in the aggregated model. Machine Learning with Adversaries: Byzantine Tolerant Gradient Descent
Bulyan It is a federated aggregation operator to prevent poisoning attacks, combining the MultiKrum federated aggregation operator and the trimmed-mean. Hence, it sorts the clients according to their geometric distances, and according to a 𝑓 parameter filters out the 2𝑓 clients of the tails of the sorted distribution of clients and aggregates the rest of them. The Hidden Vulnerability of Distributed Learning in Byzantium

Installation

In order to install this repo locally:

pip install -e .

FLEX-Clash is available on the PyPi repository and can be easily installed using pip:

pip install flex-clash

Citation

If you use this repository in your research work, please cite Flexible paper:

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

flexclash-0.0.2.tar.gz (19.9 kB view details)

Uploaded Source

Built Distribution

flexclash-0.0.2-py3-none-any.whl (23.3 kB view details)

Uploaded Python 3

File details

Details for the file flexclash-0.0.2.tar.gz.

File metadata

  • Download URL: flexclash-0.0.2.tar.gz
  • Upload date:
  • Size: 19.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 colorama/0.4.4 importlib-metadata/4.6.4 keyring/23.5.0 pkginfo/1.8.2 readme-renderer/34.0 requests-toolbelt/0.9.1 requests/2.25.1 rfc3986/1.5.0 tqdm/4.57.0 urllib3/1.26.5 CPython/3.10.12

File hashes

Hashes for flexclash-0.0.2.tar.gz
Algorithm Hash digest
SHA256 861b5c6ba63350b2b77d39c828835c9ed6c329ff1968556299b3054a24a337e1
MD5 20ac39cd9cdf1b891c3e1677b6d95879
BLAKE2b-256 5d4221dd49d4b8a533b2345a115dedf9cd7c9f02bd8d0deecd66a1b70fd1e503

See more details on using hashes here.

File details

Details for the file flexclash-0.0.2-py3-none-any.whl.

File metadata

  • Download URL: flexclash-0.0.2-py3-none-any.whl
  • Upload date:
  • Size: 23.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 colorama/0.4.4 importlib-metadata/4.6.4 keyring/23.5.0 pkginfo/1.8.2 readme-renderer/34.0 requests-toolbelt/0.9.1 requests/2.25.1 rfc3986/1.5.0 tqdm/4.57.0 urllib3/1.26.5 CPython/3.10.12

File hashes

Hashes for flexclash-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 3a0e3327ec4cfa1cbf12fd76e35a1de4254526bffc24abd545f83b56bf8f063c
MD5 cbfb6974644b93d16ad9727d5e35cd9b
BLAKE2b-256 fb71c0c27174393acd887abdc462a1d992bed6124d282c9ab545fe320a5527f6

See more details on using hashes here.

Supported by

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