[Numpy-discussion] overhauling numpy.random and randomgen

Matti Picus matti.picus at gmail.com
Thu Apr 18 10:18:42 EDT 2019


Thanks to the work of Kevin Sheppard, Robert Kern and others, the branch 
to merge randomgen https://github.com/bashtage/randomgen into numpy is 
ready for final review.

The branch is here https://github.com/numpy/numpy/pull/13163. It is 
fully backward compatible: numpy.random.mtrand, 
numpy.random.RandomState, and the various stateful distributions from 
RandomState available as numpy.random.* produce the same streams as the 
current versions. The branch is intended to implement NEP 19 
https://www.numpy.org/neps/nep-0019-rng-policy.html


The biggest change is that now there are a variety of random number 
generators available 
https://6722-908607-gh.circle-artifacts.com/0/home/circleci/repo/doc/build/html/reference/random/brng/index.html, 
and a class numpy.random.RandomGenerator that can produce all the 
distributions from RandomState. A RandomGenerator instance is provided 
for convenience as numpy.random.gen


Additional enhancements 
https://6722-908607-gh.circle-artifacts.com/0/home/circleci/repo/doc/build/html/reference/random/new-or-different.html 
allow convenient use of the new constructs in CFFI, Numba, Ctypes, and 
Cython.


There are a few things to address before merging:

- Review the new constructs and other APIS

- Decide which BRNGs to include in the first release

- Check that your packages still work with the new implementations. You 
can do this by creating a new virtualenv and installing numpy via pip 
install git+https://github.com/mattip/numpy.git@randomgen 
<https://github.com/user/repo.git@branch>


We will try to have a final video call about the branch during the 
upcoming meeting May 10-11, more details will follow once we schedule 
the call. The goal is to merge it for the upcoming 1.17 release.


The expectation is that this first merge will be followed by 
implementation and documentation tweaks and improvements, but we hope to 
get the major pieces in place as much as possible now.


Matti


Notes:


Sorry for the long urls, they link to the generated documentation from 
CI. They may not be available a few weeks from now.

There is a tracking issue for further work related to the PR 
numpy.random https://github.com/numpy/numpy/issues/13164



More information about the NumPy-Discussion mailing list