65244b4bea
Change the copyright from "JetBrains s.r.o." to "JetBrains s.r.o. and Kotlin Project contributors" Update only 2 lines copyright.
27 lines
869 B
Kotlin
27 lines
869 B
Kotlin
/*
|
|
* 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())
|
|
}
|
|
} |