Class XoShiRo256PlusPlus

  • All Implemented Interfaces:
    RandomLongSource, org.apache.commons.rng.JumpableUniformRandomProvider, org.apache.commons.rng.LongJumpableUniformRandomProvider, org.apache.commons.rng.RestorableUniformRandomProvider, org.apache.commons.rng.UniformRandomProvider

    public class XoShiRo256PlusPlus
    extends LongProvider
    A fast all-purpose 64-bit generator.

    This is a member of the Xor-Shift-Rotate family of generators. Memory footprint is 256 bits and the period is 2256-1.

    Since:
    1.3
    See Also:
    Original source code, xorshiro / xoroshiro generators
    • 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.
    • Constructor Detail

      • XoShiRo256PlusPlus

        public XoShiRo256PlusPlus​(long[] seed)
        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.
      • XoShiRo256PlusPlus

        public XoShiRo256PlusPlus​(long seed0,
                                  long seed1,
                                  long seed2,
                                  long seed3)
        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.
    • 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 from RandomLongSource.next() before the current state is updated.
        Returns:
        the next output
      • getStateInternal

        protected byte[] getStateInternal()
        Creates a snapshot of the RNG state.
        Overrides:
        getStateInternal in class LongProvider
        Returns:
        the internal state.
      • next

        public long next()
        Return the next random value.
        Specified by:
        next in interface RandomLongSource
        Returns:
        the next random value.
      • jump

        public org.apache.commons.rng.UniformRandomProvider jump()

        The jump size is the equivalent of 2128 calls to nextLong(). It can provide up to 2128 non-overlapping subsequences.

        Specified by:
        jump in interface org.apache.commons.rng.JumpableUniformRandomProvider
      • longJump

        public org.apache.commons.rng.JumpableUniformRandomProvider longJump()

        The jump size is the equivalent of 2192 calls to nextLong(). It can provide up to 264 non-overlapping subsequences of length 2192; each subsequence can provide up to 264 non-overlapping subsequences of length 2128 using the JumpableUniformRandomProvider.jump() method.

        Specified by:
        longJump in interface org.apache.commons.rng.LongJumpableUniformRandomProvider