pub struct Xoroshiro128PlusPlus { /* private fields */ }
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§
Source§impl Xoroshiro128PlusPlus
impl Xoroshiro128PlusPlus
Sourcepub fn jump(&mut self)
pub fn jump(&mut self)
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§
Source§impl Clone for Xoroshiro128PlusPlus
impl Clone for Xoroshiro128PlusPlus
Source§fn clone(&self) -> Xoroshiro128PlusPlus
fn clone(&self) -> Xoroshiro128PlusPlus
Returns a copy of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl Debug for Xoroshiro128PlusPlus
impl Debug for Xoroshiro128PlusPlus
Source§impl PartialEq for Xoroshiro128PlusPlus
impl PartialEq for Xoroshiro128PlusPlus
Source§impl RngCore for Xoroshiro128PlusPlus
impl RngCore for Xoroshiro128PlusPlus
Source§impl SeedableRng for Xoroshiro128PlusPlus
impl SeedableRng for Xoroshiro128PlusPlus
Source§fn from_seed(seed: [u8; 16]) -> Xoroshiro128PlusPlus
fn from_seed(seed: [u8; 16]) -> Xoroshiro128PlusPlus
Create a new Xoroshiro128PlusPlus
. If seed
is entirely 0, it will be
mapped to a different seed.
Source§fn seed_from_u64(seed: u64) -> Xoroshiro128PlusPlus
fn seed_from_u64(seed: u64) -> Xoroshiro128PlusPlus
Seed a Xoroshiro128PlusPlus
from a u64
using SplitMix64
.
Source§type Seed = [u8; 16]
type Seed = [u8; 16]
Seed type, which is restricted to types mutably-dereferenceable as
u8
arrays (we recommend [u8; N]
for some N
). Read moreSource§fn from_rng(rng: &mut impl RngCore) -> Self
fn from_rng(rng: &mut impl RngCore) -> Self
Create a new PRNG seeded from an infallible
Rng
. Read moreSource§fn try_from_rng<R>(rng: &mut R) -> Result<Self, <R as TryRngCore>::Error>where
R: TryRngCore,
fn try_from_rng<R>(rng: &mut R) -> Result<Self, <R as TryRngCore>::Error>where
R: TryRngCore,
Create a new PRNG seeded from a potentially fallible
Rng
. Read moreimpl Eq for Xoroshiro128PlusPlus
impl StructuralPartialEq for Xoroshiro128PlusPlus
Auto Trait Implementations§
impl Freeze for Xoroshiro128PlusPlus
impl RefUnwindSafe for Xoroshiro128PlusPlus
impl Send for Xoroshiro128PlusPlus
impl Sync for Xoroshiro128PlusPlus
impl Unpin for Xoroshiro128PlusPlus
impl UnwindSafe for Xoroshiro128PlusPlus
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<R> TryRngCore for Rwhere
R: RngCore,
impl<R> TryRngCore for Rwhere
R: RngCore,
Source§type Error = Infallible
type Error = Infallible
The type returned in the event of a RNG error.
Source§fn try_next_u32(&mut self) -> Result<u32, <R as TryRngCore>::Error>
fn try_next_u32(&mut self) -> Result<u32, <R as TryRngCore>::Error>
Return the next random
u32
.Source§fn try_next_u64(&mut self) -> Result<u64, <R as TryRngCore>::Error>
fn try_next_u64(&mut self) -> Result<u64, <R as TryRngCore>::Error>
Return the next random
u64
.Source§fn try_fill_bytes(
&mut self,
dst: &mut [u8],
) -> Result<(), <R as TryRngCore>::Error>
fn try_fill_bytes( &mut self, dst: &mut [u8], ) -> Result<(), <R as TryRngCore>::Error>
Fill
dest
entirely with random data.