Struct xoshiro::Xoroshiro128Plus[][src]

pub struct Xoroshiro128Plus { /* fields omitted */ }

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.

Methods

impl Xoroshiro128Plus
[src]

Seed a Xoroshiro128Plus 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::Xoroshiro128Plus;

let rng1 = Xoroshiro128Plus::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 Xoroshiro128Plus
[src]

Formats the value using the given formatter. Read more

impl Clone for Xoroshiro128Plus
[src]

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

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