Package it.unimi.dsi.util
Class XorShift64StarRandomGenerator
java.lang.Object
org.apache.commons.math3.random.AbstractRandomGenerator
it.unimi.dsi.util.XorShift64StarRandomGenerator
- All Implemented Interfaces:
RandomGenerator
Deprecated.
A fast, good-quality pseudorandom number generator
that combines George Marsaglia's Xorshift
generators (described in “Xorshift RNGs”,
Journal of Statistical Software, 8:1−6, 2003) with a multiplication.
-
Constructor Summary
ConstructorDescriptionDeprecated.Creates a new generator seeded usingUtil.randomSeed()
.XorShift64StarRandomGenerator
(long seed) Deprecated.Creates a new generator using a given seed. -
Method Summary
Modifier and TypeMethodDescriptionboolean
Deprecated.void
nextBytes
(byte[] bytes) Deprecated.double
Deprecated.float
Deprecated.int
nextInt()
Deprecated.int
nextInt
(int n) Deprecated.Returns a pseudorandom, approximately uniformly distributedint
value between 0 (inclusive) and the specified value (exclusive), drawn from this random number generator's sequence.long
nextLong()
Deprecated.long
nextLong
(long n) Deprecated.Returns a pseudorandom uniformly distributedlong
value between 0 (inclusive) and the specified value (exclusive), drawn from this random number generator's sequence.void
setSeed
(long seed) Deprecated.Sets the seed of this generator.void
setState
(long state) Deprecated.Sets the state of this generator.Methods inherited from class org.apache.commons.math3.random.AbstractRandomGenerator
clear, nextGaussian, setSeed, setSeed
-
Constructor Details
-
XorShift64StarRandomGenerator
public XorShift64StarRandomGenerator()Deprecated.Creates a new generator seeded usingUtil.randomSeed()
. -
XorShift64StarRandomGenerator
public XorShift64StarRandomGenerator(long seed) Deprecated.Creates a new generator using a given seed.- Parameters:
seed
- a nonzero seed for the generator (if zero, the generator will be seeded withLong.MIN_VALUE
).
-
-
Method Details
-
nextLong
public long nextLong()Deprecated.- Specified by:
nextLong
in interfaceRandomGenerator
- Overrides:
nextLong
in classAbstractRandomGenerator
-
nextInt
public int nextInt()Deprecated.- Specified by:
nextInt
in interfaceRandomGenerator
- Overrides:
nextInt
in classAbstractRandomGenerator
-
nextInt
public int nextInt(int n) Deprecated.Returns a pseudorandom, approximately uniformly distributedint
value between 0 (inclusive) and the specified value (exclusive), drawn from this random number generator's sequence.The hedge “approximately” is due to the fact that to be always faster than
ThreadLocalRandom
we return the upper 63 bits ofnextLong()
modulon
instead of usingRandom
's fancy algorithm (whichnextLong(long)
uses though). This choice introduces a bias: the numbers from 0 to 263 modn
are slightly more likely than the other ones. In the worst case, “more likely” means 1.00000000023 times more likely, which is in practice undetectable. If for some reason you need truly uniform generation, just usenextLong(long)
.- Specified by:
nextInt
in interfaceRandomGenerator
- Overrides:
nextInt
in classAbstractRandomGenerator
- Parameters:
n
- the positive bound on the random number to be returned.- Returns:
- the next pseudorandom
int
value between0
(inclusive) andn
(exclusive).
-
nextLong
public long nextLong(long n) Deprecated.Returns a pseudorandom uniformly distributedlong
value between 0 (inclusive) and the specified value (exclusive), drawn from this random number generator's sequence. The algorithm used to generate the value guarantees that the result is uniform, provided that the sequence of 64-bit values produced by this generator is.- Parameters:
n
- the positive bound on the random number to be returned.- Returns:
- the next pseudorandom
long
value between0
(inclusive) andn
(exclusive).
-
nextDouble
public double nextDouble()Deprecated.- Specified by:
nextDouble
in interfaceRandomGenerator
- Specified by:
nextDouble
in classAbstractRandomGenerator
-
nextFloat
public float nextFloat()Deprecated.- Specified by:
nextFloat
in interfaceRandomGenerator
- Overrides:
nextFloat
in classAbstractRandomGenerator
-
nextBoolean
public boolean nextBoolean()Deprecated.- Specified by:
nextBoolean
in interfaceRandomGenerator
- Overrides:
nextBoolean
in classAbstractRandomGenerator
-
nextBytes
public void nextBytes(byte[] bytes) Deprecated.- Specified by:
nextBytes
in interfaceRandomGenerator
- Overrides:
nextBytes
in classAbstractRandomGenerator
-
setSeed
public void setSeed(long seed) Deprecated.Sets the seed of this generator.The seed will be passed through
HashCommon.murmurHash3(long)
. In this way, if the user passes a small value we will avoid the short irregular transient associated with states with a very small number of bits set.- Specified by:
setSeed
in interfaceRandomGenerator
- Specified by:
setSeed
in classAbstractRandomGenerator
- Parameters:
seed
- a nonzero seed for this generator (if zero, the generator will be seeded withLong.MIN_VALUE
).
-
setState
public void setState(long state) Deprecated.Sets the state of this generator.- Parameters:
state
- the new state for this generator (must be nonzero).
-
SplitMix64RandomGenerator
instead.