Class DiscreteUniformSampler.SmallRangeDiscreteUniformSampler
java.lang.Object
org.apache.commons.rng.sampling.distribution.DiscreteUniformSampler.AbstractDiscreteUniformSampler
org.apache.commons.rng.sampling.distribution.DiscreteUniformSampler.SmallRangeDiscreteUniformSampler
- All Implemented Interfaces:
DiscreteSampler, SharedStateDiscreteSampler, SharedStateSampler<SharedStateDiscreteSampler>
- Enclosing class:
DiscreteUniformSampler
private static final class DiscreteUniformSampler.SmallRangeDiscreteUniformSampler
extends DiscreteUniformSampler.AbstractDiscreteUniformSampler
Discrete uniform distribution sampler when the range is small
enough to fit in a positive integer.
This sampler assumes the lower bound of the range is 0.
Implements the algorithm of Lemire (2019).
- Since:
- 1.0
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final longMaximum range of the sample (exclusive).private final longThe level below which samples are rejected based on the fraction remainder.Fields inherited from class DiscreteUniformSampler.AbstractDiscreteUniformSampler
rng -
Constructor Summary
ConstructorsConstructorDescriptionSmallRangeDiscreteUniformSampler(UniformRandomProvider rng, int range) SmallRangeDiscreteUniformSampler(UniformRandomProvider rng, DiscreteUniformSampler.SmallRangeDiscreteUniformSampler source) -
Method Summary
Modifier and TypeMethodDescriptionintsample()Creates anintsample.Create a new instance of the sampler with the same underlying state using the given uniform random provider as the source of randomness.Methods inherited from class DiscreteUniformSampler.AbstractDiscreteUniformSampler
toStringMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface DiscreteSampler
samples, samples
-
Field Details
-
n
private final long nMaximum range of the sample (exclusive). -
threshold
private final long thresholdThe level below which samples are rejected based on the fraction remainder.Any remainder below this denotes that there are still floor(2^32 / n) more observations of this sample from the interval [0, 2^32), where n is the range.
-
-
Constructor Details
-
SmallRangeDiscreteUniformSampler
SmallRangeDiscreteUniformSampler(UniformRandomProvider rng, int range) - Parameters:
rng- Generator of uniformly distributed random numbers.range- Maximum range of the sample (exclusive).
-
SmallRangeDiscreteUniformSampler
SmallRangeDiscreteUniformSampler(UniformRandomProvider rng, DiscreteUniformSampler.SmallRangeDiscreteUniformSampler source) - Parameters:
rng- Generator of uniformly distributed random numbers.source- Source to copy.
-
-
Method Details
-
sample
public int sample()Description copied from interface:DiscreteSamplerCreates anintsample.- Returns:
- a sample.
-
withUniformRandomProvider
Description copied from interface:SharedStateSamplerCreate a new instance of the sampler with the same underlying state using the given uniform random provider as the source of randomness.- Parameters:
rng- Generator of uniformly distributed random numbers.- Returns:
- the sampler
-