Class XoShiRo128PlusPlus
- All Implemented Interfaces:
RandomIntSource, JumpableUniformRandomProvider, LongJumpableUniformRandomProvider, RestorableUniformRandomProvider, UniformRandomProvider
float values try the
XoShiRo128Plus generator.
This is a member of the Xor-Shift-Rotate family of generators. Memory footprint is 128 bits.
- Since:
- 1.3
- See Also:
-
Field Summary
Fields -
Constructor Summary
ConstructorsModifierConstructorDescriptionXoShiRo128PlusPlus(int[] seed) Creates a new instance.XoShiRo128PlusPlus(int seed0, int seed1, int seed2, int seed3) Creates a new instance using a 4 element seed.protectedXoShiRo128PlusPlus(XoShiRo128PlusPlus source) Creates a copy instance. -
Method Summary
Modifier and TypeMethodDescriptionprotected XoShiRo128PlusPluscopy()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.intnext()Return the next random value.protected intUse the current state to compute the next output from the generator.protected voidsetStateInternal(byte[] s) Resets the RNG to the givenstate.Methods inherited from class IntProvider
nextBoolean, nextBytes, nextBytes, nextDouble, 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
-
state0
protected int state0State 0 of the generator. -
state1
protected int state1State 1 of the generator. -
state2
protected int state2State 2 of the generator. -
state3
protected int state3State 3 of the generator.
-
-
Constructor Details
-
XoShiRo128PlusPlus
Creates a new instance.- Parameters:
seed- Initial seed. If the length is larger than 4, only the first 4 elements will be used; if smaller, the remaining elements will be automatically set. A seed containing all zeros will create a non-functional generator.
-
XoShiRo128PlusPlus
Creates a new instance using a 4 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.
-
XoShiRo128PlusPlus
Creates a copy instance.- Parameters:
source- Source to copy.
-
-
Method Details
-
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 fromRandomIntSource.next()before the current state is updated.- Returns:
- the next output
-
copy
-
getStateInternal
protected byte[] getStateInternal()Creates a snapshot of the RNG state.- Overrides:
getStateInternalin classIntProvider- Returns:
- the internal state.
-
setStateInternal
protected void setStateInternal(byte[] s) Resets the RNG to the givenstate.- Overrides:
setStateInternalin classIntProvider- Parameters:
s- State (previously obtained by a call toBaseProvider.getStateInternal()).- See Also:
-
next
public int next()Return the next random value.- Specified by:
nextin interfaceRandomIntSource- Returns:
- the next random value.
-
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 264 calls to
nextInt(). It can provide up to 264 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 296 calls to
nextLong(). It can provide up to 232 non-overlapping subsequences of length 296; each subsequence can provide up to 232 non-overlapping subsequences of length 264 using theJumpableUniformRandomProvider.jump()method.- Specified by:
longJumpin interfaceLongJumpableUniformRandomProvider- Returns:
- A copy of the current state.
-