Figure 1: We perform maximal Poisson-disk sampling by rasterization and occlusion culling. First, we rasterize random disks of distinct depths (red is close, blue is far) in (a). Second, we cull the occluded disks to remove conflicting samples in (b). Third, we iterate this process on the empty regions to obtain a maximal Poisson-disk distribution in (c). (e) and (f) show uniform and importance sampling on (d).
AbstractWe present PixelPie, a highly parallel geometric formulation of the Poisson-disk sampling problem on the graphics pipeline. Traditionally, generating a distribution by throwing darts and removing conflicts has been viewed as an inherently sequential process. In this paper, we present an efficient Poisson-disk sampling algorithm that uses rasterization in a highly parallel manner. Our technique is an iterative two step process. The first step of each iteration involves rasterization of random darts at varying depths. The second step involves culling conflicted darts. Successive iterations identify and fill in the empty regions to obtain maximal distributions. Our approach maps well to the parallel and optimized graphics functions on the GPU and can be easily extended to perform importance sampling. Our implementation can generate Poisson-disk samples at the rate of nearly 7 million samples per second on a GeForce GTX 580 and is significantly faster than the state-of-the-art maximal Poisson-disk sampling techniques.