Class XoShiRo512Plus
- java.lang.Object
-
- org.apache.commons.rng.core.BaseProvider
-
- org.apache.commons.rng.core.source64.LongProvider
-
- org.apache.commons.rng.core.source64.XoShiRo512Plus
-
- All Implemented Interfaces:
RandomLongSource
,JumpableUniformRandomProvider
,LongJumpableUniformRandomProvider
,RestorableUniformRandomProvider
,UniformRandomProvider
public class XoShiRo512Plus extends LongProvider
A fast 64-bit generator suitable fordouble
generation. This is slightly faster than the all-purpose generatorXoShiRo512StarStar
.This is a member of the Xor-Shift-Rotate family of generators. Memory footprint is 512 bits and the period is 2512-1. Speed is expected to be slower than
XoShiRo256Plus
.- Since:
- 1.3
- See Also:
- Original source code, xorshiro / xoroshiro generators
-
-
Field Summary
Fields Modifier and Type Field Description protected long
state0
State 0 of the generator.protected long
state1
State 1 of the generator.protected long
state2
State 2 of the generator.protected long
state3
State 3 of the generator.protected long
state4
State 4 of the generator.protected long
state5
State 5 of the generator.protected long
state6
State 6 of the generator.protected long
state7
State 7 of the generator.
-
Constructor Summary
Constructors Modifier Constructor Description XoShiRo512Plus(long[] seed)
Creates a new instance.XoShiRo512Plus(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.protected
XoShiRo512Plus(XoShiRo512Plus source)
Creates a copy instance.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected XoShiRo512Plus
copy()
Create a copy.protected byte[]
getStateInternal()
Creates a snapshot of the RNG state.UniformRandomProvider
jump()
JumpableUniformRandomProvider
longJump()
long
next()
Return the next random value.protected long
nextOutput()
Use the current state to compute the next output from the generator.protected void
setStateInternal(byte[] s)
Resets the RNG to the givenstate
.-
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 Detail
-
state0
protected long state0
State 0 of the generator.
-
state1
protected long state1
State 1 of the generator.
-
state2
protected long state2
State 2 of the generator.
-
state3
protected long state3
State 3 of the generator.
-
state4
protected long state4
State 4 of the generator.
-
state5
protected long state5
State 5 of the generator.
-
state6
protected long state6
State 6 of the generator.
-
state7
protected long state7
State 7 of the generator.
-
-
Constructor Detail
-
XoShiRo512Plus
public XoShiRo512Plus(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.
-
XoShiRo512Plus
public XoShiRo512Plus(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.
-
XoShiRo512Plus
protected XoShiRo512Plus(XoShiRo512Plus source)
Creates a copy instance.- Parameters:
source
- Source to copy.
-
-
Method Detail
-
nextOutput
protected 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 fromRandomLongSource.next()
before the current state is updated.- Returns:
- the next output
-
copy
protected XoShiRo512Plus copy()
Create a copy.- Returns:
- the copy
-
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:
BaseProvider.checkStateSize(byte[],int)
-
next
public long next()
Return the next random value.- Specified by:
next
in interfaceRandomLongSource
- Returns:
- the next random value.
-
jump
public UniformRandomProvider jump()
The jump size is the equivalent of 2256 calls to
nextLong()
. It can provide up to 2256 non-overlapping subsequences.- Specified by:
jump
in interfaceJumpableUniformRandomProvider
-
longJump
public JumpableUniformRandomProvider longJump()
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 theJumpableUniformRandomProvider.jump()
method.- Specified by:
longJump
in interfaceLongJumpableUniformRandomProvider
-
-