The Fast Loaded Dice Roller: A Near-Optimal Exact Sampler for Discrete Probability Distributions
From MaRDI portal
Publication:6336352
arXiv2003.03830MaRDI QIDQ6336352
Feras A. Saad, Vikash Mansinghka, Cameron E. Freer, Martin C. Rinard
Publication date: 8 March 2020
Abstract: This paper introduces a new algorithm for the fundamental problem of generating a random integer from a discrete probability distribution using a source of independent and unbiased random coin flips. We prove that this algorithm, which we call the Fast Loaded Dice Roller (FLDR), is highly efficient in both space and time: (i) the size of the sampler is guaranteed to be linear in the number of bits needed to encode the input distribution; and (ii) the expected number of bits of entropy it consumes per sample is at most 6 bits more than the information-theoretically optimal rate. We present fast implementations of the linear-time preprocessing and near-optimal sampling algorithms using unsigned integer arithmetic. Empirical evaluations on a broad set of probability distributions establish that FLDR is 2x-10x faster in both preprocessing and sampling than multiple baseline algorithms, including the widely-used alias and interval samplers. It also uses up to 10000x less space than the information-theoretically optimal sampler, at the expense of less than 1.5x runtime overhead.
Has companion code repository: https://github.com/probcomp/fast-loaded-dice-roller
This page was built for publication: The Fast Loaded Dice Roller: A Near-Optimal Exact Sampler for Discrete Probability Distributions
Report a bug (only for logged in users!)Click here to report a bug for this page (MaRDI item Q6336352)