/* * 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()) } }