Skip to main content

Fairical is a Python library to assess adjustable demographically fair Machine Learning (ML) systems

Project description

latest-docs build coverage repository

Fairical

Fairical is a Python library for rigorously evaluating and comparing demographically fair machine-learning systems through the lens of multi-objective optimization. Rather than treating fairness as a single constraint, Fairical recognizes that real-world deployments must balance multiple, often conflicting fairness metrics (e.g., demographic parity, equalized odds across race, gender, age) alongside traditional utility measures like accuracy. It implements a model-agnostic evaluation framework that approximates Pareto fronts of utility-fairness trade-offs, then distills each system's performance into a compact measurement table and radar chart. By calculating convergence (how close models get to optimal trade-offs), diversity (uniform distribution and spread of solutions), capacity (number of non-dominated points), and a unified convergence-diversity score via hypervolume, Fairical delivers both quantitative rigor and qualitative clarity.

For installation and usage instructions, check-out our documentation.

If you use this library in published material, we kindly ask you to cite this work:

@misc{ozbulak_multi-objective_2025,
    title = {A Multi-Objective Evaluation Framework for Analyzing Utility-Fairness Trade-Offs in Machine Learning Systems},
    author = {Özbulak, Gökhan and Jimenez-del-Toro, Oscar and Fatoretto, Maíra and Berton, Lilian and Anjos, André},
    url = {https://arxiv.org/abs/2503.11120},
    doi = {10.48550/ARXIV.2503.11120},
    publisher = {{arXiv}},
    urldate = {2025-07-10},
    date = {2025},
}

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

fairical-2.0.1.tar.gz (59.5 kB view details)

Uploaded Source

Built Distribution

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

fairical-2.0.1-py3-none-any.whl (35.4 kB view details)

Uploaded Python 3

File details

Details for the file fairical-2.0.1.tar.gz.

File metadata

  • Download URL: fairical-2.0.1.tar.gz
  • Upload date:
  • Size: 59.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for fairical-2.0.1.tar.gz
Algorithm Hash digest
SHA256 cfea132897837b704ef3eccda4c29dd64bdea96fb7a34135b2359244348b5e3a
MD5 9765b9281d2d4f99a261e74d2734d736
BLAKE2b-256 a19594b730c409e98ece89b9900e87eac37282ff277e23b9c6b57b3ba14df865

See more details on using hashes here.

File details

Details for the file fairical-2.0.1-py3-none-any.whl.

File metadata

  • Download URL: fairical-2.0.1-py3-none-any.whl
  • Upload date:
  • Size: 35.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.9

File hashes

Hashes for fairical-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 076b45adda9b99dd95d327c20fa726994a1a99b66938a673f4b178240e4c90e9
MD5 d316a8120ef0a59b690e62e70b119ece
BLAKE2b-256 5935c70e6f1d9ab818772c55b6eaa16bf1e1322dc6357500dbc528449f34f66e

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