Struct rand_xoshiro::Xoroshiro128Plus
source · pub struct Xoroshiro128Plus { /* private fields */ }
Expand description
A xoroshiro128+ random number generator.
The xoroshiro128+ 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 xoroshiro128plus.c
reference source code by
David Blackman and Sebastiano Vigna.
Implementations§
source§impl Xoroshiro128Plus
impl Xoroshiro128Plus
sourcepub fn jump(&mut self)
pub fn jump(&mut self)
Jump forward, equivalently to 2^64 calls to next_u64()
.
This can be used to generate 2^64 non-overlapping subsequences for parallel computations.
use rand_xoshiro::rand_core::SeedableRng;
use rand_xoshiro::Xoroshiro128Plus;
let rng1 = Xoroshiro128Plus::seed_from_u64(0);
let mut rng2 = rng1.clone();
rng2.jump();
let mut rng3 = rng2.clone();
rng3.jump();
Trait Implementations§
source§impl Clone for Xoroshiro128Plus
impl Clone for Xoroshiro128Plus
source§fn clone(&self) -> Xoroshiro128Plus
fn clone(&self) -> Xoroshiro128Plus
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 Xoroshiro128Plus
impl Debug for Xoroshiro128Plus
source§impl PartialEq for Xoroshiro128Plus
impl PartialEq for Xoroshiro128Plus
source§fn eq(&self, other: &Xoroshiro128Plus) -> bool
fn eq(&self, other: &Xoroshiro128Plus) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.source§impl RngCore for Xoroshiro128Plus
impl RngCore for Xoroshiro128Plus
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 Xoroshiro128Plus
impl SeedableRng for Xoroshiro128Plus
source§fn from_seed(seed: [u8; 16]) -> Xoroshiro128Plus
fn from_seed(seed: [u8; 16]) -> Xoroshiro128Plus
Create a new Xoroshiro128Plus
. If seed
is entirely 0, it will be
mapped to a different seed.
source§fn seed_from_u64(seed: u64) -> Xoroshiro128Plus
fn seed_from_u64(seed: u64) -> Xoroshiro128Plus
Seed a Xoroshiro128Plus
from a u64
using SplitMix64
.
§type Seed = [u8; 16]
type Seed = [u8; 16]
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 Xoroshiro128Plus
impl StructuralPartialEq for Xoroshiro128Plus
Auto Trait Implementations§
impl Freeze for Xoroshiro128Plus
impl RefUnwindSafe for Xoroshiro128Plus
impl Send for Xoroshiro128Plus
impl Sync for Xoroshiro128Plus
impl Unpin for Xoroshiro128Plus
impl UnwindSafe for Xoroshiro128Plus
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
)