All Downloads are FREE. Search and download functionalities are using the official Maven repository.

spire.random.rng.Lcg32.scala Maven / Gradle / Ivy

package spire.random
package rng

import spire.util.Pack

// Linear congruent RNG with 32-bits of state.
// Numbers as in Numerical Recipes in C, 2nd ed.
// Contributed by Rex Kerr.
class Lcg32(seed0: Int) extends IntBasedGenerator {
  private var seed: Int = seed0

  def copyInit: Lcg32 = new Lcg32(seed)

  def getSeedBytes(): Array[Byte] = Pack.intToBytes(seed)

  def setSeedBytes(bytes: Array[Byte]): Unit = seed = Pack.intFromBytes(bytes)

  def nextInt(): Int = {
    seed = 1664525 * seed + 1013904223
    seed
  }
}

object Lcg32 extends GeneratorCompanion[Lcg32, Int] {
  def randomSeed(): Int = System.nanoTime.toInt

  def fromBytes(bytes: Array[Byte]): Lcg32 = new Lcg32(Pack.intFromBytes(bytes))
  def fromSeed(seed: Int): Lcg32 = new Lcg32(seed)
  def fromTime(time: Long = System.nanoTime): Lcg32 = new Lcg32(time.toInt)

  def step(n: Int): Int = 1664525 * n + 1013904223
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy