Metadata-Version: 2.4
Name: uqregressors
Version: 1.0.13
Summary: PyTorch-based regressors with uncertainty quantification and scikit-learn interface
Author-email: Arjun Shah <arjunrs@stanford.edu>
License-Expression: MIT
License-File: LICENSE.txt
Requires-Python: >=3.8
Requires-Dist: covmetrics
Requires-Dist: gpytorch
Requires-Dist: matplotlib
Requires-Dist: numpy
Requires-Dist: openpyxl
Requires-Dist: optuna
Requires-Dist: scikit-learn
Requires-Dist: scikit-optimize
Requires-Dist: scipy
Requires-Dist: seaborn
Requires-Dist: xlrd
Provides-Extra: dev
Requires-Dist: black; extra == 'dev'
Requires-Dist: coverage; extra == 'dev'
Requires-Dist: jupyter; extra == 'dev'
Requires-Dist: mypy; extra == 'dev'
Requires-Dist: pytest; extra == 'dev'
Requires-Dist: ruff; extra == 'dev'
Provides-Extra: docs
Requires-Dist: mkdocs; extra == 'docs'
Requires-Dist: mkdocs-jupyter; extra == 'docs'
Requires-Dist: mkdocs-material; extra == 'docs'
Provides-Extra: wandb
Requires-Dist: wandb>=0.15; extra == 'wandb'
Description-Content-Type: text/markdown

[![PyPI - Version](https://img.shields.io/pypi/v/uqregressors.svg)](https://pypi.org/project/uqregressors)
[![Python Tests](https://github.com/arjunrs3/uqregressors/actions/workflows/python-tests.yml/badge.svg)](https://github.com/arjunrs3/uqregressors/actions/workflows/python-tests.yml)
-----

# UQRegressors

**UQRegressors** is a Python library for regression models that provide **prediction intervals**, in addition to point estimates. It is meant for machine learning applications where quantifying uncertainty is important. Full documentation is available at: https://arjunrs3.github.io/UQRegressors/.

It features **highly customizable** parameters for each model, an **easy to use** interface with built-in dataset validation, **GPU compatibility** with a PyTorch backend, **validated implementations** with comparisons to published results, **easy saving and loading** of created models, and a **wide variety of metrics and visualization** tools available to assess model quality. 

Please direct any questions or suggestions to the email arjunrs@stanford.edu.

---

## Key Capabilities

1. **Dataset Loading & Validation** — Utility functions to clean and validate your input data.
2. **Uncertainty‑Aware Regressors**  
   - Conformal: CQR, K‑Fold CQR, Ensemble‑based CQR  
   - Bayesian: Deep Ensembles, MC Dropout, Gaussian Processes (GP, BBMM GP)
3. **Hyperparameter Tuning** — Optuna‑based tuning with support for custom interval‑width objective functions.
4. **Uncertainty Metrics** — RMSE, coverage, interval width, interval score, NLL, correlation diagnostics, conditional coverage, RMSCD variants, and more.
5. **Visualization Tools** — Calibration curves, prediction-vs-true plots, model comparison bar charts.

---

## Installation
To install the core features of UQRegressors: 
```bash
pip install uqregressors
```
UQRegressors requires **PyTorch**, which you should install according to your setup:
- **CPU only**:  
  ```bash
  pip install torch torchvision torchaudio
  ```
- **CUDA GPU** (choose the version matching your GPU):
  ```bash
  pip install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118
  ```
- For other versions, see [PyTorch Install Guide](https://pytorch.org/get-started/locally).
---

## Getting Started (More detail in full docs)

```python
from uqregressors.bayesian.dropout import MCDropoutRegressor
from uqregressors.tuning.tuning import tune_hyperparams, interval_width
from uqregressors.plotting.plotting import plot_pred_vs_true

# Define a dataset
X_train = np.linspace(0, 1, 5)
X_test = np.linspace(0, 1, 40)
y_train = np.sin(2 * np.pi * X_train)
y_test = np.sin(2 * np.pi * X_test)

# Train an MC‑Dropout regressor
reg = MCDropoutRegressor(epochs=50, random_seed=42)
reg.fit(X_train, y_train)
mean, lower, upper = reg.predict(X_test)

# Visualize results
plot_pred_vs_true(mean, lower, upper, y_test, show=True, title="MC‑Dropout")

# Hyperparameter tuning example (e.g., tuning CQR)
from uqregressors.conformal.cqr import ConformalQuantileRegressor
cqr = ConformalQuantileRegressor(alpha=0.1, epochs=20, random_seed=42)

opt_cqr, best_score, study = tune_hyperparams(
    regressor=cqr,
    param_space={"tau_lo": lambda t: t.suggest_float("tau_lo", 0.01, 0.1),
                 "tau_hi": lambda t: t.suggest_float("tau_hi", 0.9, 0.99)},
    X=X_train, y=y_train,
    score_fn=interval_width,
    greater_is_better=False,
    n_trials=10,
    n_splits=3
)
mean_t, lo_t, hi_t = opt_cqr.predict(X_test)
plot_pred_vs_true(mean_t, lo_t, hi_t, y_test, show=True, title="Tuned CQR")
```

---

## Documentation

See the complete API Documentation with complete examples:  
https://arjunrs3.github.io/UQRegressors/

---

## Contributing

Contributions, issues, and feature requests are welcome! Please:

1. Fork the repo  
2. Create a feature branch (`git checkout -b my-feature`)  
3. Commit your changes and push  
4. Open a Pull Request
5. Email arjunrs@stanford.edu with any questions

---

## License

[MIT License](LICENSE)

---
