Class XoRoShiRo128PlusPlus

  • 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 XoRoShiRo128PlusPlus
    extends LongProvider
    A fast all-purpose 64-bit generator.

    This is a member of the Xor-Shift-Rotate family of generators. Memory footprint is 128 bits and the period is 2128-1. Speed is expected to be similar to XoShiRo256StarStar.

    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.
    • Constructor Detail

      • XoRoShiRo128PlusPlus

        public XoRoShiRo128PlusPlus​(long[] seed)
        Creates a new instance.
        Parameters:
        seed - Initial seed. If the length is larger than 2, only the first 2 elements will be used; if smaller, the remaining elements will be automatically set. A seed containing all zeros will create a non-functional generator.
      • XoRoShiRo128PlusPlus

        public XoRoShiRo128PlusPlus​(long seed0,
                                    long seed1)
        Creates a new instance using a 2 element seed. A seed containing all zeros will create a non-functional generator.
        Parameters:
        seed0 - Initial seed element 0.
        seed1 - Initial seed element 1.
    • Method Detail

      • next

        public long next()
        Return the next random value.
        Specified by:
        next in interface RandomLongSource
        Returns:
        the next random value.
      • 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
      • jump

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

        The jump size is the equivalent of 264 calls to nextLong(). 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
      • getStateInternal

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