Struct xoshiro::Xoshiro256StarStar[][src]

pub struct Xoshiro256StarStar { /* fields omitted */ }

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.

Methods

impl Xoshiro256StarStar
[src]

Seed a Xoshiro256StarStar from a u64 using SplitMix64.

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

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

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 Debug for Xoshiro256StarStar
[src]

Formats the value using the given formatter. Read more

impl Clone for Xoshiro256StarStar
[src]

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

impl SeedableRng for Xoshiro256StarStar
[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 Xoshiro256StarStar. If seed is entirely 0, it will be mapped to a different seed.

Create a new PRNG seeded from another Rng. Read more

impl RngCore for Xoshiro256StarStar
[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

Auto Trait Implementations