Struct rand_xoshiro::Xoroshiro128PlusPlus [−][src]
pub struct Xoroshiro128PlusPlus { /* fields omitted */ }
Expand description
A xoroshiro128++ random number generator.
The xoroshiro128++ algorithm is not suitable for cryptographic purposes, but is very fast and has excellent statistical properties.
The algorithm used here is translated from the xoroshiro128plusplus.c
reference source code by
David Blackman and Sebastiano Vigna.
Implementations
Jump forward, equivalently to 2^64 calls to next_u64()
.
This can be used to generate 2^64 non-overlapping subsequences for parallel computations.
use rand_xoshiro::rand_core::SeedableRng;
use rand_xoshiro::Xoroshiro128PlusPlus;
let rng1 = Xoroshiro128PlusPlus::seed_from_u64(0);
let mut rng2 = rng1.clone();
rng2.jump();
let mut rng3 = rng2.clone();
rng3.jump();
Trait Implementations
This method tests for self
and other
values to be equal, and is used
by ==
. Read more
This method tests for !=
.
Create a new Xoroshiro128PlusPlus
. If seed
is entirely 0, it will be
mapped to a different seed.
Seed a Xoroshiro128PlusPlus
from a u64
using SplitMix64
.
Seed type, which is restricted to types mutably-dereferencable as u8
arrays (we recommend [u8; N]
for some N
). Read more
Create a new PRNG seeded from another Rng
. Read more
Auto Trait Implementations
impl RefUnwindSafe for Xoroshiro128PlusPlus
impl Send for Xoroshiro128PlusPlus
impl Sync for Xoroshiro128PlusPlus
impl Unpin for Xoroshiro128PlusPlus
impl UnwindSafe for Xoroshiro128PlusPlus
Blanket Implementations
Mutably borrows from an owned value. Read more