Skip to main content

Fair division algorithms in Python

Project description

fairpyx

PyTest result PyPI version

fairpyx is a Python library containing various algorithms for fair allocation, with an emphasis on Course allocation. It is designed for three target audiences:

  • Laypeople, who want to use existing fair division algorithms for real-life problems.
  • Researchers, who develop new fair division algorithms and want to quickly implement them and compare to existing algorithms.
  • Students, who want to trace the execution of algorithms to understand how they work.

Installation

For the stable version:

pip install fairpyx

For the latest version:

pip install git+https://github.com/ariel-research/fairpyx.git

To verify that everything was installed correctly, run one of the example programs, e.g.

cd fairpyx
python examples/courses.py
python examples/input_formats.py

or run the tests:

pytest

Usage

To activate a fair division algorithm, first construct a fairpyx.Instance, for example:

import fairpyx
valuations = {"Alice": {"w":11,"x":22,"y":44,"z":0}, "George": {"w":22,"x":11,"y":66,"z":33}}
instance = fairpyx.Instance(valuations=valuations)

An instance can have other fields, such as: agent_capacities, item_capacities, agent_conflicts and item_conflicts. These fields are used by some of the algorithms. See instances.py for details.

Then, use the function fairpyx.divide to run an algorithm on the instance. For example:

allocation = fairpyx.divide(algorithm=fairpyx.algorithms.iterated_maximum_matching, instance=instance)
print(allocation)

Features and Examples

  1. Course allocation algorithms;

  2. Various input formats, to easily use by both researchers and end-users;

  3. A demo of a the simple round-robin algorithm;

Contributing new algorithms

You are welcome to add fair allocation algorithms, including your published algorithms, to fairpyx. Please use the following steps to contribute:

  1. Fork the repository, then install your fork locally as follows:

    clone https://github.com/<your-username>/fairpyx.git
    cd fairpyx
    pip install -e .
    
  2. Read the code at algorithm_examples.py to see how the implementation works.

  • Note that the implementation does not use the Instance variable directly - it uses an AllocationBuilder variable, which tracks both the ongoing allocation and the remaining input (the remaining capacities of agents and items).
  1. Write a function that accepts a parameter of type AllocationBuilder, as well as any custom parameters your algorithm needs.
  • The AllocationBuilder argument sent to your function is already initialized with an empty allocation. Your function has to modify this argument using the methods give or give_bundle, which give an item or a set of items to an agent and update the capacities accordingly.
  • You can easily chain algorithms. For example, if the last phase of your algorithm is dividing the remaining items using round-robin, you can simply call round_robin(alloc) at the end of your function; the AllocationBundle object already tracks the remaining items for you.
  • Your function need not return any value; the allocation is read from the alloc.
  • The divide function is responsible for converting the Instance to an AllocationBuilder before your function starts, and extracting the allocation from the AllocationBuilder after your function ends, so you can focus on writing the algorithm itself.

See allocations.py for more details on the AllocationBuilder object.

See also

  • fairpy is an older library with the same goals. It contains more algorithms for fair item allocation, as well as algorithms for fair cake-cutting. fairpyx was created in order to provide a simpler interface, that also allows capacities and conflicts, which are important for fair course allocation.
  • Other open-source projects related to fairness.

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

fairpyx-0.0.9.tar.gz (180.4 kB view details)

Uploaded Source

Built Distribution

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

fairpyx-0.0.9-py3-none-any.whl (179.7 kB view details)

Uploaded Python 3

File details

Details for the file fairpyx-0.0.9.tar.gz.

File metadata

  • Download URL: fairpyx-0.0.9.tar.gz
  • Upload date:
  • Size: 180.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.17

File hashes

Hashes for fairpyx-0.0.9.tar.gz
Algorithm Hash digest
SHA256 f45030c55bebf5cca48f6997f7d0b07b9136214d1fe20617a1244d5e11e5da1f
MD5 6e8100aa5f0de606da3247f19f225081
BLAKE2b-256 779b281b1b20fffcca2a6c1c2b793dc2e3d774ed8c1358d680403442816aa37a

See more details on using hashes here.

File details

Details for the file fairpyx-0.0.9-py3-none-any.whl.

File metadata

  • Download URL: fairpyx-0.0.9-py3-none-any.whl
  • Upload date:
  • Size: 179.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.17

File hashes

Hashes for fairpyx-0.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 fa53cac0f78cfc3199279d42c60b48e008c5e22a69f90c898d64a6d20c2dc89d
MD5 215b828e5ad441af81dce18381617baa
BLAKE2b-256 37d4605b3d3b13d327415d9caf6bf2c4cd85ab9f89ac758f95da664a1dda9194

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