rand: fix warnings
parent
076089d3c5
commit
13c68eb81e
|
@ -1,44 +0,0 @@
|
||||||
// Copyright (c) 2019-2020 Alexander Medvednikov. All rights reserved.
|
|
||||||
// Use of this source code is governed by an MIT license
|
|
||||||
// that can be found in the LICENSE file.
|
|
||||||
import crypto.rand
|
|
||||||
|
|
||||||
fn get_random_bytes(no_bytes int) []byte {
|
|
||||||
r := rand.read(no_bytes) or {
|
|
||||||
assert false
|
|
||||||
return []
|
|
||||||
}
|
|
||||||
assert r.len == no_bytes
|
|
||||||
return r
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_crypto_rand_read() {
|
|
||||||
no_bytes := 100
|
|
||||||
r1 := get_random_bytes(no_bytes)
|
|
||||||
r2 := get_random_bytes(no_bytes)
|
|
||||||
mut equals := 0
|
|
||||||
for i in 0 .. r1.len {
|
|
||||||
if r1[i] == r2[i] {
|
|
||||||
equals++
|
|
||||||
}
|
|
||||||
}
|
|
||||||
assert (100.0 * f32(equals) / f32(no_bytes)) < 20.0
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_crypto_rand_int_u64() {
|
|
||||||
max := u64(160)
|
|
||||||
mut unique := []u64{}
|
|
||||||
for _ in 0 .. 80 {
|
|
||||||
r := rand.int_u64(max) or {
|
|
||||||
assert false
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if r >= max {
|
|
||||||
assert false
|
|
||||||
}
|
|
||||||
if r !in unique {
|
|
||||||
unique << r
|
|
||||||
}
|
|
||||||
}
|
|
||||||
assert unique.len >= 10
|
|
||||||
}
|
|
|
@ -234,7 +234,7 @@ pub fn (mut rng MT19937RNG) intn(max int) int {
|
||||||
eprintln('max has to be positive.')
|
eprintln('max has to be positive.')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return int(rng.u32n(max))
|
return int(rng.u32n(u32(max)))
|
||||||
}
|
}
|
||||||
|
|
||||||
// rng.i64n(max) - return a 64bit positive i64 in [0, max)
|
// rng.i64n(max) - return a 64bit positive i64 in [0, max)
|
||||||
|
@ -244,7 +244,7 @@ pub fn (mut rng MT19937RNG) i64n(max i64) i64 {
|
||||||
eprintln('max has to be positive.')
|
eprintln('max has to be positive.')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return i64(rng.u64n(max))
|
return i64(rng.u64n(u64(max)))
|
||||||
}
|
}
|
||||||
|
|
||||||
// rng.int_in_range(min, max) - return a 32bit positive int in [0, max)
|
// rng.int_in_range(min, max) - return a 32bit positive int in [0, max)
|
||||||
|
|
|
@ -14,7 +14,7 @@ const (
|
||||||
)
|
)
|
||||||
|
|
||||||
fn mt19937_basic_test() {
|
fn mt19937_basic_test() {
|
||||||
rng := rand.MT19937RNG{}
|
mut rng := rand.MT19937RNG{}
|
||||||
rng.seed([u32(0xdeadbeef)])
|
rng.seed([u32(0xdeadbeef)])
|
||||||
target := [956529277, 3842322136, 3319553134, 1843186657, 2704993644, 595827513, 938518626,
|
target := [956529277, 3842322136, 3319553134, 1843186657, 2704993644, 595827513, 938518626,
|
||||||
1676224337, 3221315650, 1819026461]
|
1676224337, 3221315650, 1819026461]
|
||||||
|
@ -73,7 +73,7 @@ fn test_mt19937_variability() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_uniformity_u64(rng rand.MT19937RNG, range u64) {
|
fn check_uniformity_u64(mut rng rand.MT19937RNG, range u64) {
|
||||||
range_f64 := f64(range)
|
range_f64 := f64(range)
|
||||||
expected_mean := range_f64 / 2.0
|
expected_mean := range_f64 / 2.0
|
||||||
mut variance := 0.0
|
mut variance := 0.0
|
||||||
|
@ -94,12 +94,12 @@ fn test_mt19937_uniformity_u64() {
|
||||||
mut rng := rand.MT19937RNG{}
|
mut rng := rand.MT19937RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for range in ranges {
|
for range in ranges {
|
||||||
check_uniformity_u64(rng, range)
|
check_uniformity_u64(mut rng, u64(range))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_uniformity_f64(rng rand.MT19937RNG) {
|
fn check_uniformity_f64(mut rng rand.MT19937RNG) {
|
||||||
expected_mean := 0.5
|
expected_mean := 0.5
|
||||||
mut variance := 0.0
|
mut variance := 0.0
|
||||||
for _ in 0 .. sample_size {
|
for _ in 0 .. sample_size {
|
||||||
|
@ -118,7 +118,7 @@ fn test_mt19937_uniformity_f64() {
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
mut rng := rand.MT19937RNG{}
|
mut rng := rand.MT19937RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
check_uniformity_f64(rng)
|
check_uniformity_f64(mut rng)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -128,7 +128,7 @@ fn test_mt19937_u32n() {
|
||||||
mut rng := rand.MT19937RNG{}
|
mut rng := rand.MT19937RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u32n(max)
|
value := rng.u32n(u32(max))
|
||||||
assert value >= 0
|
assert value >= 0
|
||||||
assert value < max
|
assert value < max
|
||||||
}
|
}
|
||||||
|
@ -155,7 +155,7 @@ fn test_mt19937_u32_in_range() {
|
||||||
mut rng := rand.MT19937RNG{}
|
mut rng := rand.MT19937RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u32_in_range(min, max)
|
value := rng.u32_in_range(u32(min), u32(max))
|
||||||
assert value >= min
|
assert value >= min
|
||||||
assert value < max
|
assert value < max
|
||||||
}
|
}
|
||||||
|
@ -210,7 +210,7 @@ fn test_mt19937_int63() {
|
||||||
fn test_mt19937_intn() {
|
fn test_mt19937_intn() {
|
||||||
max := 2525642
|
max := 2525642
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.MT19937RNG{}
|
mut rng := rand.MT19937RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.intn(max)
|
value := rng.intn(max)
|
||||||
|
@ -223,7 +223,7 @@ fn test_mt19937_intn() {
|
||||||
fn test_mt19937_i64n() {
|
fn test_mt19937_i64n() {
|
||||||
max := i64(3246727724653636)
|
max := i64(3246727724653636)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.MT19937RNG{}
|
mut rng := rand.MT19937RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.i64n(max)
|
value := rng.i64n(max)
|
||||||
|
@ -237,7 +237,7 @@ fn test_mt19937_int_in_range() {
|
||||||
min := -4252
|
min := -4252
|
||||||
max := 1034
|
max := 1034
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.MT19937RNG{}
|
mut rng := rand.MT19937RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.int_in_range(min, max)
|
value := rng.int_in_range(min, max)
|
||||||
|
@ -251,7 +251,7 @@ fn test_mt19937_i64_in_range() {
|
||||||
min := i64(-24095)
|
min := i64(-24095)
|
||||||
max := i64(324058)
|
max := i64(324058)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.MT19937RNG{}
|
mut rng := rand.MT19937RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.i64_in_range(min, max)
|
value := rng.i64_in_range(min, max)
|
||||||
|
|
|
@ -106,7 +106,7 @@ pub fn (mut rng MuslRNG) u32_in_range(min, max u64) u64 {
|
||||||
eprintln('max must be greater than min')
|
eprintln('max must be greater than min')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return min + rng.u32n(max - min)
|
return min + rng.u32n(u32(max - min))
|
||||||
}
|
}
|
||||||
|
|
||||||
// rn.u64_in_range(min, max) - return a pseudorandom 64 bit unsigned u64 in [min, max)
|
// rn.u64_in_range(min, max) - return a pseudorandom 64 bit unsigned u64 in [min, max)
|
||||||
|
@ -150,7 +150,7 @@ pub fn (mut rng MuslRNG) intn(max int) int {
|
||||||
eprintln('max has to be positive.')
|
eprintln('max has to be positive.')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return int(rng.u32n(max))
|
return int(rng.u32n(u32(max)))
|
||||||
}
|
}
|
||||||
|
|
||||||
// rng.i64n(max) - return a 64bit positive i64 in [0, max)
|
// rng.i64n(max) - return a 64bit positive i64 in [0, max)
|
||||||
|
@ -160,7 +160,7 @@ pub fn (mut rng MuslRNG) i64n(max i64) i64 {
|
||||||
eprintln('max has to be positive.')
|
eprintln('max has to be positive.')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return i64(rng.u64n(max))
|
return i64(rng.u64n(u64(max)))
|
||||||
}
|
}
|
||||||
|
|
||||||
// rng.int_in_range(min, max) - return a 32bit positive int in [0, max)
|
// rng.int_in_range(min, max) - return a 32bit positive int in [0, max)
|
||||||
|
|
|
@ -63,7 +63,7 @@ fn test_musl_variability() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_uniformity_u64(rng rand.MuslRNG, range u64) {
|
fn check_uniformity_u64(mut rng rand.MuslRNG, range u64) {
|
||||||
range_f64 := f64(range)
|
range_f64 := f64(range)
|
||||||
expected_mean := range_f64 / 2.0
|
expected_mean := range_f64 / 2.0
|
||||||
mut variance := 0.0
|
mut variance := 0.0
|
||||||
|
@ -84,12 +84,12 @@ fn test_musl_uniformity_u64() {
|
||||||
mut rng := rand.MuslRNG{}
|
mut rng := rand.MuslRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for range in ranges {
|
for range in ranges {
|
||||||
check_uniformity_u64(rng, range)
|
check_uniformity_u64(mut rng, u64(range))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_uniformity_f64(rng rand.MuslRNG) {
|
fn check_uniformity_f64(mut rng rand.MuslRNG) {
|
||||||
expected_mean := 0.5
|
expected_mean := 0.5
|
||||||
mut variance := 0.0
|
mut variance := 0.0
|
||||||
for _ in 0 .. sample_size {
|
for _ in 0 .. sample_size {
|
||||||
|
@ -108,7 +108,7 @@ fn test_musl_uniformity_f64() {
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
mut rng := rand.MuslRNG{}
|
mut rng := rand.MuslRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
check_uniformity_f64(rng)
|
check_uniformity_f64(mut rng)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -118,7 +118,7 @@ fn test_musl_u32n() {
|
||||||
mut rng := rand.MuslRNG{}
|
mut rng := rand.MuslRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u32n(max)
|
value := rng.u32n(u32(max))
|
||||||
assert value >= 0
|
assert value >= 0
|
||||||
assert value < max
|
assert value < max
|
||||||
}
|
}
|
||||||
|
@ -145,7 +145,7 @@ fn test_musl_u32_in_range() {
|
||||||
mut rng := rand.MuslRNG{}
|
mut rng := rand.MuslRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u32_in_range(min, max)
|
value := rng.u32_in_range(u64(min), u64(max))
|
||||||
assert value >= min
|
assert value >= min
|
||||||
assert value < max
|
assert value < max
|
||||||
}
|
}
|
||||||
|
@ -200,7 +200,7 @@ fn test_musl_int63() {
|
||||||
fn test_musl_intn() {
|
fn test_musl_intn() {
|
||||||
max := 2525642
|
max := 2525642
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.MuslRNG{}
|
mut rng := rand.MuslRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.intn(max)
|
value := rng.intn(max)
|
||||||
|
@ -213,7 +213,7 @@ fn test_musl_intn() {
|
||||||
fn test_musl_i64n() {
|
fn test_musl_i64n() {
|
||||||
max := i64(3246727724653636)
|
max := i64(3246727724653636)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.MuslRNG{}
|
mut rng := rand.MuslRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.i64n(max)
|
value := rng.i64n(max)
|
||||||
|
@ -227,7 +227,7 @@ fn test_musl_int_in_range() {
|
||||||
min := -4252
|
min := -4252
|
||||||
max := 1034
|
max := 1034
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.MuslRNG{}
|
mut rng := rand.MuslRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.int_in_range(min, max)
|
value := rng.int_in_range(min, max)
|
||||||
|
@ -241,7 +241,7 @@ fn test_musl_i64_in_range() {
|
||||||
min := i64(-24095)
|
min := i64(-24095)
|
||||||
max := i64(324058)
|
max := i64(324058)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.MuslRNG{}
|
mut rng := rand.MuslRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.i64_in_range(min, max)
|
value := rng.i64_in_range(min, max)
|
||||||
|
|
|
@ -14,7 +14,7 @@ mut:
|
||||||
|
|
||||||
// TODO: Remove in Phase 2 of reorganizing Random
|
// TODO: Remove in Phase 2 of reorganizing Random
|
||||||
pub fn new_pcg32(init_state, init_seq u64) PCG32RNG {
|
pub fn new_pcg32(init_state, init_seq u64) PCG32RNG {
|
||||||
rng := PCG32RNG{}
|
mut rng := PCG32RNG{}
|
||||||
rng.seed([u32(init_state), u32(init_state >> 32), u32(init_seq), u32(init_seq >> 32)])
|
rng.seed([u32(init_state), u32(init_state >> 32), u32(init_seq), u32(init_seq >> 32)])
|
||||||
return rng
|
return rng
|
||||||
}
|
}
|
||||||
|
@ -104,7 +104,7 @@ pub fn (mut rng PCG32RNG) u32_in_range(min, max u64) u64 {
|
||||||
eprintln('max must be greater than min')
|
eprintln('max must be greater than min')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return min + rng.u32n(max - min)
|
return min + rng.u32n(u32(max - min))
|
||||||
}
|
}
|
||||||
|
|
||||||
// rn.u64_in_range(min, max) - return a pseudorandom 64 bit unsigned u64 in [min, max)
|
// rn.u64_in_range(min, max) - return a pseudorandom 64 bit unsigned u64 in [min, max)
|
||||||
|
@ -148,7 +148,7 @@ pub fn (mut rng PCG32RNG) intn(max int) int {
|
||||||
eprintln('max has to be positive.')
|
eprintln('max has to be positive.')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return int(rng.u32n(max))
|
return int(rng.u32n(u32(max)))
|
||||||
}
|
}
|
||||||
|
|
||||||
// rng.i64n(max) - return a 64bit positive i64 in [0, max)
|
// rng.i64n(max) - return a 64bit positive i64 in [0, max)
|
||||||
|
@ -158,7 +158,7 @@ pub fn (mut rng PCG32RNG) i64n(max i64) i64 {
|
||||||
eprintln('max has to be positive.')
|
eprintln('max has to be positive.')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return i64(rng.u64n(max))
|
return i64(rng.u64n(u64(max)))
|
||||||
}
|
}
|
||||||
|
|
||||||
// rng.int_in_range(min, max) - return a 32bit positive int in [0, max)
|
// rng.int_in_range(min, max) - return a 32bit positive int in [0, max)
|
||||||
|
|
|
@ -61,7 +61,7 @@ fn test_pcg32_variability() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_uniformity_u64(rng rand.PCG32RNG, range u64) {
|
fn check_uniformity_u64(mut rng rand.PCG32RNG, range u64) {
|
||||||
range_f64 := f64(range)
|
range_f64 := f64(range)
|
||||||
expected_mean := range_f64 / 2.0
|
expected_mean := range_f64 / 2.0
|
||||||
mut variance := 0.0
|
mut variance := 0.0
|
||||||
|
@ -82,12 +82,12 @@ fn test_pcg32_uniformity_u64() {
|
||||||
mut rng := rand.PCG32RNG{}
|
mut rng := rand.PCG32RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for range in ranges {
|
for range in ranges {
|
||||||
check_uniformity_u64(rng, range)
|
check_uniformity_u64(mut rng, u64(range))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_uniformity_f64(rng rand.PCG32RNG) {
|
fn check_uniformity_f64(mut rng rand.PCG32RNG) {
|
||||||
expected_mean := 0.5
|
expected_mean := 0.5
|
||||||
mut variance := 0.0
|
mut variance := 0.0
|
||||||
for _ in 0 .. sample_size {
|
for _ in 0 .. sample_size {
|
||||||
|
@ -106,7 +106,7 @@ fn test_pcg32_uniformity_f64() {
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
mut rng := rand.PCG32RNG{}
|
mut rng := rand.PCG32RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
check_uniformity_f64(rng)
|
check_uniformity_f64(mut rng)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -116,7 +116,7 @@ fn test_pcg32_u32n() {
|
||||||
mut rng := rand.PCG32RNG{}
|
mut rng := rand.PCG32RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u32n(max)
|
value := rng.u32n(u32(max))
|
||||||
assert value >= 0
|
assert value >= 0
|
||||||
assert value < max
|
assert value < max
|
||||||
}
|
}
|
||||||
|
@ -143,7 +143,7 @@ fn test_pcg32_u32_in_range() {
|
||||||
mut rng := rand.PCG32RNG{}
|
mut rng := rand.PCG32RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u32_in_range(min, max)
|
value := rng.u32_in_range(u64(min), u64(max))
|
||||||
assert value >= min
|
assert value >= min
|
||||||
assert value < max
|
assert value < max
|
||||||
}
|
}
|
||||||
|
@ -198,7 +198,7 @@ fn test_pcg32_int63() {
|
||||||
fn test_pcg32_intn() {
|
fn test_pcg32_intn() {
|
||||||
max := 2525642
|
max := 2525642
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.PCG32RNG{}
|
mut rng := rand.PCG32RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.intn(max)
|
value := rng.intn(max)
|
||||||
|
@ -211,7 +211,7 @@ fn test_pcg32_intn() {
|
||||||
fn test_pcg32_i64n() {
|
fn test_pcg32_i64n() {
|
||||||
max := i64(3246727724653636)
|
max := i64(3246727724653636)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.PCG32RNG{}
|
mut rng := rand.PCG32RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.i64n(max)
|
value := rng.i64n(max)
|
||||||
|
@ -225,7 +225,7 @@ fn test_pcg32_int_in_range() {
|
||||||
min := -4252
|
min := -4252
|
||||||
max := 1034
|
max := 1034
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.PCG32RNG{}
|
mut rng := rand.PCG32RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.int_in_range(min, max)
|
value := rng.int_in_range(min, max)
|
||||||
|
@ -239,7 +239,7 @@ fn test_pcg32_i64_in_range() {
|
||||||
min := i64(-24095)
|
min := i64(-24095)
|
||||||
max := i64(324058)
|
max := i64(324058)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.PCG32RNG{}
|
mut rng := rand.PCG32RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.i64_in_range(min, max)
|
value := rng.i64_in_range(min, max)
|
||||||
|
|
107
vlib/rand/rand.v
107
vlib/rand/rand.v
|
@ -27,10 +27,6 @@ pub fn rand_r(seed &int) int {
|
||||||
return ns & 0x7fffffff
|
return ns & 0x7fffffff
|
||||||
}
|
}
|
||||||
|
|
||||||
const (
|
|
||||||
default_rng = new_default({})
|
|
||||||
)
|
|
||||||
|
|
||||||
pub struct PRNGConfigStruct {
|
pub struct PRNGConfigStruct {
|
||||||
seed []u32 = time_seed_array(2)
|
seed []u32 = time_seed_array(2)
|
||||||
}
|
}
|
||||||
|
@ -41,109 +37,6 @@ pub fn new_default(config PRNGConfigStruct) &WyRandRNG {
|
||||||
return rng
|
return rng
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// u32() - returns a uniformly distributed pseudorandom 32-bit unsigned u32
|
|
||||||
pub fn u32() u32 {
|
|
||||||
return default_rng.u32()
|
|
||||||
}
|
|
||||||
|
|
||||||
// u64() - returns a uniformly distributed pseudorandom 64-bit unsigned u64
|
|
||||||
pub fn u64() u64 {
|
|
||||||
return default_rng.u64()
|
|
||||||
}
|
|
||||||
|
|
||||||
// u32n(max) - returns a uniformly distributed pseudorandom 32-bit unsigned u32 in [0, max)
|
|
||||||
pub fn u32n(max u32) u32 {
|
|
||||||
return default_rng.u32n(max)
|
|
||||||
}
|
|
||||||
|
|
||||||
// u64n(max) - returns a uniformly distributed pseudorandom 64-bit unsigned u64 in [0, max)
|
|
||||||
pub fn u64n(max u64) u64 {
|
|
||||||
return default_rng.u64n(max)
|
|
||||||
}
|
|
||||||
|
|
||||||
// u32n() - returns a uniformly distributed pseudorandom 32-bit unsigned u32 in [min, max)
|
|
||||||
pub fn u32_in_range(min, max u32) u32 {
|
|
||||||
return default_rng.u32_in_range(min, max)
|
|
||||||
}
|
|
||||||
|
|
||||||
// u64_in_range(min, max) - returns a uniformly distributed pseudorandom 64-bit unsigned u64 in [min, max)
|
|
||||||
pub fn u64_in_range(min, max u64) u64 {
|
|
||||||
return default_rng.u64_in_range(min, max)
|
|
||||||
}
|
|
||||||
|
|
||||||
// int() - returns a uniformly distributed pseudorandom 32-bit signed (possibly negative) int
|
|
||||||
pub fn int() int {
|
|
||||||
return default_rng.int()
|
|
||||||
}
|
|
||||||
|
|
||||||
// intn(max) - returns a uniformly distributed pseudorandom 32-bit signed positive int in [0, max)
|
|
||||||
pub fn intn(max int) int {
|
|
||||||
return default_rng.intn(max)
|
|
||||||
}
|
|
||||||
|
|
||||||
// int_in_range(min, max) - returns a uniformly distributed pseudorandom
|
|
||||||
// 32-bit signed int in [min, max)
|
|
||||||
pub fn int_in_range(min, max int) int {
|
|
||||||
return default_rng.int_in_range(min, max)
|
|
||||||
}
|
|
||||||
|
|
||||||
// int31() - returns a uniformly distributed pseudorandom 31-bit signed positive int
|
|
||||||
pub fn int31() int {
|
|
||||||
return default_rng.int31()
|
|
||||||
}
|
|
||||||
|
|
||||||
// i64() - returns a uniformly distributed pseudorandom 64-bit signed (possibly negative) i64
|
|
||||||
pub fn i64() i64 {
|
|
||||||
return default_rng.i64()
|
|
||||||
}
|
|
||||||
|
|
||||||
// i64n(max) - returns a uniformly distributed pseudorandom 64-bit signed positive i64 in [0, max)
|
|
||||||
pub fn i64n(max i64) i64 {
|
|
||||||
return default_rng.i64n(max)
|
|
||||||
}
|
|
||||||
|
|
||||||
// i64_in_range(min, max) - returns a uniformly distributed pseudorandom
|
|
||||||
// 64-bit signed int in [min, max)
|
|
||||||
pub fn i64_in_range(min, max i64) i64 {
|
|
||||||
return default_rng.i64_in_range(min, max)
|
|
||||||
}
|
|
||||||
|
|
||||||
// int63() - returns a uniformly distributed pseudorandom 63-bit signed positive int
|
|
||||||
pub fn int63() i64 {
|
|
||||||
return default_rng.int63()
|
|
||||||
}
|
|
||||||
|
|
||||||
// f32() - returns a uniformly distributed 32-bit floating point in [0, 1)
|
|
||||||
pub fn f32() f32 {
|
|
||||||
return default_rng.f32()
|
|
||||||
}
|
|
||||||
|
|
||||||
// f64() - returns a uniformly distributed 64-bit floating point in [0, 1)
|
|
||||||
pub fn f64() f64 {
|
|
||||||
return default_rng.f64()
|
|
||||||
}
|
|
||||||
|
|
||||||
// f32n() - returns a uniformly distributed 32-bit floating point in [0, max)
|
|
||||||
pub fn f32n(max f32) f32 {
|
|
||||||
return default_rng.f32n(max)
|
|
||||||
}
|
|
||||||
|
|
||||||
// f64n() - returns a uniformly distributed 64-bit floating point in [0, max)
|
|
||||||
pub fn f64n(max f64) f64 {
|
|
||||||
return default_rng.f64n(max)
|
|
||||||
}
|
|
||||||
|
|
||||||
// f32_in_range(min, max) - returns a uniformly distributed 32-bit floating point in [min, max)
|
|
||||||
pub fn f32_in_range(min, max f32) f32 {
|
|
||||||
return default_rng.f32_in_range(min, max)
|
|
||||||
}
|
|
||||||
|
|
||||||
// f64_in_range(min, max) - returns a uniformly distributed 64-bit floating point in [min, max)
|
|
||||||
pub fn f64_in_range(min, max f64) f64 {
|
|
||||||
return default_rng.f64_in_range(min, max)
|
|
||||||
}
|
|
||||||
|
|
||||||
// rand_f32 return a random f32 between 0 and max
|
// rand_f32 return a random f32 between 0 and max
|
||||||
[deprecated]
|
[deprecated]
|
||||||
pub fn rand_f32(max f32) f32 {
|
pub fn rand_f32(max f32) f32 {
|
||||||
|
|
|
@ -54,210 +54,3 @@ fn assert_randoms_equal(r1, r2 []int) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn test_rand_f32_old() {
|
|
||||||
for seed in seeds {
|
|
||||||
rand.seed(seed)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
res := rand.rand_f32(100.0)
|
|
||||||
assert res >= 0.0
|
|
||||||
assert res < 100.0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_f32_in_range_old() {
|
|
||||||
for seed in seeds {
|
|
||||||
rand.seed(seed)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
res := rand.rand_f32_in_range(1.0, 2048.0)
|
|
||||||
assert res >= 1.0
|
|
||||||
assert res < 2048.0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_f64_old() {
|
|
||||||
for seed in seeds {
|
|
||||||
rand.seed(seed)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
res := rand.rand_f64(100.0)
|
|
||||||
assert res >= 0.0
|
|
||||||
assert res < 100.0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_f64_in_range_old() {
|
|
||||||
for seed in seeds {
|
|
||||||
rand.seed(seed)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
res := rand.rand_f64_in_range(1.0, 2048.0)
|
|
||||||
assert res >= 1.0
|
|
||||||
assert res < 2048.0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_uniform_f32() {
|
|
||||||
for seed in seeds {
|
|
||||||
rand.seed(seed)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
res := rand.rand_uniform_f32()
|
|
||||||
assert res >= 0.0
|
|
||||||
assert res < 1.0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_uniform_f64() {
|
|
||||||
for seed in seeds {
|
|
||||||
rand.seed(seed)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
res := rand.rand_uniform_f64()
|
|
||||||
assert res >= 0.0
|
|
||||||
assert res < 1.0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_u32n() {
|
|
||||||
max := u32(4287502)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
assert rand.u32n(max) < max
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_u64n() {
|
|
||||||
max := u64(23442353534587502)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
assert rand.u64n(max) < max
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_u32_in_range() {
|
|
||||||
min := u32(5256)
|
|
||||||
max := u32(4287502)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.u32_in_range(min, max)
|
|
||||||
assert value >= min
|
|
||||||
assert value < max
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_u64_in_range() {
|
|
||||||
min := u64(4265266246)
|
|
||||||
max := u64(23442353534587502)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.u64_in_range(min, max)
|
|
||||||
assert value >= min
|
|
||||||
assert value < max
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_intn() {
|
|
||||||
max := 720948723
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.intn(max)
|
|
||||||
assert value >= 0
|
|
||||||
assert value < max
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_i64n() {
|
|
||||||
max := i64(209487239094)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.i64n(max)
|
|
||||||
assert value >= 0
|
|
||||||
assert value < max
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_int_in_range() {
|
|
||||||
min := -34058
|
|
||||||
max := -10542
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.int_in_range(min, max)
|
|
||||||
assert value >= min
|
|
||||||
assert value < max
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_i64_in_range() {
|
|
||||||
min := i64(-5026245)
|
|
||||||
max := i64(209487239094)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.i64_in_range(min, max)
|
|
||||||
assert value >= min
|
|
||||||
assert value < max
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_int31() {
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.int31()
|
|
||||||
assert value >= 0
|
|
||||||
assert value <= math.max_i32
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_int63() {
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.int63()
|
|
||||||
assert value >= 0
|
|
||||||
assert value <= math.max_i64
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_f32() {
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.f32()
|
|
||||||
assert value >= 0.0
|
|
||||||
assert value < 1.0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_f64() {
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.f64()
|
|
||||||
assert value >= 0.0
|
|
||||||
assert value < 1.0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_f32n() {
|
|
||||||
max := f32(34.52)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.f32n(max)
|
|
||||||
assert value >= 0.0
|
|
||||||
assert value < max
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_f64n() {
|
|
||||||
max := 3495.2
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.f64n(max)
|
|
||||||
assert value >= 0.0
|
|
||||||
assert value < max
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_f32_in_range() {
|
|
||||||
min := f32(-10.4)
|
|
||||||
max := f32(43.2)
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.f32_in_range(min, max)
|
|
||||||
assert value >= min
|
|
||||||
assert value < max
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn test_rand_f64_in_range() {
|
|
||||||
min := -10980.4
|
|
||||||
max := -2.0
|
|
||||||
for _ in 0 .. rnd_count {
|
|
||||||
value := rand.f64_in_range(min, max)
|
|
||||||
assert value >= min
|
|
||||||
assert value < max
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -135,7 +135,7 @@ pub fn (mut rng SplitMix64RNG) intn(max int) int {
|
||||||
eprintln('max has to be positive.')
|
eprintln('max has to be positive.')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return int(rng.u32n(max))
|
return int(rng.u32n(u32(max)))
|
||||||
}
|
}
|
||||||
|
|
||||||
// rng.i64n(max) returns a pseudorandom int that lies in [0, max)
|
// rng.i64n(max) returns a pseudorandom int that lies in [0, max)
|
||||||
|
@ -145,7 +145,7 @@ pub fn (mut rng SplitMix64RNG) i64n(max i64) i64 {
|
||||||
eprintln('max has to be positive.')
|
eprintln('max has to be positive.')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return i64(rng.u64n(max))
|
return i64(rng.u64n(u64(max)))
|
||||||
}
|
}
|
||||||
|
|
||||||
// rng.int_in_range(min, max) returns a pseudorandom int that lies in [min, max)
|
// rng.int_in_range(min, max) returns a pseudorandom int that lies in [min, max)
|
||||||
|
|
|
@ -63,7 +63,7 @@ fn test_splitmix64_variability() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_uniformity_u64(rng rand.SplitMix64RNG, range u64) {
|
fn check_uniformity_u64(mut rng rand.SplitMix64RNG, range u64) {
|
||||||
range_f64 := f64(range)
|
range_f64 := f64(range)
|
||||||
expected_mean := range_f64 / 2.0
|
expected_mean := range_f64 / 2.0
|
||||||
mut variance := 0.0
|
mut variance := 0.0
|
||||||
|
@ -84,12 +84,12 @@ fn test_splitmix64_uniformity_u64() {
|
||||||
mut rng := rand.SplitMix64RNG{}
|
mut rng := rand.SplitMix64RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for range in ranges {
|
for range in ranges {
|
||||||
check_uniformity_u64(rng, range)
|
check_uniformity_u64(mut rng, u64(range))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_uniformity_f64(rng rand.SplitMix64RNG) {
|
fn check_uniformity_f64(mut rng rand.SplitMix64RNG) {
|
||||||
expected_mean := 0.5
|
expected_mean := 0.5
|
||||||
mut variance := 0.0
|
mut variance := 0.0
|
||||||
for _ in 0 .. sample_size {
|
for _ in 0 .. sample_size {
|
||||||
|
@ -108,7 +108,7 @@ fn test_splitmix64_uniformity_f64() {
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
mut rng := rand.SplitMix64RNG{}
|
mut rng := rand.SplitMix64RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
check_uniformity_f64(rng)
|
check_uniformity_f64(mut rng)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -118,7 +118,7 @@ fn test_splitmix64_u32n() {
|
||||||
mut rng := rand.SplitMix64RNG{}
|
mut rng := rand.SplitMix64RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u32n(max)
|
value := rng.u32n(u32(max))
|
||||||
assert value >= 0
|
assert value >= 0
|
||||||
assert value < max
|
assert value < max
|
||||||
}
|
}
|
||||||
|
@ -145,7 +145,7 @@ fn test_splitmix64_u32_in_range() {
|
||||||
mut rng := rand.SplitMix64RNG{}
|
mut rng := rand.SplitMix64RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u32_in_range(min, max)
|
value := rng.u32_in_range(u32(min), u32(max))
|
||||||
assert value >= min
|
assert value >= min
|
||||||
assert value < max
|
assert value < max
|
||||||
}
|
}
|
||||||
|
@ -200,7 +200,7 @@ fn test_splitmix64_int63() {
|
||||||
fn test_splimix64_intn() {
|
fn test_splimix64_intn() {
|
||||||
max := 2525642
|
max := 2525642
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.SplitMix64RNG{}
|
mut rng := rand.SplitMix64RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.intn(max)
|
value := rng.intn(max)
|
||||||
|
@ -213,7 +213,7 @@ fn test_splimix64_intn() {
|
||||||
fn test_splimix64_i64n() {
|
fn test_splimix64_i64n() {
|
||||||
max := i64(3246727724653636)
|
max := i64(3246727724653636)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.SplitMix64RNG{}
|
mut rng := rand.SplitMix64RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.i64n(max)
|
value := rng.i64n(max)
|
||||||
|
@ -227,7 +227,7 @@ fn test_splimix64_int_in_range() {
|
||||||
min := -4252
|
min := -4252
|
||||||
max := 230549862
|
max := 230549862
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.SplitMix64RNG{}
|
mut rng := rand.SplitMix64RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.int_in_range(min, max)
|
value := rng.int_in_range(min, max)
|
||||||
|
@ -241,7 +241,7 @@ fn test_splimix64_i64_in_range() {
|
||||||
min := i64(-24095)
|
min := i64(-24095)
|
||||||
max := i64(324058)
|
max := i64(324058)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.SplitMix64RNG{}
|
mut rng := rand.SplitMix64RNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.i64_in_range(min, max)
|
value := rng.i64_in_range(min, max)
|
||||||
|
|
|
@ -204,7 +204,7 @@ pub fn (r SysRNG) intn(max int) int {
|
||||||
eprintln('max has to be positive.')
|
eprintln('max has to be positive.')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return int(r.u32n(max))
|
return int(r.u32n(u32(max)))
|
||||||
}
|
}
|
||||||
|
|
||||||
// r.i64n(max) returns a pseudorandom i64 that lies in [0, max)
|
// r.i64n(max) returns a pseudorandom i64 that lies in [0, max)
|
||||||
|
@ -214,7 +214,7 @@ pub fn (r SysRNG) i64n(max i64) i64 {
|
||||||
eprintln('max has to be positive.')
|
eprintln('max has to be positive.')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return i64(r.u64n(max))
|
return i64(r.u64n(u64(max)))
|
||||||
}
|
}
|
||||||
|
|
||||||
// r.int_in_range(min, max) returns a pseudorandom int that lies in [min, max)
|
// r.int_in_range(min, max) returns a pseudorandom int that lies in [min, max)
|
||||||
|
|
|
@ -28,8 +28,8 @@ fn test_sys_rng_reproducibility() {
|
||||||
// seed for another batch of data.
|
// seed for another batch of data.
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
r1 := rand.SysRNG{}
|
mut r1 := rand.SysRNG{}
|
||||||
r2 := rand.SysRNG{}
|
mut r2 := rand.SysRNG{}
|
||||||
r1.seed(seed_data)
|
r1.seed(seed_data)
|
||||||
ints1 := get_n_randoms(value_count, r1)
|
ints1 := get_n_randoms(value_count, r1)
|
||||||
r2.seed(seed_data)
|
r2.seed(seed_data)
|
||||||
|
@ -55,7 +55,7 @@ fn test_sys_rng_variability() {
|
||||||
// improbable but not impossible.
|
// improbable but not impossible.
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
mut values := []u64{cap: value_count}
|
mut values := []u64{cap: value_count}
|
||||||
for i in 0 .. value_count {
|
for i in 0 .. value_count {
|
||||||
|
@ -88,10 +88,10 @@ fn test_sys_rng_uniformity_u64() {
|
||||||
ranges := [14019545, 80240, 130]
|
ranges := [14019545, 80240, 130]
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for range in ranges {
|
for range in ranges {
|
||||||
check_uniformity_u64(rng, range)
|
check_uniformity_u64(rng, u64(range))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -114,7 +114,7 @@ fn test_sys_rng_uniformity_f64() {
|
||||||
// The f64 version
|
// The f64 version
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
check_uniformity_f64(rng)
|
check_uniformity_f64(rng)
|
||||||
}
|
}
|
||||||
|
@ -124,10 +124,10 @@ fn test_sys_rng_u32n() {
|
||||||
max := 16384
|
max := 16384
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u32n(max)
|
value := rng.u32n(u32(max))
|
||||||
assert value >= 0
|
assert value >= 0
|
||||||
assert value < max
|
assert value < max
|
||||||
}
|
}
|
||||||
|
@ -138,7 +138,7 @@ fn test_sys_rng_u64n() {
|
||||||
max := u64(379091181005)
|
max := u64(379091181005)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u64n(max)
|
value := rng.u64n(max)
|
||||||
|
@ -153,10 +153,10 @@ fn test_sys_rng_u32_in_range() {
|
||||||
min := 316846
|
min := 316846
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u32_in_range(min, max)
|
value := rng.u32_in_range(u32(min), u32(max))
|
||||||
assert value >= min
|
assert value >= min
|
||||||
assert value < max
|
assert value < max
|
||||||
}
|
}
|
||||||
|
@ -168,7 +168,7 @@ fn test_sys_rng_u64_in_range() {
|
||||||
min := u64(6848646868)
|
min := u64(6848646868)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u64_in_range(min, max)
|
value := rng.u64_in_range(min, max)
|
||||||
|
@ -182,7 +182,7 @@ fn test_sys_rng_intn() {
|
||||||
max := 2525642
|
max := 2525642
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.intn(max)
|
value := rng.intn(max)
|
||||||
|
@ -196,7 +196,7 @@ fn test_sys_rng_i64n() {
|
||||||
max := i64(3246727724653636)
|
max := i64(3246727724653636)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.i64n(max)
|
value := rng.i64n(max)
|
||||||
|
@ -211,7 +211,7 @@ fn test_sys_rng_int_in_range() {
|
||||||
max := 23054962
|
max := 23054962
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.int_in_range(min, max)
|
value := rng.int_in_range(min, max)
|
||||||
|
@ -226,7 +226,7 @@ fn test_sys_rng_i64_in_range() {
|
||||||
max := i64(324058)
|
max := i64(324058)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.i64_in_range(min, max)
|
value := rng.i64_in_range(min, max)
|
||||||
|
@ -241,7 +241,7 @@ fn test_sys_rng_int31() {
|
||||||
sign_mask := 0x80000000
|
sign_mask := 0x80000000
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.int31()
|
value := rng.int31()
|
||||||
|
@ -258,7 +258,7 @@ fn test_sys_rng_int63() {
|
||||||
sign_mask := i64(0x8000000000000000)
|
sign_mask := i64(0x8000000000000000)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.int63()
|
value := rng.int63()
|
||||||
|
@ -272,7 +272,7 @@ fn test_sys_rng_int63() {
|
||||||
fn test_sys_rng_f32() {
|
fn test_sys_rng_f32() {
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.f32()
|
value := rng.f32()
|
||||||
|
@ -285,7 +285,7 @@ fn test_sys_rng_f32() {
|
||||||
fn test_sys_rng_f64() {
|
fn test_sys_rng_f64() {
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.f64()
|
value := rng.f64()
|
||||||
|
@ -299,7 +299,7 @@ fn test_sys_rng_f32n() {
|
||||||
max := f32(357.0)
|
max := f32(357.0)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.f32()
|
value := rng.f32()
|
||||||
|
@ -313,7 +313,7 @@ fn test_sys_rng_f64n() {
|
||||||
max := 1.52e6
|
max := 1.52e6
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.f64()
|
value := rng.f64()
|
||||||
|
@ -328,7 +328,7 @@ fn test_sys_rng_f32_in_range() {
|
||||||
max := f32(125.0)
|
max := f32(125.0)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.f32()
|
value := rng.f32()
|
||||||
|
@ -343,7 +343,7 @@ fn test_sys_rng_f64_in_range() {
|
||||||
max := 5015.2
|
max := 5015.2
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
seed_data := [seed]
|
seed_data := [seed]
|
||||||
rng := rand.SysRNG{}
|
mut rng := rand.SysRNG{}
|
||||||
rng.seed(seed_data)
|
rng.seed(seed_data)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.f64()
|
value := rng.f64()
|
||||||
|
|
|
@ -164,7 +164,7 @@ pub fn (mut rng WyRandRNG) intn(max int) int {
|
||||||
eprintln('max has to be positive.')
|
eprintln('max has to be positive.')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return int(rng.u32n(max))
|
return int(rng.u32n(u32(max)))
|
||||||
}
|
}
|
||||||
|
|
||||||
// rng.i64n(max) returns a pseudorandom int that lies in [0, max)
|
// rng.i64n(max) returns a pseudorandom int that lies in [0, max)
|
||||||
|
@ -174,7 +174,7 @@ pub fn (mut rng WyRandRNG) i64n(max i64) i64 {
|
||||||
eprintln('max has to be positive.')
|
eprintln('max has to be positive.')
|
||||||
exit(1)
|
exit(1)
|
||||||
}
|
}
|
||||||
return i64(rng.u64n(max))
|
return i64(rng.u64n(u64(max)))
|
||||||
}
|
}
|
||||||
|
|
||||||
// rng.int_in_range(min, max) returns a pseudorandom int that lies in [min, max)
|
// rng.int_in_range(min, max) returns a pseudorandom int that lies in [min, max)
|
||||||
|
|
|
@ -63,7 +63,7 @@ fn test_wyrand_variability() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_uniformity_u64(rng rand.WyRandRNG, range u64) {
|
fn check_uniformity_u64(mut rng rand.WyRandRNG, range u64) {
|
||||||
range_f64 := f64(range)
|
range_f64 := f64(range)
|
||||||
expected_mean := range_f64 / 2.0
|
expected_mean := range_f64 / 2.0
|
||||||
mut variance := 0.0
|
mut variance := 0.0
|
||||||
|
@ -84,12 +84,12 @@ fn test_wyrand_uniformity_u64() {
|
||||||
mut rng := rand.WyRandRNG{}
|
mut rng := rand.WyRandRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for range in ranges {
|
for range in ranges {
|
||||||
check_uniformity_u64(rng, range)
|
check_uniformity_u64(mut rng, u64(range))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_uniformity_f64(rng rand.WyRandRNG) {
|
fn check_uniformity_f64(mut rng rand.WyRandRNG) {
|
||||||
expected_mean := 0.5
|
expected_mean := 0.5
|
||||||
mut variance := 0.0
|
mut variance := 0.0
|
||||||
for _ in 0 .. sample_size {
|
for _ in 0 .. sample_size {
|
||||||
|
@ -108,7 +108,7 @@ fn test_wyrand_uniformity_f64() {
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
mut rng := rand.WyRandRNG{}
|
mut rng := rand.WyRandRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
check_uniformity_f64(rng)
|
check_uniformity_f64(mut rng)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -118,7 +118,7 @@ fn test_wyrand_u32n() {
|
||||||
mut rng := rand.WyRandRNG{}
|
mut rng := rand.WyRandRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u32n(max)
|
value := rng.u32n(u32(max))
|
||||||
assert value >= 0
|
assert value >= 0
|
||||||
assert value < max
|
assert value < max
|
||||||
}
|
}
|
||||||
|
@ -145,7 +145,7 @@ fn test_wyrand_u32_in_range() {
|
||||||
mut rng := rand.WyRandRNG{}
|
mut rng := rand.WyRandRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.u32_in_range(min, max)
|
value := rng.u32_in_range(u32(min), u32(max))
|
||||||
assert value >= min
|
assert value >= min
|
||||||
assert value < max
|
assert value < max
|
||||||
}
|
}
|
||||||
|
@ -200,7 +200,7 @@ fn test_wyrand_int63() {
|
||||||
fn test_wyrand_intn() {
|
fn test_wyrand_intn() {
|
||||||
max := 2525642
|
max := 2525642
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.WyRandRNG{}
|
mut rng := rand.WyRandRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.intn(max)
|
value := rng.intn(max)
|
||||||
|
@ -213,7 +213,7 @@ fn test_wyrand_intn() {
|
||||||
fn test_wyrand_i64n() {
|
fn test_wyrand_i64n() {
|
||||||
max := i64(3246727724653636)
|
max := i64(3246727724653636)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.WyRandRNG{}
|
mut rng := rand.WyRandRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.i64n(max)
|
value := rng.i64n(max)
|
||||||
|
@ -227,7 +227,7 @@ fn test_wyrand_int_in_range() {
|
||||||
min := -4252
|
min := -4252
|
||||||
max := 1034
|
max := 1034
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.WyRandRNG{}
|
mut rng := rand.WyRandRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.int_in_range(min, max)
|
value := rng.int_in_range(min, max)
|
||||||
|
@ -241,7 +241,7 @@ fn test_wyrand_i64_in_range() {
|
||||||
min := i64(-24095)
|
min := i64(-24095)
|
||||||
max := i64(324058)
|
max := i64(324058)
|
||||||
for seed in seeds {
|
for seed in seeds {
|
||||||
rng := rand.WyRandRNG{}
|
mut rng := rand.WyRandRNG{}
|
||||||
rng.seed(seed)
|
rng.seed(seed)
|
||||||
for _ in 0 .. range_limit {
|
for _ in 0 .. range_limit {
|
||||||
value := rng.i64_in_range(min, max)
|
value := rng.i64_in_range(min, max)
|
||||||
|
|
Loading…
Reference in New Issue