Struct xoshiro::Xoshiro128StarStar[][src]

pub struct Xoshiro128StarStar { /* fields omitted */ }

A xoshiro128** random number generator.

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

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

Methods

impl Xoshiro128StarStar
[src]

Seed a Xoshiro128StarStar from a u64 using SplitMix64.

Jump forward, equivalently to 2^64 calls to next_u32().

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();

Trait Implementations

impl Debug for Xoshiro128StarStar
[src]

Formats the value using the given formatter. Read more

impl Clone for Xoshiro128StarStar
[src]

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

impl SeedableRng for Xoshiro128StarStar
[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 Xoshiro128StarStar. 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 Xoshiro128StarStar
[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