Bayesian Light Source Separator
Project description
Bayesian Light Source Separator (BLISS)
Introduction
BLISS is a Bayesian method for deblending and cataloging light sources. BLISS provides:
- Accurate estimation of parameters in crowded fields with overlapping sources
- Calibrated uncertainties through fully Bayesian inference via neural posterior estimation (NPE)
- Scalability to petabyte-scale surveys containing billions of celestial objects
BLISS uses neural posterior estimation (NPE), a form of simulation-based inference in which a neural network maps telescope images directly to an approximate Bayesian posterior. BLISS uses autoregressive tiling with checkerboard patterns that align the variational distribution's conditional dependencies with the true posterior, improving calibration. BLISS systematically outperforms standard survey pipelines for light source detection, flux measurement, star/galaxy classification, and galaxy shape measurement.
Installation
Requirements: Python 3.12 or higher
BLISS is pip installable with the following command:
pip install bliss-toolkit
The required dependencies are listed in the [tool.poetry.dependencies] block of the pyproject.toml file.
Installation (Developers)
- Install poetry:
curl -sSL https://install.python-poetry.org | python3 -
poetry config virtualenvs.in-project true
- Install the fftw library (which is used by
galsim). With Ubuntu you can install it by running
sudo apt-get install libfftw3-dev
- Install git-lfs if you haven't already installed it for another project:
git-lfs install
- Now download the bliss repo and fetch some pre-trained models and test data from git-lfs:
git clone git@github.com:prob-ml/bliss.git
- To create a poetry environment with the
blissdependencies satisfied, run
cd bliss
poetry install
- Activate the virtual environment:
source .venv/bin/activate
- Verify that bliss is installed correctly by running the tests both on your CPU (default) and on your GPU:
pytest
pytest --gpu
- Finally, if you are planning to contribute code to this repository, consider installing our pre-commit hooks so that your code commits will be checked locally for compliance with our coding conventions:
pre-commit install
Usage
BLISS provides a command-line interface powered by Hydra for configuration management. The basic usage pattern is:
bliss mode={generate,train,predict} [config options]
mode=generate- Generate synthetic training data from the forward modelmode=train- Train encoder networks on simulated or real datamode=predict- Run inference on astronomical images to produce catalogs
Configuration files are located in bliss/conf/ and can be composed and overridden via command line arguments.
Case Studies
The case_studies/ directory contains research applications of BLISS:
- weak_lensing/ - Shear (γ) and convergence (κ) estimation, validated on DC2 and DECaLS simulations
- redshift/ - Photo-z estimation (BLISS-PZ) with multiple variational families
- galaxy_clustering/ - Galaxy cluster detection and membership prediction, validated on DES DR2
- dc2_cataloging/ - Full cataloging pipeline for DC2 simulation
- strong_lensing/ - Strong gravitational lens detection
- spatial_tiling/ - Spatially autoregressive tiling for astronomical cataloging
- psf_variation/ - Spatially varying PSFs for astronomical cataloging
References
Yicun Duan, Xinyue Li, Camille Avestruz, Jeffrey Regier, and LSST Dark Energy Collaboration. Neural posterior estimation for cataloging astronomical images from the Legacy Survey of Space and Time. arXiv:2510.15315. 2025.
Jeffrey Regier. Neural posterior estimation with autoregressive tiling for detecting objects in astronomical images. arXiv:2510.03074. 2025.
Aakash Patel, Tianqing Zhang, Camille Avestruz, Jeffrey Regier, and LSST Dark Energy Science Collaboration. Neural posterior estimation for cataloging astronomical images with spatially varying backgrounds and point spread functions. The Astronomical Journal. 2025.
Runjing Liu, Jon D. McAuliffe, Jeffrey Regier, and The LSST Dark Energy Science Collaboration. Variational inference for deblending crowded starfields. Journal of Machine Learning Research. 2023.
Mallory Wang, Ismael Mendoza, Cheng Wang, Camille Avestruz, and Jeffrey Regier. Statistical inference for coadded astronomical images. NeurIPS Workshop on Machine Learning and the Physical Sciences. 2022.
Yash Patel and Jeffrey Regier. Scalable Bayesian inference for detecting strong gravitational lensing systems. NeurIPS Workshop on Machine Learning and the Physical Sciences. 2022.
Derek Hansen, Ismael Mendoza, Runjing Liu, Ziteng Pang, Zhe Zhao, Camille Avestruz, and Jeffrey Regier. Scalable Bayesian inference for detection and deblending in astronomical images. ICML Workshop on Machine Learning for Astrophysics. 2022.
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 bliss_toolkit-0.4.2.tar.gz.
File metadata
- Download URL: bliss_toolkit-0.4.2.tar.gz
- Upload date:
- Size: 61.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.4 CPython/3.12.3 Linux/6.14.0-36-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6a9d4a01644e77c9def993987283c7553a190fb459c5a402330d89308074c9ee
|
|
| MD5 |
2c8921d9b452fe33af92838699e1fa76
|
|
| BLAKE2b-256 |
d63a391d55e75a2fc5a8b9ab1dd4cfd65a9651aea211a894834e745227cc8e93
|
File details
Details for the file bliss_toolkit-0.4.2-py3-none-any.whl.
File metadata
- Download URL: bliss_toolkit-0.4.2-py3-none-any.whl
- Upload date:
- Size: 69.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.4 CPython/3.12.3 Linux/6.14.0-36-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
29e22e58ed675d6378a3b9cbaaf0820cff2bc5d7da81abad034e42c8166ea081
|
|
| MD5 |
6ca31b26963a6df74975569ddbb25dfd
|
|
| BLAKE2b-256 |
d4577b6a7917dbeb86e03d98ed56758d36e14a63ccb6201e9cc8a384cc06b79f
|