Class AbstractXoRoShiRo1024
- All Implemented Interfaces:
RandomLongSource
,JumpableUniformRandomProvider
,LongJumpableUniformRandomProvider
,RestorableUniformRandomProvider
,UniformRandomProvider
- Direct Known Subclasses:
XoRoShiRo1024PlusPlus
,XoRoShiRo1024Star
,XoRoShiRo1024StarStar
- Since:
- 1.3
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate int
Index in "state" array.private static final long[]
The coefficients for the jump function.private static final long[]
The coefficients for the long jump function.private static final int
Size of the state vector.private final long[]
State. -
Constructor Summary
ConstructorsModifierConstructorDescription(package private)
AbstractXoRoShiRo1024
(long[] seed) Creates a new instance.protected
Creates a copy instance. -
Method Summary
Modifier and TypeMethodDescriptionprotected abstract AbstractXoRoShiRo1024
copy()
Create a copy.protected byte[]
Creates a snapshot of the RNG state.jump()
Creates a copy of the UniformRandomProvider and then advances the state of the current instance.longJump()
Creates a copy of the JumpableUniformRandomProvider and then advances the state of the current instance.long
next()
Return the next random value.private void
performJump
(long[] jumpCoefficients) Perform the jump to advance the generator state.private void
setSeedInternal
(long[] seed) Seeds the RNG.protected void
setStateInternal
(byte[] s) Resets the RNG to the givenstate
.protected abstract long
transform
(long s0, long s15) Transform the two consecutive 64-bit states of the generator to a 64-bit output.Methods inherited from class org.apache.commons.rng.core.source64.LongProvider
nextBoolean, nextInt, nextLong, resetCachedState
Methods inherited from class org.apache.commons.rng.core.BaseProvider
checkIndex, checkStateSize, composeStateInternal, extendSeed, extendSeed, fillState, fillState, restoreState, saveState, splitStateInternal, toString
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.apache.commons.rng.JumpableUniformRandomProvider
jumps, jumps
Methods inherited from interface org.apache.commons.rng.LongJumpableUniformRandomProvider
longJumps, longJumps
Methods inherited from interface org.apache.commons.rng.UniformRandomProvider
doubles, doubles, doubles, doubles, ints, ints, ints, ints, longs, longs, longs, longs, nextBoolean, nextBytes, nextBytes, nextDouble, nextDouble, nextDouble, nextFloat, nextFloat, nextFloat, nextInt, nextInt, nextInt, nextLong, nextLong, nextLong
-
Field Details
-
SEED_SIZE
private static final int SEED_SIZESize of the state vector.- See Also:
-
JUMP_COEFFICIENTS
private static final long[] JUMP_COEFFICIENTSThe coefficients for the jump function. -
LONG_JUMP_COEFFICIENTS
private static final long[] LONG_JUMP_COEFFICIENTSThe coefficients for the long jump function. -
state
private final long[] stateState. -
index
private int indexIndex in "state" array.
-
-
Constructor Details
-
AbstractXoRoShiRo1024
AbstractXoRoShiRo1024(long[] seed) Creates a new instance.- Parameters:
seed
- Initial seed. If the length is larger than 16, only the first 16 elements will be used; if smaller, the remaining elements will be automatically set. A seed containing all zeros will create a non-functional generator.
-
AbstractXoRoShiRo1024
Creates a copy instance.- Parameters:
source
- Source to copy.
-
-
Method Details
-
getStateInternal
protected byte[] getStateInternal()Creates a snapshot of the RNG state.- Overrides:
getStateInternal
in classLongProvider
- Returns:
- the internal state.
-
setStateInternal
protected void setStateInternal(byte[] s) Resets the RNG to the givenstate
.- Overrides:
setStateInternal
in classLongProvider
- Parameters:
s
- State (previously obtained by a call toBaseProvider.getStateInternal()
).- See Also:
-
setSeedInternal
private void setSeedInternal(long[] seed) Seeds the RNG.- Parameters:
seed
- Seed.
-
next
public long next()Return the next random value.- Specified by:
next
in interfaceRandomLongSource
- Returns:
- the next random value.
-
transform
protected abstract long transform(long s0, long s15) Transform the two consecutive 64-bit states of the generator to a 64-bit output. The transformation function shall vary with respect to different generators.- Parameters:
s0
- The current state.s15
- The previous state.- Returns:
- the output
-
jump
Creates a copy of the UniformRandomProvider and then advances the state of the current instance. The copy is returned.The current state will be advanced in a single operation by the equivalent of a number of sequential calls to a method that updates the state of the provider. The size of the jump is implementation dependent.
Repeat invocations of this method will create a series of generators that are uniformly spaced at intervals of the output sequence. Each generator provides non-overlapping output for the length of the jump for use in parallel computations.
The jump size is the equivalent of 2512 calls to
nextLong()
. It can provide up to 2512 non-overlapping subsequences.- Specified by:
jump
in interfaceJumpableUniformRandomProvider
- Returns:
- A copy of the current state.
-
longJump
Creates a copy of the JumpableUniformRandomProvider and then advances the state of the current instance. The copy is returned.The current state will be advanced in a single operation by the equivalent of a number of sequential calls to a method that updates the state of the provider. The size of the long jump is implementation dependent.
Repeat invocations of this method will create a series of generators that are uniformly spaced at intervals of the output sequence. Each generator provides non-overlapping output for the length of the long jump for use in parallel computations.
The returned copy may be jumped
m / n
times before overlap with the current instance wherem
is the long jump length andn
is the jump length of theJumpableUniformRandomProvider.jump()
method.The jump size is the equivalent of 2768 calls to
nextLong()
. It can provide up to 2256 non-overlapping subsequences of length 2768; each subsequence can provide up to 2256 non-overlapping subsequences of length 2512 using thejump()
method.- Specified by:
longJump
in interfaceLongJumpableUniformRandomProvider
- Returns:
- A copy of the current state.
-
copy
Create a copy.- Returns:
- the copy
-
performJump
private void performJump(long[] jumpCoefficients) Perform the jump to advance the generator state. Resets the cached state of the generator.- Parameters:
jumpCoefficients
- the jump coefficients
-