Struct rand_xoshiro::Xoshiro256PlusPlus
source · [−]pub struct Xoshiro256PlusPlus { /* private fields */ }
Expand description
A xoshiro256** random number generator.
The xoshiro256** algorithm is not suitable for cryptographic purposes, but is very fast and has excellent statistical properties.
The algorithm used here is translated from the xoshiro256plusplus.c
reference source code by
David Blackman and Sebastiano Vigna.
Implementations
sourceimpl Xoshiro256PlusPlus
impl Xoshiro256PlusPlus
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::Xoshiro256PlusPlus;
let rng1 = Xoshiro256PlusPlus::seed_from_u64(0);
let mut rng2 = rng1.clone();
rng2.jump();
let mut rng3 = rng2.clone();
rng3.jump();
Trait Implementations
sourceimpl Clone for Xoshiro256PlusPlus
impl Clone for Xoshiro256PlusPlus
sourcefn clone(&self) -> Xoshiro256PlusPlus
fn clone(&self) -> Xoshiro256PlusPlus
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 Xoshiro256PlusPlus
impl Debug for Xoshiro256PlusPlus
sourceimpl PartialEq<Xoshiro256PlusPlus> for Xoshiro256PlusPlus
impl PartialEq<Xoshiro256PlusPlus> for Xoshiro256PlusPlus
sourcefn eq(&self, other: &Xoshiro256PlusPlus) -> bool
fn eq(&self, other: &Xoshiro256PlusPlus) -> bool
This method tests for self
and other
values to be equal, and is used
by ==
. Read more
sourcefn ne(&self, other: &Xoshiro256PlusPlus) -> bool
fn ne(&self, other: &Xoshiro256PlusPlus) -> bool
This method tests for !=
.
sourceimpl RngCore for Xoshiro256PlusPlus
impl RngCore for Xoshiro256PlusPlus
sourceimpl SeedableRng for Xoshiro256PlusPlus
impl SeedableRng for Xoshiro256PlusPlus
sourcefn from_seed(seed: [u8; 32]) -> Xoshiro256PlusPlus
fn from_seed(seed: [u8; 32]) -> Xoshiro256PlusPlus
Create a new Xoshiro256PlusPlus
. If seed
is entirely 0, it will be
mapped to a different seed.
sourcefn seed_from_u64(seed: u64) -> Xoshiro256PlusPlus
fn seed_from_u64(seed: u64) -> Xoshiro256PlusPlus
Seed a Xoshiro256PlusPlus
from a u64
using SplitMix64
.
type Seed = [u8; 32]
type Seed = [u8; 32]
Seed type, which is restricted to types mutably-dereferencable as u8
arrays (we recommend [u8; N]
for some N
). Read more
sourcefn from_rng<R>(rng: R) -> Result<Self, Error> where
R: RngCore,
fn from_rng<R>(rng: R) -> Result<Self, Error> where
R: RngCore,
Create a new PRNG seeded from another Rng
. Read more
sourcefn from_entropy() -> Self
fn from_entropy() -> Self
impl Eq for Xoshiro256PlusPlus
impl StructuralEq for Xoshiro256PlusPlus
impl StructuralPartialEq for Xoshiro256PlusPlus
Auto Trait Implementations
impl RefUnwindSafe for Xoshiro256PlusPlus
impl Send for Xoshiro256PlusPlus
impl Sync for Xoshiro256PlusPlus
impl Unpin for Xoshiro256PlusPlus
impl UnwindSafe for Xoshiro256PlusPlus
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
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more