Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aleximmer/Laplace
Laplace approximations for Deep Learning.
https://github.com/aleximmer/Laplace
approximate-bayesian-inference deep-learning laplace-approximation neural-network
Last synced: 4 months ago
JSON representation
Laplace approximations for Deep Learning.
- Host: GitHub
- URL: https://github.com/aleximmer/Laplace
- Owner: aleximmer
- License: mit
- Created: 2021-03-12T16:31:04.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-07-12T16:50:37.000Z (7 months ago)
- Last Synced: 2024-07-15T13:00:56.349Z (7 months ago)
- Topics: approximate-bayesian-inference, deep-learning, laplace-approximation, neural-network
- Language: Python
- Homepage: https://aleximmer.github.io/Laplace
- Size: 2.04 MB
- Stars: 438
- Watchers: 9
- Forks: 65
- Open Issues: 43
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
![]()
data:image/s3,"s3://crabby-images/b70bc/b70bc4d78c24e0db2dc36038c9eca30ad2500553" alt="pytest"
data:image/s3,"s3://crabby-images/cbb3b/cbb3b3b80c7c3b3f253cc854dbe7cbf05128dd9d" alt="lint"
data:image/s3,"s3://crabby-images/fc831/fc831a35a2d39ad59ce4187e762fb2de5ebf159d" alt="format"
[📖 Documentation \& API reference](https://aleximmer.github.io/Laplace)
The laplace package facilitates the application of Laplace approximations for entire neural networks, subnetworks of neural networks, or just their last layer.
The package enables posterior approximations, marginal-likelihood estimation, and various posterior predictive computations.There is also a corresponding paper, [_Laplace Redux — Effortless Bayesian Deep Learning_](https://arxiv.org/abs/2106.14806), which introduces the library, provides an introduction to the Laplace approximation, reviews its use in deep learning, and empirically demonstrates its versatility and competitiveness. Please consider referring to the paper when using our library:
```bibtex
@inproceedings{laplace2021,
title={Laplace Redux--Effortless {B}ayesian Deep Learning},
author={Erik Daxberger and Agustinus Kristiadi and Alexander Immer
and Runa Eschenhagen and Matthias Bauer and Philipp Hennig},
booktitle={{N}eur{IPS}},
year={2021}
}
```The [code](https://github.com/runame/laplace-redux) to reproduce the experiments in the paper is also publicly available; it provides examples of how to use our library for predictive uncertainty quantification, model selection, and continual learning.
> [!IMPORTANT]
> As a user, one should not expect Laplace to work automatically.
> That is, one should experiment with different Laplace's options
> (hessian_factorization, prior precision tuning method, predictive method, backend,
> etc!). Try looking at various papers that use Laplace for references on how to
> set all those options depending on the applications/problems at hand.## Installation
> [!IMPORTANT]
> We assume Python >= 3.9 since lower versions are [(soon to be) deprecated](https://devguide.python.org/versions/).
> PyTorch version 2.0 and up is also required for full compatibility.To install laplace with `pip`, run the following:
```bash
pip install laplace-torch
```Additionally, if you want to use the `asdfghjkl` backend, please install it via:
```bash
pip install git+https://[email protected]/wiseodd/asdl@asdfghjkl
```## Simple usage
> [!TIP]
> Check out for more usage examples
> and API reference.In the following example, a pre-trained model is loaded,
then the Laplace approximation is fit to the training data
(using a diagonal Hessian approximation over all parameters),
and the prior precision is optimized with cross-validation `"gridsearch"`.
After that, the resulting LA is used for prediction with
the `"probit"` predictive for classification.```python
from laplace import Laplace# Pre-trained model
model = load_map_model()# User-specified LA flavor
la = Laplace(model, "classification",
subset_of_weights="all",
hessian_structure="diag")
la.fit(train_loader)
la.optimize_prior_precision(
method="gridsearch",
pred_type="glm",
link_approx="probit",
val_loader=val_loader
)# User-specified predictive approx.
pred = la(x, pred_type="glm", link_approx="probit")
```## Contributing
Pull requests are very welcome.
Please follow the guidelines in