2020-02-03 05:00:36 +01:00
|
|
|
// Copyright (c) 2019-2020 Alexander Medvednikov. All rights reserved.
|
2019-06-23 04:21:30 +02:00
|
|
|
// Use of this source code is governed by an MIT license
|
|
|
|
// that can be found in the LICENSE file.
|
2019-06-22 20:20:28 +02:00
|
|
|
module rand
|
|
|
|
|
2020-05-27 19:13:57 +02:00
|
|
|
const (
|
|
|
|
max_i32 = 2147483647
|
|
|
|
)
|
|
|
|
|
2020-04-03 08:53:57 +02:00
|
|
|
fn C.rand() int
|
|
|
|
|
2019-07-13 18:17:45 +02:00
|
|
|
pub fn seed(s int) {
|
|
|
|
C.srand(s)
|
2019-06-22 20:20:28 +02:00
|
|
|
}
|
|
|
|
|
2019-06-26 12:56:49 +02:00
|
|
|
pub fn next(max int) int {
|
2019-06-27 19:02:47 +02:00
|
|
|
return C.rand() % max
|
2019-06-22 20:20:28 +02:00
|
|
|
}
|
|
|
|
|
2020-04-03 08:53:57 +02:00
|
|
|
// rand_r returns a pseudo-random number;
|
|
|
|
// writes a result value to the seed argument.
|
2020-04-26 11:56:27 +02:00
|
|
|
pub fn rand_r(seed &int) int {
|
2020-04-03 08:53:57 +02:00
|
|
|
ns := *seed * 1103515245 + 12345
|
2020-05-11 16:05:59 +02:00
|
|
|
unsafe {
|
|
|
|
(*seed) = ns
|
|
|
|
}
|
2020-04-03 08:53:57 +02:00
|
|
|
return ns & 0x7fffffff
|
2019-09-16 21:21:21 +02:00
|
|
|
}
|
2020-05-27 15:41:37 +02:00
|
|
|
|
|
|
|
// rand_f32 return a random f32 between 0 and max
|
|
|
|
pub fn rand_f32(max f32) f32 {
|
2020-05-27 19:13:57 +02:00
|
|
|
return f32(f64(C.rand()) / f64(C.RAND_MAX) * f64(max))
|
2020-05-27 15:41:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// rand_f32 return a random f32 in range min and max
|
2020-05-27 19:13:57 +02:00
|
|
|
pub fn rand_f32_in_range(min, max f32) f32 {
|
|
|
|
scaled_r := f32(next(max_i32)) / max_i32
|
|
|
|
return min + scaled_r * (max - min)
|
2020-05-27 15:41:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// rand_f64 return a random f64 between 0 and max
|
|
|
|
pub fn rand_f64(max f32) f32 {
|
2020-05-27 19:13:57 +02:00
|
|
|
return f64(C.rand()) / f64(C.RAND_MAX) * f64(max)
|
2020-05-27 15:41:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// rand_f64 return a random f64 in range min and max
|
2020-05-27 19:13:57 +02:00
|
|
|
pub fn rand_f64_in_range(min, max f64) f64 {
|
|
|
|
scaled_r := f64(next(max_i32)) / max_i32
|
|
|
|
return min + scaled_r * (max - min)
|
|
|
|
}
|