| // Copyright 2014 The Rust Project Developers. See the COPYRIGHT |
| // file at the top-level directory of this distribution and at |
| // http://rust-lang.org/COPYRIGHT. |
| // |
| // Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or |
| // http://www.apache.org/licenses/LICENSE-2.0> or the MIT license |
| // <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your |
| // option. This file may not be copied, modified, or distributed |
| // except according to those terms. |
| |
| mod map; |
| mod set; |
| |
| /// XorShiftRng |
| struct DeterministicRng { |
| x: u32, |
| y: u32, |
| z: u32, |
| w: u32, |
| } |
| |
| impl DeterministicRng { |
| fn new() -> Self { |
| DeterministicRng { |
| x: 0x193a6754, |
| y: 0xa8a7d469, |
| z: 0x97830e05, |
| w: 0x113ba7bb, |
| } |
| } |
| |
| fn next(&mut self) -> u32 { |
| let x = self.x; |
| let t = x ^ (x << 11); |
| self.x = self.y; |
| self.y = self.z; |
| self.z = self.w; |
| let w_ = self.w; |
| self.w = w_ ^ (w_ >> 19) ^ (t ^ (t >> 8)); |
| self.w |
| } |
| } |