blob: 5bef7ec5d3e52f3894d5e2fd70853530e9e87eeb [file] [log] [blame]
/*
* Copyright 2010-2018 JetBrains s.r.o. and Kotlin Programming Language contributors.
* Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.
*/
package test.random
import kotlin.math.pow
import kotlin.random.*
import kotlin.test.*
class XorWowRandomImplTest {
@Test
fun predefinedSequence() {
val seed = 1
val addend = (seed shl 10) xor (seed ushr 4)
@Suppress("INVISIBLE_REFERENCE", "INVISIBLE_MEMBER")
val random: Random = XorWowRandom(seed, 0, 0, 0, 0, addend)
// differs from reference 0.8178000247146859 because of different double mixing algorithm
assertEquals(0.817799582443095, random.nextDouble())
assertEquals(0.8407576507888734, random.nextBits(31) / (2.0.pow(31)))
assertEquals(533150816, random.nextInt())
}
}