Text Anonymization Evaluation Library
Project description
𝜏 Tau-Eval: A Unified Evaluation Framework for Useful and Private Text Anonymization
Tau-Eval is a user-friendly, modular, and customizable Python library designed to benchmark and evaluate text anonymization algorithms. It enables granular analysis of anonymization impacts from both privacy and utility perspectives. Tau-Eval seamlessly integrates with LiteLLM and 🤗 Hugging Face to support a wide range of datasets, models, and evaluation metrics.
Installation
From PyPI
Install Tau-Eval via pip:
pip install tau-eval
From source
To install from source:
- Clone this repository on your own path:
git clone https://github.com/gabrielloiseau/tau-eval.git
cd tau-eval
- Create an environment with your own preferred package manager. We used python 3.10 and dependencies listed in
pyproject.toml. If you use conda, you can just run the following commands from the root of the project:
conda create --name taueval python=3.10 # create the environment
conda activate taueval # activate the environment
pip install -e . # install the required packages
Quickstart
Tau-Eval is designed for flexibility. With just a few lines of code, you can set up and run evaluations.
1. Define Your Anonymization Model
Create a custom anonymization model by extending the Anonymizer interface:
from tau_eval.models import Anonymizer
class TestModel(Anonymizer):
def __init__(self):
self.name = "Test Model"
def anonymize(self, text: str) -> str:
# Implement anonymization logic
return text
def anonymize_batch(self, texts: list[str]) -> list[str]:
# Batch processing
return texts
Or use prebuilt models from tau_eval.models.
2. Configure Evaluation Metrics
Use built-in metrics from tau_eval.metrics or define your own following this signature:
Callable[[str | list[str], str | list[str]], dict]
This allows complete control over what and how you evaluate.
3. Instantiate Tasks
Tasks can be created using prebuilt options in tau_eval.tasks, or customized using CustomTask. Tau-Eval also supports tasksource for dataset integration.
from tau_eval.tasks import DeIdentification
from tasknet import AutoTask
anli = AutoTask("anli/a1")
deid = DeIdentification(dataset="ai4privacy/pii-masking-400k")
4. Configure and Run Your Experiment
Define an experiment configuration:
from tau_eval.config import ExperimentConfig
config = ExperimentConfig(
exp_name="test-experiment",
classifier_name="answerdotai/ModernBERT-base",
train_task_models=True,
train_with_generations=False,
)
Run the experiment:
from tau_eval.experiment import Experiment
Experiment(
models=[TestModel(), ...],
metrics=["bertscore", "rouge"],
tasks=[anli, deid],
config=config
).run()
5. Visualize Results
Tau-Eval includes built-in visualization tools to compare model anonymization strategies and evaluation results. You can find them with tau_eval.visualization.
Tutorials
You can explore our tutorials to master Tau-Eval more effectively in the examples/ folder.
Contributors
- Gabriel Loiseau, Hornetsecurity, Inria Lille
Citation
If you use 𝜏 Tau-Eval in your work, please cite our paper as follows:
@misc{loiseau2025taueval,
title={Tau-Eval: A Unified Evaluation Framework for Useful and Private Text Anonymization},
author={Gabriel Loiseau, Damien Sileo, Damien Riquet, Maxime Meyer, Marc Tommasi},
year={2025},
eprint={2506.05979},
archivePrefix={arXiv},
primaryClass={cs.CL},
url={https://arxiv.org/abs/2506.05979},
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file tau_eval-0.2.1.tar.gz.
File metadata
- Download URL: tau_eval-0.2.1.tar.gz
- Upload date:
- Size: 39.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4462d7a9f6ea6721867993eb7c008de13991e39819773ced0d9dfb123437b23d
|
|
| MD5 |
e6f0f91d8ab8c42ade61550832a2307f
|
|
| BLAKE2b-256 |
f05336814ed8e54f9e700c1fc3dc2362cf1ab88c6b349ab3c1cad2cbfd27a0a3
|
Provenance
The following attestation bundles were made for tau_eval-0.2.1.tar.gz:
Publisher:
python-publish.yml on GabrielLoiseau/tau-eval
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tau_eval-0.2.1.tar.gz -
Subject digest:
4462d7a9f6ea6721867993eb7c008de13991e39819773ced0d9dfb123437b23d - Sigstore transparency entry: 288278083
- Sigstore integration time:
-
Permalink:
GabrielLoiseau/tau-eval@8c8d32effd7f78cb0b96f7b4db245cf990dc19e4 -
Branch / Tag:
refs/tags/v0.2.1 - Owner: https://github.com/GabrielLoiseau
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@8c8d32effd7f78cb0b96f7b4db245cf990dc19e4 -
Trigger Event:
release
-
Statement type:
File details
Details for the file tau_eval-0.2.1-py3-none-any.whl.
File metadata
- Download URL: tau_eval-0.2.1-py3-none-any.whl
- Upload date:
- Size: 42.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
848819f1c466d82413c76278aae20f4abef6df0e12e38d7714e337ca3c995fe7
|
|
| MD5 |
e72bd1d37e570919b60cfb470307d569
|
|
| BLAKE2b-256 |
97ec4d8155af42c477593cee8c6985a067506bfe9011bff690f6323e71d0c77c
|
Provenance
The following attestation bundles were made for tau_eval-0.2.1-py3-none-any.whl:
Publisher:
python-publish.yml on GabrielLoiseau/tau-eval
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tau_eval-0.2.1-py3-none-any.whl -
Subject digest:
848819f1c466d82413c76278aae20f4abef6df0e12e38d7714e337ca3c995fe7 - Sigstore transparency entry: 288278109
- Sigstore integration time:
-
Permalink:
GabrielLoiseau/tau-eval@8c8d32effd7f78cb0b96f7b4db245cf990dc19e4 -
Branch / Tag:
refs/tags/v0.2.1 - Owner: https://github.com/GabrielLoiseau
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@8c8d32effd7f78cb0b96f7b4db245cf990dc19e4 -
Trigger Event:
release
-
Statement type: