Class AbstractXoShiRo512
- All Implemented Interfaces:
RandomLongSource, JumpableUniformRandomProvider, LongJumpableUniformRandomProvider, RestorableUniformRandomProvider, UniformRandomProvider
- Direct Known Subclasses:
XoShiRo512Plus, XoShiRo512PlusPlus, XoShiRo512StarStar
- Since:
- 1.3
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate static final long[]The coefficients for the jump function.private static final long[]The coefficients for the long jump function.private static final intSize of the state vector.protected longState 0 of the generator.protected longState 1 of the generator.protected longState 2 of the generator.protected longState 3 of the generator.protected longState 4 of the generator.protected longState 5 of the generator.protected longState 6 of the generator.protected longState 7 of the generator. -
Constructor Summary
ConstructorsModifierConstructorDescription(package private)AbstractXoShiRo512(long[] seed) Creates a new instance.(package private)AbstractXoShiRo512(long seed0, long seed1, long seed2, long seed3, long seed4, long seed5, long seed6, long seed7) Creates a new instance using an 8 element seed.protectedAbstractXoShiRo512(AbstractXoShiRo512 source) Creates a copy instance. -
Method Summary
Modifier and TypeMethodDescriptionprotected abstract AbstractXoShiRo512copy()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.longnext()Return the next random value.protected abstract longUse the current state to compute the next output from the generator.private voidperformJump(long[] jumpCoefficients) Perform the jump to advance the generator state.private voidsetState(long[] state) Copies the state from the array into the generator state.protected voidsetStateInternal(byte[] s) Resets the RNG to the givenstate.Methods inherited from class LongProvider
nextBoolean, nextInt, nextLong, resetCachedStateMethods inherited from class BaseProvider
checkIndex, checkStateSize, composeStateInternal, extendSeed, extendSeed, fillState, fillState, restoreState, saveState, splitStateInternal, toStringMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface JumpableUniformRandomProvider
jumps, jumpsMethods inherited from interface LongJumpableUniformRandomProvider
longJumps, longJumpsMethods inherited from interface 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. -
state0
protected long state0State 0 of the generator. -
state1
protected long state1State 1 of the generator. -
state2
protected long state2State 2 of the generator. -
state3
protected long state3State 3 of the generator. -
state4
protected long state4State 4 of the generator. -
state5
protected long state5State 5 of the generator. -
state6
protected long state6State 6 of the generator. -
state7
protected long state7State 7 of the generator.
-
-
Constructor Details
-
AbstractXoShiRo512
AbstractXoShiRo512(long[] seed) Creates a new instance.- Parameters:
seed- Initial seed. If the length is larger than 8, only the first 8 elements will be used; if smaller, the remaining elements will be automatically set. A seed containing all zeros will create a non-functional generator.
-
AbstractXoShiRo512
AbstractXoShiRo512(long seed0, long seed1, long seed2, long seed3, long seed4, long seed5, long seed6, long seed7) Creates a new instance using an 8 element seed. A seed containing all zeros will create a non-functional generator.- Parameters:
seed0- Initial seed element 0.seed1- Initial seed element 1.seed2- Initial seed element 2.seed3- Initial seed element 3.seed4- Initial seed element 4.seed5- Initial seed element 5.seed6- Initial seed element 6.seed7- Initial seed element 7.
-
AbstractXoShiRo512
Creates a copy instance.- Parameters:
source- Source to copy.
-
-
Method Details
-
setState
private void setState(long[] state) Copies the state from the array into the generator state.- Parameters:
state- the new state
-
getStateInternal
protected byte[] getStateInternal()Creates a snapshot of the RNG state.- Overrides:
getStateInternalin classLongProvider- Returns:
- the internal state.
-
setStateInternal
protected void setStateInternal(byte[] s) Resets the RNG to the givenstate.- Overrides:
setStateInternalin classLongProvider- Parameters:
s- State (previously obtained by a call toBaseProvider.getStateInternal()).- See Also:
-
next
public long next()Return the next random value.- Specified by:
nextin interfaceRandomLongSource- Returns:
- the next random value.
-
nextOutput
protected abstract long nextOutput()Use the current state to compute the next output from the generator. The output function shall vary with respect to different generators. This method is called fromnext()before the current state is updated.- Returns:
- the next 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 2256 calls to
nextLong(). It can provide up to 2256 non-overlapping subsequences.- Specified by:
jumpin 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 / ntimes before overlap with the current instance wheremis the long jump length andnis the jump length of theJumpableUniformRandomProvider.jump()method.The jump size is the equivalent of 2384 calls to
nextLong(). It can provide up to 2128 non-overlapping subsequences of length 2384; each subsequence can provide up to 2128 non-overlapping subsequences of length 2256 using thejump()method.- Specified by:
longJumpin interfaceLongJumpableUniformRandomProvider- Returns:
- A copy of the current state.
-
copy
-
performJump
private void performJump(long[] jumpCoefficients) Perform the jump to advance the generator state. Resets the cached state of the generator.- Parameters:
jumpCoefficients- Jump coefficients.
-