public abstract class BitsStreamGenerator extends Object implements RandomGenerator, Serializable
Constructor and Description |
---|
BitsStreamGenerator()
Creates a new random number generator.
|
Modifier and Type | Method and Description |
---|---|
void |
clear()
Clears the cache used by the default implementation of
nextGaussian . |
protected abstract int |
next(int bits)
Generate next pseudorandom number.
|
boolean |
nextBoolean()
Returns the next pseudorandom, uniformly distributed
boolean value from this random number
generator's
sequence. |
void |
nextBytes(byte[] bytes)
Generates random bytes and places them into a user-supplied
byte array.
|
double |
nextDouble()
Returns the next pseudorandom, uniformly distributed
double value between 0.0 and
1.0 from this random number generator's sequence. |
float |
nextFloat()
Returns the next pseudorandom, uniformly distributed
float value between 0.0 and
1.0 from this random
number generator's sequence. |
double |
nextGaussian()
Returns the next pseudorandom, Gaussian ("normally") distributed
double value with mean
0.0 and standard
deviation 1.0 from this random number generator's sequence. |
int |
nextInt()
Returns the next pseudorandom, uniformly distributed
int value from this random number generator's
sequence. |
int |
nextInt(int n)
Returns a pseudorandom, uniformly distributed int value
between 0 (inclusive) and the specified value (exclusive), drawn from
this random number generator's sequence.
|
long |
nextLong()
Returns the next pseudorandom, uniformly distributed
long value from this random number generator's
sequence. |
abstract void |
setSeed(int seed)
Sets the seed of the underlying random number generator using an
int seed. |
abstract void |
setSeed(int[] seed)
Sets the seed of the underlying random number generator using an
int array seed. |
abstract void |
setSeed(long seed)
Sets the seed of the underlying random number generator using a
long seed. |
public BitsStreamGenerator()
public abstract void setSeed(int seed)
int
seed.
Sequences of values generated starting with the same seeds should be identical.
setSeed
in interface RandomGenerator
seed
- the seed valuepublic abstract void setSeed(int[] seed)
int
array seed.
Sequences of values generated starting with the same seeds should be identical.
setSeed
in interface RandomGenerator
seed
- the seed valuepublic abstract void setSeed(long seed)
long
seed.
Sequences of values generated starting with the same seeds should be identical.
setSeed
in interface RandomGenerator
seed
- the seed valueprotected abstract int next(int bits)
This method is the core generation algorithm. It is used by all the public generation methods for the various
primitive types nextBoolean()
, nextBytes(byte[])
, nextDouble()
, nextFloat()
,
nextGaussian()
, nextInt()
, next(int)
and nextLong()
.
bits
- number of random bits to producepublic boolean nextBoolean()
boolean
value from this random number
generator's
sequence.nextBoolean
in interface RandomGenerator
boolean
value from this random number
generator's
sequencepublic void nextBytes(byte[] bytes)
nextBytes
in interface RandomGenerator
bytes
- the non-null byte array in which to put the
random bytespublic double nextDouble()
double
value between 0.0
and
1.0
from this random number generator's sequence.nextDouble
in interface RandomGenerator
double
value between 0.0
and
1.0
from this random number generator's sequencepublic float nextFloat()
float
value between 0.0
and
1.0
from this random
number generator's sequence.nextFloat
in interface RandomGenerator
float
value between 0.0
and
1.0
from this
random number generator's sequencepublic double nextGaussian()
double
value with mean
0.0
and standard
deviation 1.0
from this random number generator's sequence.nextGaussian
in interface RandomGenerator
double
value with mean
0.0
and
standard deviation 1.0
from this random number
generator's sequencepublic int nextInt()
int
value from this random number generator's
sequence.
All 232 possible int values
should be produced with (approximately) equal probability.nextInt
in interface RandomGenerator
int
value from this random number generator's
sequencepublic int nextInt(int n)
This default implementation is copied from Apache Harmony java.util.Random (r929253).
Implementation notes:
(int) ((n * (long) next(31)) >> 31)
.next(31) % n
with next(31)
values rejected
(i.e. regenerated) until a value that is larger than the remainder of Integer.MAX_VALUE / n
is generated.
Rejection of this initial segment is necessary to ensure a uniform distribution.nextInt
in interface RandomGenerator
n
- the bound on the random number to be returned. Must be
positive.public long nextLong()
long
value from this random number generator's
sequence. All
264 possible long values
should be produced with (approximately) equal probability.nextLong
in interface RandomGenerator
long
value from this random number generator's
sequencepublic void clear()
nextGaussian
.Copyright © 2019 CNES. All rights reserved.