summaryrefslogtreecommitdiff
path: root/numpy/random/bit_generator.pyx
diff options
context:
space:
mode:
authorCharles Harris <charlesr.harris@gmail.com>2020-06-10 12:07:52 -0600
committerGitHub <noreply@github.com>2020-06-10 12:07:52 -0600
commit073316d25d24b7cb4ffc09fc705448b0e17dc2dc (patch)
tree5204939b8990a34ecb8cd41bfae0340509f1ead7 /numpy/random/bit_generator.pyx
parentc0c7c42014edac6135cbadc89577c4b662fb5c19 (diff)
parente1db72c2c99d23982551def864b24d277b297aa6 (diff)
downloadnumpy-073316d25d24b7cb4ffc09fc705448b0e17dc2dc.tar.gz
Merge pull request #16551 from numpy/fix/seed-sequence-zeros
BUG: Ensure SeedSequence 0-padding does not collide with spawn keys
Diffstat (limited to 'numpy/random/bit_generator.pyx')
-rw-r--r--numpy/random/bit_generator.pyx11
1 files changed, 10 insertions, 1 deletions
diff --git a/numpy/random/bit_generator.pyx b/numpy/random/bit_generator.pyx
index f145ec13d..3c52a9933 100644
--- a/numpy/random/bit_generator.pyx
+++ b/numpy/random/bit_generator.pyx
@@ -382,13 +382,22 @@ cdef class SeedSequence():
-------
entropy_array : 1D uint32 array
"""
- # Convert run-entropy, program-entropy, and the spawn key into uint32
+ # Convert run-entropy and the spawn key into uint32
# arrays and concatenate them.
# We MUST have at least some run-entropy. The others are optional.
assert self.entropy is not None
run_entropy = _coerce_to_uint32_array(self.entropy)
spawn_entropy = _coerce_to_uint32_array(self.spawn_key)
+ if len(spawn_entropy) > 0 and len(run_entropy) < self.pool_size:
+ # Explicitly fill out the entropy with 0s to the pool size to avoid
+ # conflict with spawn keys. We changed this in 1.19.0 to fix
+ # gh-16539. In order to preserve stream-compatibility with
+ # unspawned SeedSequences with small entropy inputs, we only do
+ # this when a spawn_key is specified.
+ diff = self.pool_size - len(run_entropy)
+ run_entropy = np.concatenate(
+ [run_entropy, np.zeros(diff, dtype=np.uint32)])
entropy_array = np.concatenate([run_entropy, spawn_entropy])
return entropy_array