2020-02-03 07:00:36 +03:00
|
|
|
// Copyright (c) 2019-2020 Alexander Medvednikov. All rights reserved.
|
2019-06-23 05:21:30 +03:00
|
|
|
// Use of this source code is governed by an MIT license
|
|
|
|
// that can be found in the LICENSE file.
|
2019-06-22 21:20:28 +03:00
|
|
|
module rand
|
|
|
|
|
2020-06-01 22:13:56 +03:00
|
|
|
// TODO: Remove these functions once done:
|
|
|
|
// 1. C.rand()
|
|
|
|
// 2. seed()
|
|
|
|
// 3. next()
|
|
|
|
// 4. rand_r()
|
|
|
|
// fn C.rand() int
|
2019-07-13 19:17:45 +03:00
|
|
|
pub fn seed(s int) {
|
|
|
|
C.srand(s)
|
2019-06-22 21:20:28 +03:00
|
|
|
}
|
|
|
|
|
2019-06-26 13:56:49 +03:00
|
|
|
pub fn next(max int) int {
|
2019-06-27 20:02:47 +03:00
|
|
|
return C.rand() % max
|
2019-06-22 21:20:28 +03:00
|
|
|
}
|
|
|
|
|
2020-04-03 09:53:57 +03:00
|
|
|
// rand_r returns a pseudo-random number;
|
|
|
|
// writes a result value to the seed argument.
|
2020-04-26 12:56:27 +03:00
|
|
|
pub fn rand_r(seed &int) int {
|
2020-04-03 09:53:57 +03:00
|
|
|
ns := *seed * 1103515245 + 12345
|
2020-05-11 17:05:59 +03:00
|
|
|
unsafe {
|
|
|
|
(*seed) = ns
|
|
|
|
}
|
2020-04-03 09:53:57 +03:00
|
|
|
return ns & 0x7fffffff
|
2019-09-16 22:21:21 +03:00
|
|
|
}
|
2020-05-27 16:41:37 +03:00
|
|
|
|
2020-06-01 22:13:56 +03:00
|
|
|
pub struct PRNGConfigStruct {
|
|
|
|
seed []u32 = time_seed_array(2)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn new_default(config PRNGConfigStruct) &WyRandRNG {
|
|
|
|
rng := &WyRandRNG{}
|
|
|
|
rng.seed(config.seed)
|
|
|
|
return rng
|
|
|
|
}
|
|
|
|
|
2020-05-27 16:41:37 +03:00
|
|
|
// rand_f32 return a random f32 between 0 and max
|
2020-06-01 22:13:56 +03:00
|
|
|
[deprecated]
|
2020-05-27 16:41:37 +03:00
|
|
|
pub fn rand_f32(max f32) f32 {
|
2020-05-28 02:16:17 +03:00
|
|
|
return rand_uniform_f32() * max
|
2020-05-27 16:41:37 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// rand_f32 return a random f32 in range min and max
|
2020-06-01 22:13:56 +03:00
|
|
|
[deprecated]
|
2020-05-27 20:13:57 +03:00
|
|
|
pub fn rand_f32_in_range(min, max f32) f32 {
|
2020-05-28 02:16:17 +03:00
|
|
|
return min + rand_uniform_f32() * (max - min)
|
2020-05-27 16:41:37 +03:00
|
|
|
}
|
|
|
|
|
2020-05-28 02:16:17 +03:00
|
|
|
// rand_f64 return a random f64 between 0 (inclusive) and max (exclusive)
|
2020-06-01 22:13:56 +03:00
|
|
|
[deprecated]
|
2020-05-28 02:16:17 +03:00
|
|
|
pub fn rand_f64(max f64) f64 {
|
|
|
|
return rand_uniform_f64() * max
|
2020-05-27 16:41:37 +03:00
|
|
|
}
|
|
|
|
|
2020-05-28 02:16:17 +03:00
|
|
|
// rand_f64 return a random f64 in range min (inclusive) and max (exclusive)
|
2020-06-01 22:13:56 +03:00
|
|
|
[deprecated]
|
2020-05-27 20:13:57 +03:00
|
|
|
pub fn rand_f64_in_range(min, max f64) f64 {
|
2020-05-28 02:16:17 +03:00
|
|
|
return min + rand_uniform_f64() * (max - min)
|
|
|
|
}
|
|
|
|
|
|
|
|
// rand_uniform_f32 returns a uniformly distributed f32 in the range 0 (inclusive) and 1 (exclusive)
|
2020-06-01 22:13:56 +03:00
|
|
|
[deprecated]
|
2020-05-28 02:16:17 +03:00
|
|
|
pub fn rand_uniform_f32() f32 {
|
|
|
|
return f32(C.rand()) / f32(C.RAND_MAX)
|
2020-05-27 20:13:57 +03:00
|
|
|
}
|
2020-05-28 02:16:17 +03:00
|
|
|
|
|
|
|
// rand_uniform_f64 returns a uniformly distributed f64 in the range 0 (inclusive) and 1 (exclusive)
|
2020-06-01 22:13:56 +03:00
|
|
|
[deprecated]
|
2020-05-28 02:16:17 +03:00
|
|
|
pub fn rand_uniform_f64() f64 {
|
|
|
|
return f64(C.rand()) / f64(C.RAND_MAX)
|
2020-06-01 22:13:56 +03:00
|
|
|
}
|