This code repository contains implementations of measures used to quantify discrimination.
For background information on the project, see http://fairness-measures.org/
For the measures that are implemented, see http://fairness-measures.org/Pages/Measures
These programs take as input a dataset in which each row represents a person.
We assume one of the attributes in the input is the target or outcome, which we assume was produced by a predictive model (if we want to evaluate algorithmic fairness), or by a person (if we want to evaluate fairness of human decisions). For instance, an outcome could be binary such as whether a person got a scholarship or not, or numeric such as the credit score associated to a person. Some outcomes can be considered positive, such as when a benefit is received, while other outcomes are negative, such as when a benefit is denied.
We further assume there are protected attributes in the input, such as gender, race, age, or disability that should ideally not affect the outcome. Some values of the protected attribute are associated to potentially discriminated groups, such as disability=yes.
The output is a measure of fairness. Fairness can be measured in many ways, for instance one of the simplest cases is statistical parity, i.e., an equal distribution of protected and non-protected attributes for the elements that received the positive outcome. There are many other ways in which fairness can be measured, please refer to the code comments.
The rest of this page explains how to install and run the code.
- Each feature should be represented in a column with the first entry as the column name.
- Protected attributes require the prefix
protected
. The outcome attribute requires the prefixtarget
. For example, if you need to measure fairness rankings of a dataset with the columnssex
andcredit_score
, please rename the first columns e.g. toprotected_sex
andtarget_credit_Score
- Protected candidates' feature value indices range from
0
, to the highest protected group index , such that in the case of havingsex
as a protected feature, we use1
for women if female is the protected group and0
for men provided they are the only unprotected group. In a different use case, where age is the protected attribute in ascending order, we can use:
0
for people up to 18 years of age, with3
being the lowest protected group index (always0
)1
for people between 19 to 35 year,2
for people between 36 to 64 years,3
for people above 65 years, with these being as the group protected most, i.e. with a highest protected group index (higher number indicates a more protected group)
Please note that the available datasets are collected and/or provided as is and are not preprocessed with any protected
or target
columns.
- python version 3.5
- dataset to examine in csv format with features as described above
- clone repository
- put into python path
src
andtest
packages match the same directory scheme. If you would like to run a test for a certain script, it should be under the same file structure from thetest
directory. To run all tests at once, userunner.py
- go to
src/
- call main.py to perform the tests on the provided example dataset
python3 main.py -d
- call
main.py
with your dataset file to perform t-test on your data
python3 main.py -f </PATH/TO/YOUR/CSV/FILE/datasetname.csv>
- unittests for the system
- go to
test/
- call
python3 runner.py
- you can upload your contributions on the
Upload
branch. After reviewing, we will merge it. - For suggestions, please create a Github Issue.
- Check GitHub's Version History
- Meike Zehlike - Initiator - MilkaLichtblau
See also the list of contributors who participated in this project.
This project is licensed under the GPL License
If you use this software or prepared datasets in your work, we ask you to cite this work:
- Meike Zehlike, Carlos Castillo, Francesco Bonchi, Sara Hajian, Mohamed Megahed. “Fairness Measures: Datasets and software for detecting algorithmic discrimination.” June, 2017. http://fairness-measures.org/
Measurements that were implemented are found in the following paper(s):
- Indrė Žliobaitė. “Measuring discrimination in algorithmic decision making.” Data Mining and Knowledge Discovery 31, no. 4 (July 31, 2017): 1060-089. doi:10.1007/s10618-017-0506-1.”