v/vlib/rand/rand.v

47 lines
1.2 KiB
V
Raw Normal View History

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.
2020-04-03 08:53:57 +02:00
2019-06-22 20:20:28 +02:00
module rand
2020-04-03 08:53:57 +02:00
fn C.rand() int
pub fn seed(s int) {
C.srand(s)
2019-06-22 20:20:28 +02:00
}
pub fn next(max int) int {
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.
pub fn rand_r(seed &int) int {
2020-04-03 08:53:57 +02:00
ns := *seed * 1103515245 + 12345
unsafe {
(*seed) = ns
}
2020-04-03 08:53:57 +02:00
return ns & 0x7fffffff
2019-09-16 21:21:21 +02:00
}
// rand_f32 return a random f32 between 0 and max
pub fn rand_f32(max f32) f32 {
return f32( f64(C.rand()) / ( f64(C.RAND_MAX)/f64(max) ) )
}
// rand_f32 return a random f32 in range min and max
pub fn rand_f32_in_range(min f32, max f32) f32 {
scaled_r := f32(rand.next( 2147483647 )) / 2147483647.0
return min + scaled_r * (max - min )
}
// rand_f64 return a random f64 between 0 and max
pub fn rand_f64(max f32) f32 {
return f64(C.rand()) / ( f64(C.RAND_MAX)/f64(max) )
}
// rand_f64 return a random f64 in range min and max
pub fn rand_f64_in_range(min f64, max f64) f64 {
scaled_r := f64(rand.next( 2147483647 )) / 2147483647.0
return min + scaled_r * (max - min )
}