Skip to main content

Declearn - a python package for private decentralized learning.

Project description

Declearn: a modular and extensible framework for Federated Learning


Introduction

declearn is a python package providing with a framework to perform federated learning, i.e. to train machine learning models by distributing computations across a set of data owners that, consequently, only have to share aggregated information (rather than individual data samples) with an orchestrating server (and, by extension, with each other).

The aim of declearn is to provide both real-world end-users and algorithm researchers with a modular and extensible framework that:

  • builds on abstractions general enough to write backbone algorithmic code agnostic to the actual computation framework, statistical model details or network communications setup
  • designs modular and combinable objects, so that algorithmic features, and more generally any specific implementation of a component (the model, network protocol, client or server optimizer...) may easily be plugged into the main federated learning process - enabling users to experiment with configurations that intersect unitary features
  • provides with functioning tools that may be used out-of-the-box to set up federated learning tasks using some popular computation frameworks (scikit- learn, tensorflow, pytorch...) and federated learning algorithms (FedAvg, Scaffold, FedYogi...)
  • provides with tools that enable extending the support of existing tools and APIs to custom functions and classes without having to hack into the source code, merely adding new features (tensor libraries, model classes, optimization plug-ins, orchestration algorithms, communication protocols...) to the party

At the moment, declearn has been focused on so-called "centralized" federated learning that implies a central server orchestrating computations, but it might become more oriented towards decentralized processes in the future, that remove the use of a central agent.

Setup

TL;DR:

  • Use pip install declearn to install the package's latest release from PyPI.
  • Use pip install declearn[all] to install all extra dependencies, that notably include network communication and machine learning frameworks.
  • You may be picky as to the extra dependencies you want to install: for that, please have a look at the [project.optional-dependencies] section of the pyproject.toml file.

If you want to read more about how to setup for and finally install declearn, you may read the installation guide

Quickstart

Our quickstart example is the right place to start with if you want too see in a glance what end-user declearn code looks like.

Usage of the Python API

The user guide is the natural entrypoint to learn more about declearn's take on Federated Learning, the current package capabilities, how to implement your own use case, and the structure and key points of the package's API.

To dive directly into the code's documentation, you may also jump to the API reference.

Developers

Information for developers, such as how to contribute, coding rules, and how to run the tests, can be found in the developer guide.

Copyright

Declearn is an open-source software developed by people from the Magnet team at Inria.

Authors

Current core developers are listed under the pyproject.toml file. A more detailed acknowledgement and history of authors and contributors to declearn can be found in the AUTHORS file.

License

Declearn distributed under the Apache-2.0 license. All code files should therefore contain the following mention, which also applies to the present README file:

Copyright 2023 Inria (Institut National de la Recherche en Informatique
et Automatique)

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

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

declearn-2.0.3.tar.gz (213.6 kB view details)

Uploaded Source

Built Distribution

declearn-2.0.3-py3-none-any.whl (223.5 kB view details)

Uploaded Python 3

File details

Details for the file declearn-2.0.3.tar.gz.

File metadata

  • Download URL: declearn-2.0.3.tar.gz
  • Upload date:
  • Size: 213.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.4

File hashes

Hashes for declearn-2.0.3.tar.gz
Algorithm Hash digest
SHA256 0239dcec93a464612cc268e9045a2bf45ffb3b2708204f2f4a83704e916f99d1
MD5 04d02d6617d50bb16dba27b015f9b85d
BLAKE2b-256 30f20caa1180808f4a8861fb2204506a1aa6fdc4048227beca2db9e38729a59c

See more details on using hashes here.

File details

Details for the file declearn-2.0.3-py3-none-any.whl.

File metadata

  • Download URL: declearn-2.0.3-py3-none-any.whl
  • Upload date:
  • Size: 223.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.4

File hashes

Hashes for declearn-2.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 0d5a6325ff3ea0ea4705f8b875802c3ea49f562996766ef6f73413f617d973ce
MD5 b86f00ad972c4f41595feaee69be3857
BLAKE2b-256 44ba24cf2f78ed8f5a00cc666d75e52e28244c006e1bb8877f7e4cc9860d2cb4

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