[−][src]Struct rand_xoshiro::Xoshiro256PlusPlus
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
impl Xoshiro256PlusPlus
[src]
pub fn jump(&mut self)
[src]
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();
pub fn long_jump(&mut self)
[src]
Jump forward, equivalently to 2^192 calls to next_u64()
.
This can be used to generate 2^64 starting points, from each of which
jump()
will generate 2^64 non-overlapping subsequences for parallel
distributed computations.
Trait Implementations
impl Clone for Xoshiro256PlusPlus
[src]
pub fn clone(&self) -> Xoshiro256PlusPlus
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl Debug for Xoshiro256PlusPlus
[src]
impl Eq for Xoshiro256PlusPlus
[src]
impl PartialEq<Xoshiro256PlusPlus> for Xoshiro256PlusPlus
[src]
pub fn eq(&self, other: &Xoshiro256PlusPlus) -> bool
[src]
pub fn ne(&self, other: &Xoshiro256PlusPlus) -> bool
[src]
impl RngCore for Xoshiro256PlusPlus
[src]
pub fn next_u32(&mut self) -> u32
[src]
pub fn next_u64(&mut self) -> u64
[src]
pub fn fill_bytes(&mut self, dest: &mut [u8])
[src]
pub fn try_fill_bytes(&mut self, dest: &mut [u8]) -> Result<(), Error>
[src]
impl SeedableRng for Xoshiro256PlusPlus
[src]
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
pub fn from_seed(seed: [u8; 32]) -> Xoshiro256PlusPlus
[src]
Create a new Xoshiro256PlusPlus
. If seed
is entirely 0, it will be
mapped to a different seed.
pub fn seed_from_u64(seed: u64) -> Xoshiro256PlusPlus
[src]
Seed a Xoshiro256PlusPlus
from a u64
using SplitMix64
.
pub fn from_rng<R>(rng: R) -> Result<Self, Error> where
R: RngCore,
[src]
R: RngCore,
impl StructuralEq for Xoshiro256PlusPlus
[src]
impl StructuralPartialEq for Xoshiro256PlusPlus
[src]
Auto Trait Implementations
impl Send for Xoshiro256PlusPlus
[src]
impl Sync for Xoshiro256PlusPlus
[src]
impl Unpin for Xoshiro256PlusPlus
[src]
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,