Struct rand_xoshiro::Xoshiro256Plus
source · [−]pub struct Xoshiro256Plus { /* private fields */ }Expand description
A xoshiro256+ random number generator.
The xoshiro256+ algorithm is not suitable for cryptographic purposes, but is very fast and has good statistical properties, besides a low linear complexity in the lowest bits.
The algorithm used here is translated from the xoshiro256plus.c
reference source code by
David Blackman and Sebastiano Vigna.
Implementations
sourceimpl Xoshiro256Plus
impl Xoshiro256Plus
sourcepub fn jump(&mut self)
pub fn jump(&mut self)
Jump forward, equivalently to 2^128 calls to next_u64().
This can be used to generate 2^128 non-overlapping subsequences for parallel computations.
use rand_xoshiro::rand_core::SeedableRng;
use rand_xoshiro::Xoshiro256Plus;
let rng1 = Xoshiro256Plus::seed_from_u64(0);
let mut rng2 = rng1.clone();
rng2.jump();
let mut rng3 = rng2.clone();
rng3.jump();Trait Implementations
sourceimpl Clone for Xoshiro256Plus
impl Clone for Xoshiro256Plus
sourcefn clone(&self) -> Xoshiro256Plus
fn clone(&self) -> Xoshiro256Plus
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source. Read more
sourceimpl Debug for Xoshiro256Plus
impl Debug for Xoshiro256Plus
sourceimpl PartialEq<Xoshiro256Plus> for Xoshiro256Plus
impl PartialEq<Xoshiro256Plus> for Xoshiro256Plus
sourcefn eq(&self, other: &Xoshiro256Plus) -> bool
fn eq(&self, other: &Xoshiro256Plus) -> bool
This method tests for self and other values to be equal, and is used
by ==. Read more
sourcefn ne(&self, other: &Xoshiro256Plus) -> bool
fn ne(&self, other: &Xoshiro256Plus) -> bool
This method tests for !=.
sourceimpl RngCore for Xoshiro256Plus
impl RngCore for Xoshiro256Plus
sourcefn fill_bytes(&mut self, dest: &mut [u8])
fn fill_bytes(&mut self, dest: &mut [u8])
Fill dest with random data. Read more
sourceimpl SeedableRng for Xoshiro256Plus
impl SeedableRng for Xoshiro256Plus
sourcefn from_seed(seed: [u8; 32]) -> Xoshiro256Plus
fn from_seed(seed: [u8; 32]) -> Xoshiro256Plus
Create a new Xoshiro256Plus. If seed is entirely 0, it will be
mapped to a different seed.
sourcefn seed_from_u64(seed: u64) -> Xoshiro256Plus
fn seed_from_u64(seed: u64) -> Xoshiro256Plus
Seed a Xoshiro256Plus from a u64 using SplitMix64.
impl Eq for Xoshiro256Plus
impl StructuralEq for Xoshiro256Plus
impl StructuralPartialEq for Xoshiro256Plus
Auto Trait Implementations
impl RefUnwindSafe for Xoshiro256Plus
impl Send for Xoshiro256Plus
impl Sync for Xoshiro256Plus
impl Unpin for Xoshiro256Plus
impl UnwindSafe for Xoshiro256Plus
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
