-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathrandom.zig
42 lines (33 loc) · 1.32 KB
/
random.zig
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
// SPDX-License-Identifier: Apache-2.0
const std = @import("std");
const Random = std.rand.Random;
pub const Sfc32 = @import("random/sfc32.zig");
/// Returns uniformly distributed value in [-n..n) interval
pub fn norm(comptime T: type, rnd: *Random, n: T) T {
std.debug.assert(@typeInfo(T) == .Float);
return rnd.float(T) * 2 * n - n;
}
/// Returns uniformly distributed value in either the
/// [min..max) or the (-max..-min] interval (same odds)
pub fn normMinmax(comptime T: type, rnd: *Random, min: T, max: T) T {
std.debug.assert(@typeInfo(T) == .Float);
const x = minmax(T, rnd, min, max);
return if (rnd.int(u1) == 1) x else -x;
}
/// Returns uniformly distributed value in [min..max) interval
pub fn minmax(comptime T: type, rnd: *Random, min: T, max: T) T {
std.debug.assert(@typeInfo(T) == .Float);
return min + (max - min) * rnd.float(T);
}
pub fn minmaxInt(comptime T: type, rnd: *Random, min: T, max: T) T {
return rnd.intRangeLessThan(T, min, max);
}
pub fn pick(comptime T: type, rnd: *Random, opts: anytype) T {
return opts[rnd.uintLessThan(usize, opts.len)];
}
pub fn pickWeighted(comptime T: type, rnd: *Random, opts: anytype, weights: []const f32) T {
return opts[rnd.weightedIndex(f32, weights)];
}
pub fn chance(rnd: *Random, prob: f32) bool {
return rnd.float(f32) < prob;
}