As vision algorithms mature with increasing inspiration from the learning community, statistically independent pseudo random number generation (PRNG) becomes increasingly important. At the same time, execution time demands have seen algorithms being implemented on evolving parallel hardware such as GPUs. The Mersenne Twister (MT) has proven to be the current state of the art for generating high quality random numbers, and the Nvidia provided software for parallel MT is in widespread use. While execution time is important, development time is also critical. As processor cardinality changes, a foundation for generating simulations that will vary only in execution time and not in the actual result is useful; otherwise the development time will be impacted. In this paper, we present an implementation of the Lagged Fibonacci Generator (LFG) considered to be of quality equal to MT on the GPU. Unlike MT, LFG has this important processor-cardinality agnostic capability -- that is -- as the number of processing resources changes, the overall sequence of random numbers remains the same. This feature not withstanding, our basic implementation is roughly as fast as the parallel MT; an in-memory version is actually 25% faster in execution time. Both parallel MT as well as parallel LFG show enormous speed up over their sequential counterparts. Finally, a prototype particle filter tracking application shows that our method works not just in parallel computing theory, but also in practice for vision applications, providing a decrease of 60% in execution time.
[1]
Srinivas Aluru,et al.
Lagged Fibonacci Random Number Generators for Distributed Memory Parallel Computers
,
1997,
J. Parallel Distributed Comput..
[2]
Takuji Nishimura,et al.
Mersenne twister: a 623-dimensionally equidistributed uniform pseudo-random number generator
,
1998,
TOMC.
[3]
Jerome Spanier,et al.
Dynamic creation of pseudorandom number generators
,
2000
.
[4]
David Thomas,et al.
The Art in Computer Programming
,
2001
.
[5]
Neil J. Gordon,et al.
A tutorial on particle filters for online nonlinear/non-Gaussian Bayesian tracking
,
2002,
IEEE Trans. Signal Process..
[6]
Matthew Papakipos,et al.
Pseudorandom number generation on the GPU
,
2006,
GH '06.
[7]
Li-Yi Wei,et al.
Parallel white noise generation on a GPU via cryptographic hash
,
2008,
I3D '08.