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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
use crate::prng_iter;
use crate::smol_core;
use crate::smol_core::Algorithm;
#[derive(Default)]
pub struct Sfc32 {
pub(crate) data: [u32; 4],
}
prng_iter! {Sfc32}
#[derive(Default)]
pub struct Sfc32Small {
pub(crate) data: u32,
}
prng_iter! {Sfc32Small}
impl Algorithm for Sfc32 {
type Output = u32;
fn gen(&mut self) -> Self::Output {
self.data[3] = self.data[3].overflowing_add(1).0;
let t = self.data[0]
.overflowing_add(self.data[1])
.0
.overflowing_add(self.data[2])
.0;
self.data[0] ^= self.data[1] >> 9;
self.data[1] ^= self.data[2].overflowing_shl(3).0;
self.data[2] = (self.data[2].overflowing_shl(21).0 | (self.data[1] >> 11))
.overflowing_add(t)
.0;
t
}
}
impl Algorithm for Sfc32Small {
type Output = u32;
fn gen(&mut self) -> Self::Output {
self.data = self.data.overflowing_add(0x9e3779b9u32).0;
let mut z = self.data;
z = z.overflowing_mul(0x85ebca6bu32).0;
z ^= z >> 13;
z = z.overflowing_mul(0xc2b2ae35u32).0;
z ^= z >> 16;
z
}
}