Composable Effects for Flexible and Accelerated Probabilistic Programming in NumPyro
Du Phan, Neeraj Pradhan, Martin Jankowiak
TL;DR
The paper tackles the need for fast, flexible probabilistic programming by uniting Pyro-like modeling with JAX-based acceleration. It introduces NumPyro, a NumPy-based PPL that uses effect handlers to compose with JAX transformations, enabling end-to-end JIT compilation and vectorization. A key contribution is an iterative NUTS implementation that is fully JIT-compiled and memory-efficient, along with vmap-enabled batching for inference tasks. Empirical results show substantial speedups over Pyro and Stan across small and large datasets, underscoring the practical impact for scalable probabilistic inference.
Abstract
NumPyro is a lightweight library that provides an alternate NumPy backend to the Pyro probabilistic programming language with the same modeling interface, language primitives and effect handling abstractions. Effect handlers allow Pyro's modeling API to be extended to NumPyro despite its being built atop a fundamentally different JAX-based functional backend. In this work, we demonstrate the power of composing Pyro's effect handlers with the program transformations that enable hardware acceleration, automatic differentiation, and vectorization in JAX. In particular, NumPyro provides an iterative formulation of the No-U-Turn Sampler (NUTS) that can be end-to-end JIT compiled, yielding an implementation that is much faster than existing alternatives in both the small and large dataset regimes.
