Class XoShiRo128StarStar

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

    public class XoShiRo128StarStar
    extends IntProvider
    A fast all-purpose 32-bit generator. For faster generation of 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:
    Original source code, xorshiro / xoroshiro generators
    • Field Detail

      • state0

        protected int state0
        State 0 of the generator.
      • state1

        protected int state1
        State 1 of the generator.
      • state2

        protected int state2
        State 2 of the generator.
      • state3

        protected int state3
        State 3 of the generator.
    • Constructor Detail

      • XoShiRo128StarStar

        public XoShiRo128StarStar​(int[] 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.
      • XoShiRo128StarStar

        public XoShiRo128StarStar​(int seed0,
                                  int seed1,
                                  int seed2,
                                  int 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 int 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 RandomIntSource.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 IntProvider
        Returns:
        the internal state.
      • next

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

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

        The jump size is the equivalent of 264 calls to nextInt(). It can provide up to 264 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 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 the JumpableUniformRandomProvider.jump() method.

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