pub struct Xoroshiro64StarStar { /* private fields */ }Expand description
A xoroshiro64** random number generator.
The xoshiro64** algorithm is not suitable for cryptographic purposes, but is very fast and has excellent statistical properties.
The algorithm used here is translated from the xoroshiro64starstar.c
reference source code by
David Blackman and Sebastiano Vigna.
Implementations§
Source§impl Xoroshiro64StarStar
impl Xoroshiro64StarStar
Sourcepub fn state(&self) -> [u8; 8]
pub fn state(&self) -> [u8; 8]
Return the internal state of the generator as little-endian
bytes that can be passed to SeedableRng::from_seed to
reconstruct an identical generator.
The all-zero state is unreachable from any non-zero seed, so
the round-trip is exact for any generator obtained via the
usual constructors. (An all-zero input to from_seed is
remapped to seed_from_u64(0).)
Trait Implementations§
Source§impl Clone for Xoroshiro64StarStar
impl Clone for Xoroshiro64StarStar
Source§fn clone(&self) -> Xoroshiro64StarStar
fn clone(&self) -> Xoroshiro64StarStar
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for Xoroshiro64StarStar
impl Debug for Xoroshiro64StarStar
Source§impl PartialEq for Xoroshiro64StarStar
impl PartialEq for Xoroshiro64StarStar
Source§impl SeedableRng for Xoroshiro64StarStar
impl SeedableRng for Xoroshiro64StarStar
Source§fn from_seed(seed: [u8; 8]) -> Xoroshiro64StarStar
fn from_seed(seed: [u8; 8]) -> Xoroshiro64StarStar
Create a new Xoroshiro64StarStar. If seed is entirely 0, it will be
mapped to a different seed.
Source§fn seed_from_u64(seed: u64) -> Xoroshiro64StarStar
fn seed_from_u64(seed: u64) -> Xoroshiro64StarStar
Seed a Xoroshiro64StarStar from a u64 using SplitMix64.
Source§type Seed = [u8; 8]
type Seed = [u8; 8]
u8
arrays (we recommend [u8; N] for some N). Read moreSource§fn from_rng<R>(rng: &mut R) -> Self
fn from_rng<R>(rng: &mut R) -> Self
Rng. Read more