Struct rand_xoshiro::Xoshiro256StarStar
source · pub struct Xoshiro256StarStar { /* 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 xoshiro256starstar.c
reference source code by
David Blackman and Sebastiano Vigna.
Implementations§
source§impl Xoshiro256StarStar
impl Xoshiro256StarStar
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::Xoshiro256StarStar;
let rng1 = Xoshiro256StarStar::seed_from_u64(0);
let mut rng2 = rng1.clone();
rng2.jump();
let mut rng3 = rng2.clone();
rng3.jump();
Trait Implementations§
source§impl Clone for Xoshiro256StarStar
impl Clone for Xoshiro256StarStar
source§fn clone(&self) -> Xoshiro256StarStar
fn clone(&self) -> Xoshiro256StarStar
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 Xoshiro256StarStar
impl Debug for Xoshiro256StarStar
source§impl PartialEq for Xoshiro256StarStar
impl PartialEq for Xoshiro256StarStar
source§fn eq(&self, other: &Xoshiro256StarStar) -> bool
fn eq(&self, other: &Xoshiro256StarStar) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.source§impl RngCore for Xoshiro256StarStar
impl RngCore for Xoshiro256StarStar
source§fn fill_bytes(&mut self, dest: &mut [u8])
fn fill_bytes(&mut self, dest: &mut [u8])
Fill
dest
with random data. Read moresource§impl SeedableRng for Xoshiro256StarStar
impl SeedableRng for Xoshiro256StarStar
source§fn from_seed(seed: [u8; 32]) -> Xoshiro256StarStar
fn from_seed(seed: [u8; 32]) -> Xoshiro256StarStar
Create a new Xoshiro256StarStar
. If seed
is entirely 0, it will be
mapped to a different seed.
source§fn seed_from_u64(seed: u64) -> Xoshiro256StarStar
fn seed_from_u64(seed: u64) -> Xoshiro256StarStar
Seed a Xoshiro256StarStar
from a u64
using SplitMix64
.
§type Seed = [u8; 32]
type Seed = [u8; 32]
Seed type, which is restricted to types mutably-dereferenceable as
u8
arrays (we recommend [u8; N]
for some N
). Read moresource§fn 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 moresource§fn from_entropy() -> Self
fn from_entropy() -> Self
impl Eq for Xoshiro256StarStar
impl StructuralPartialEq for Xoshiro256StarStar
Auto Trait Implementations§
impl Freeze for Xoshiro256StarStar
impl RefUnwindSafe for Xoshiro256StarStar
impl Send for Xoshiro256StarStar
impl Sync for Xoshiro256StarStar
impl Unpin for Xoshiro256StarStar
impl UnwindSafe for Xoshiro256StarStar
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§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)