Skip to main content

Bayesian Light Source Separator

Project description

Bayesian Light Source Separator (BLISS)

tests codecov.io PyPI

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)

  1. Install poetry:
curl -sSL https://install.python-poetry.org | python3 -
poetry config virtualenvs.in-project true
  1. Install the fftw library (which is used by galsim). With Ubuntu you can install it by running
sudo apt-get install libfftw3-dev
  1. Install git-lfs if you haven't already installed it for another project:
git-lfs install
  1. 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
  1. To create a poetry environment with the bliss dependencies satisfied, run
cd bliss
poetry install
  1. Activate the virtual environment:
source .venv/bin/activate
  1. Verify that bliss is installed correctly by running the tests both on your CPU (default) and on your GPU:
pytest
pytest --gpu
  1. 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 model
  • mode=train - Train encoder networks on simulated or real data
  • mode=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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bliss_toolkit-0.4.2.tar.gz (61.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bliss_toolkit-0.4.2-py3-none-any.whl (69.5 kB view details)

Uploaded Python 3

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

Hashes for bliss_toolkit-0.4.2.tar.gz
Algorithm Hash digest
SHA256 6a9d4a01644e77c9def993987283c7553a190fb459c5a402330d89308074c9ee
MD5 2c8921d9b452fe33af92838699e1fa76
BLAKE2b-256 d63a391d55e75a2fc5a8b9ab1dd4cfd65a9651aea211a894834e745227cc8e93

See more details on using hashes here.

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

Hashes for bliss_toolkit-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 29e22e58ed675d6378a3b9cbaaf0820cff2bc5d7da81abad034e42c8166ea081
MD5 6ca31b26963a6df74975569ddbb25dfd
BLAKE2b-256 d4577b6a7917dbeb86e03d98ed56758d36e14a63ccb6201e9cc8a384cc06b79f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page