Struct xoshiro::Xoroshiro128StarStar[][src]

pub struct Xoroshiro128StarStar { /* fields omitted */ }

A xoroshiro128** random number generator.

The xoroshiro128** algorithm is not suitable for cryptographic purposes, but is very fast and has excellent statistical properties.

The algorithm used here is translated from the xoroshiro128starstar.c reference source code by David Blackman and Sebastiano Vigna.

Methods

impl Xoroshiro128StarStar
[src]

Seed a Xoroshiro128StarStar from a u64 using SplitMix64.

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::SeedableRng;
use xoshiro::Xoroshiro128StarStar;

let rng1 = Xoroshiro128StarStar::from_seed_u64(0);
let mut rng2 = rng1.clone();
rng2.jump();
let mut rng3 = rng2.clone();
rng3.jump();

Jump forward, equivalently to 2^96 calls to next_u64().

This can be used to generate 2^32 starting points, from each of which jump() will generate 2^32 non-overlapping subsequences for parallel distributed computations.

Trait Implementations

impl Debug for Xoroshiro128StarStar
[src]

Formats the value using the given formatter. Read more

impl Clone for Xoroshiro128StarStar
[src]

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

impl RngCore for Xoroshiro128StarStar
[src]

Return the next random u32. Read more

Return the next random u64. Read more

Fill dest with random data. Read more

Fill dest entirely with random data. Read more

impl SeedableRng for Xoroshiro128StarStar
[src]

Seed type, which is restricted to types mutably-dereferencable as u8 arrays (we recommend [u8; N] for some N). Read more

Create a new Xoroshiro128StarStar. If seed is entirely 0, it will be mapped to a different seed.

Create a new PRNG seeded from another Rng. Read more

Auto Trait Implementations