Struct rand_xoshiro::Xoshiro256Plus [−][src]
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
impl Xoshiro256Plus
[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::Xoshiro256Plus; let rng1 = Xoshiro256Plus::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 Xoshiro256Plus
[src]
fn clone(&self) -> Xoshiro256Plus
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl Debug for Xoshiro256Plus
[src]
impl RngCore for Xoshiro256Plus
[src]
fn next_u32(&mut self) -> u32
[src]
fn next_u64(&mut self) -> u64
[src]
fn fill_bytes(&mut self, dest: &mut [u8])
[src]
fn try_fill_bytes(&mut self, dest: &mut [u8]) -> Result<(), Error>
[src]
impl SeedableRng for Xoshiro256Plus
[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
fn from_seed(seed: [u8; 32]) -> Xoshiro256Plus
[src]
Create a new Xoshiro256Plus
. If seed
is entirely 0, it will be
mapped to a different seed.
fn seed_from_u64(seed: u64) -> Xoshiro256Plus
[src]
Seed a Xoshiro256Plus
from a u64
using SplitMix64
.
pub fn from_rng<R>(rng: R) -> Result<Self, Error> where
R: RngCore,
[src]
R: RngCore,
pub fn from_entropy() -> Self
[src]
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
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> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn clone_into(&self, target: &mut T)
[src]
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>,