Skip to main content

The NLP Bias Identification Toolkit

Project description

Biaslyze

The NLP Bias Identification Toolkit

Bias is often subtle and difficult to detect in NLP models, as the protected attributes are less obvious and can take many forms in language (e.g. proxies, double meanings, ambiguities etc.). Therefore, technical bias testing is a key step in avoiding algorithmically mediated discrimination. However, it is currently conducted too rarely due to the effort involved, missing resources or lack of awareness for the problem.

Biaslyze helps to get started with the analysis of bias within NLP models and offers a concrete entry point for further impact assessments and mitigation measures. Especially for developers, researchers and teams with limited resources, our toolbox offers a low-effort approach to bias testing in NLP use cases.

Supported Models

All text classification models with probability output are supported. This includes models from scikit-learn, tensorflow, pytorch, huggingface transformers and custom models. The bias detection requires you to pass a predict_proba function similar to what you would get on scikit-learn models. You can find a tutorial on how to do that for pre-trained transformer models here.

Installation

Installation can be done using pypi:

pip install biaslyze

Then you need to download the required spacy models:

python -m spacy download en_core_web_sm

Quickstart

from biaslyze.bias_detectors import CounterfactualBiasDetector

bias_detector = CounterfactualBiasDetector()

# detect bias in the model based on the given texts
# here, clf is a scikit-learn text classification pipeline trained for a binary classification task
detection_res = bias_detector.process(
    texts=texts,
    predict_func=clf.predict_proba
)

# see a summary of the detection
detection_res.report()

# launch the dashboard visualize the counterfactual scores
detection_res.dashboard(num_keywords=10)

You will get results as Boxplots, among others, indicating the impact of keywords and concepts on the prediction of your model. Example output:

See more detailed examples in the tutorial.

Development setup

  • First you need to install poetry to manage your python environment: https://python-poetry.org/docs/#installation
  • Run make install to install the dependencies and get the spacy basemodels.
  • Now you can use biaslyze in your jupyter notebooks.

Adding concepts and keywords

You can add concepts and new keywords for existing concepts by editing the concept files in concepts. A tutorial on how to create custom concepts and work with them can be found here.

Preview/build the documentation with mkdocs

To preview the documentation run make doc-preview. This will launch a preview of the documentation on http://127.0.0.1:8000/. To build the documentation html run make doc.

Run the automated tests

make test

Style guide

We are using isort and black: make style For linting we are running ruff: make lint

Contributing

Follow the Google style guide for Python: https://google.github.io/styleguide/pyguide.html

This project uses black, isort and ruff to enforce style. Apply it by running make style and make lint.

Acknowledgements

  • Funded from March 2023 until August 2023 by logos of the "Bundesministerium für Bildung und Forschung", Prodotype Fund and OKFN-Deutschland

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

biaslyze-0.1.0.tar.gz (29.9 kB view details)

Uploaded Source

Built Distribution

biaslyze-0.1.0-py3-none-any.whl (33.9 kB view details)

Uploaded Python 3

File details

Details for the file biaslyze-0.1.0.tar.gz.

File metadata

  • Download URL: biaslyze-0.1.0.tar.gz
  • Upload date:
  • Size: 29.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.10.12 Linux/5.15.0-1041-azure

File hashes

Hashes for biaslyze-0.1.0.tar.gz
Algorithm Hash digest
SHA256 4b8fa8210a38019a7c7b3ac8ee1865f98c3ce94570a951aad2589c78bf223e42
MD5 4914a36bb18fb0a587a942395416708a
BLAKE2b-256 795748c3feec5c14dd6f5adf7bbfa03ac9cdded3e58eb4e1fc2c1faf63762db7

See more details on using hashes here.

File details

Details for the file biaslyze-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: biaslyze-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 33.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.10.12 Linux/5.15.0-1041-azure

File hashes

Hashes for biaslyze-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8b68ae16dec9f652d211fc6b2b0f63cdb872e358ac019ca3a3f8408cb8accb80
MD5 fb51d30f89b10dc0c8908106bee6cd9d
BLAKE2b-256 be28dcea9b74bf8a98ccc1fd019b55fa87a7b8ed0ae336bf54cc048d714cb7d0

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