Struct xoshiro::Xoshiro128Plus[][src]

pub struct Xoshiro128Plus { /* fields omitted */ }

A xoshiro128+ random number generator.

The xoshiro128+ 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 xoshiro128starstar.c reference source code by David Blackman and Sebastiano Vigna.

Methods

impl Xoshiro128Plus
[src]

Seed a Xoshiro128Plus 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 Xoshiro128Plus
[src]

Formats the value using the given formatter. Read more

impl Clone for Xoshiro128Plus
[src]

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

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