Home

Awesome

<!-- Banner --> <div align="center"> <picture> <source media="(prefers-color-scheme: dark)" srcset="docs/assets/banner_dark.png"> <source media="(prefers-color-scheme: light)" srcset="docs/assets/banner_light.png"> <img src="docs/assets/banner_light.png" alt="Puncc" width="90%" align="right"> </picture> </div> <br> <!-- Badges --> <div align="center"> <a href="#"> <img src="https://img.shields.io/badge/Python-3.8 +-efefef"> </a> <a href="#"> <img src="https://img.shields.io/badge/License-MIT-efefef"> </a> <a href="https://github.com/deel-ai/puncc/actions/workflows/linter.yml"> <img alt="PyLint" src="https://github.com/deel-ai/puncc/actions/workflows/linter.yml/badge.svg"> </a> <a href="https://github.com/deel-ai/puncc/actions/workflows/tests.yml"> <img alt="Tox" src="https://github.com/deel-ai/puncc/actions/workflows/tests.yml/badge.svg"> </a> </div> <br>

Puncc (short for Predictive uncertainty calibration and conformalization) is an open-source Python library. It seamlessly integrates a collection of state-of-the-art conformal prediction algorithms and associated techniques for diverse machine learning tasks, including regression, classification and anomaly detection. Puncc can be used with any predictive model to provide rigorous uncertainty estimations. Under data exchangeability (or i.i.d), the generated prediction sets are guaranteed to cover the true outputs within a user-defined error $\alpha$.

Documentation is available online.

πŸ“š Table of contents

🐾 Installation

puncc requires a version of python higher than 3.8 and several libraries including Scikit-learn and Numpy. It is recommended to install puncc in a virtual environment to not mess with your system's dependencies.

You can directly install the library using pip:

pip install puncc
<!-- You can alternatively clone the repo and use the makefile to automatically create a virtual environment and install the requirements: * For users: ```bash make install-user ``` * For developpers: ```bash make prepare-dev ``` -->

πŸ“– Documentation

For comprehensive documentation, we encourage you to visit the official documentation page.

πŸ‘¨β€πŸŽ“ Tutorials

We highly recommend following the introductory tutorials to get familiar with the library and its API.

TutorialDescriptionLink
Introduction TutorialGet started with the basics of puncc.Open In Github Open In Colab
API TutorialLearn about the API and how to use it effectively.Open In Github Open In Colab
Tutorial on CP with PyTorchUnderstand how to apply Conformal Prediction with PyTorch.Open In Github Open In Colab
Architecture OverviewDetailed overview of puncc's architecture.Open In Github

πŸš€ Quickstart

Conformal prediction enables to transform point predictions into interval predictions with high probability of coverage. The figure below shows the result of applying the split conformal algorithm on a linear regressor.

<figure style="text-align:center"> <img src="docs/assets/cp_process.png"/> </figure>

Many conformal prediction algorithms can easily be applied using puncc. The code snippet below shows the example of split conformal prediction with a pretrained linear model:

from deel.puncc.api.prediction import BasePredictor
from deel.puncc.regression import SplitCP

# Load calibration and test data
# ...

# Pretrained regression model
# trained_linear_model = ...

# Wrap the model to enable interoperability with different ML libraries
trained_predictor =  BasePredictor(trained_linear_model)

# Instanciate the split conformal wrapper for the linear model.
# Train argument is set to False because we do not want to retrain the model
split_cp = SplitCP(trained_predictor, train=False)

# With a calibration dataset, compute (and store) nonconformity scores
split_cp.fit(X_calib=X_calib, y_calib=y_calib)

# Obtain the model's point prediction y_pred and prediction interval
# PI = [y_pred_lower, y_pred_upper] for a target coverage of 90% (1-alpha).
y_pred, y_pred_lower, y_pred_upper = split_cp.predict(X_test, alpha=0.1)

The library provides several metrics (deel.puncc.metrics) and plotting capabilities (deel.puncc.plotting) to evaluate and visualize the results of a conformal procedure. For a target error rate of $\alpha = 0.1$, the marginal coverage reached in this example on the test set is higher than $90$% (see Introduction tutorial):

<div align="center"> <figure style="text-align:center"> <img src="docs/assets/results_quickstart_split_cp_pi.png" alt="90% Prediction Interval with the Split Conformal Prediction Method" width="70%"/> <div align=center>90% Prediction Interval with Split Conformal Prediction.</div> </figure> </div> <br>

More flexibility with the API

Puncc provides two ways of defining and using conformal prediction wrappers:

A quick comparison of both approaches is provided in the API tutorial for a regression problem.

πŸ“š Citation

If you use our library for your work, please cite our paper:

@inproceedings{mendil2023puncc,
  title={PUNCC: a Python Library for Predictive Uncertainty Calibration and Conformalization},
  author={Mendil, Mouhcine and Mossina, Luca and Vigouroux, David},
  booktitle={Conformal and Probabilistic Prediction with Applications},
  pages={582--601},
  year={2023},
  organization={PMLR}
}

Puncc has been used to support the work presented in our COPA 2022 paper on conformal prediction for time series.

@inproceedings{mendil2022robust,
  title={Robust Gas Demand Forecasting With Conformal Prediction},
  author={Mendil, Mouhcine and Mossina, Luca and Nabhan, Marc and Pasini, Kevin},
  booktitle={Conformal and Probabilistic Prediction with Applications},
  pages={169--187},
  year={2022},
  organization={PMLR}
}

πŸ™ Acknowledgments

<img align="right" src="https://www.deel.ai/wp-content/uploads/2021/05/logo-DEEL.png" width="25%"> This project received funding from the French ”Investing for the Future – PIA3” program within the Artificial and Natural Intelligence Toulouse Institute (ANITI). The authors gratefully acknowledge the support of the <a href="https://www.deel.ai/"> DEEL </a> project.

πŸ‘¨β€πŸ’» About the Developers

Puncc's development team is a group of passionate scientists and engineers who are committed to developing a dependable and user-friendly open-source software. We are always looking for new contributors to this initiative. If you are interested in helping us develop puncc, please feel free to get involved.

πŸ’» Contributing

Contributions are welcome! Feel free to report an issue or open a pull request. Take a look at our guidelines here.

πŸ”‘ License

The package is released under MIT license.