Skip to main content

SplitMix64

Struct SplitMix64 

Source
pub struct SplitMix64 { /* private fields */ }
Expand description

๐ŸŽฒ SplitMix64 pseudo-random number generator.


๐Ÿ“ num/prob/rand


A small 64-bit-state generator useful for seed expansion, simple streams, and diffusing weak seed material.

This is not a cryptographic generator.

Implementationsยง

Sourceยง

impl SplitMix64

Source

pub const GOLDEN_GAMMA: u64 = 0x9E37_79B9_7F4A_7C15

Weyl increment derived from the 64-bit fractional golden ratio.

Source

pub const MIX_A: u64 = 0xBF58_476D_1CE4_E5B9

First SplitMix64 avalanche multiplier.

Source

pub const MIX_B: u64 = 0x94D0_49BB_1331_11EB

Second SplitMix64 avalanche multiplier.

Source

pub const fn new(seed: u64) -> Self

Creates a new generator from a 64-bit state.

Source

pub const fn mix64(x: u64) -> u64

Applies the SplitMix64 output mixer.

Source

pub const fn next_u64(&mut self) -> u64

Advances the state and returns the next value.

Source

pub const fn fill_bytes(&mut self, buffer: &mut [u8])

Fills the buffer with generated bytes.

Trait Implementationsยง

Sourceยง

impl Clone for SplitMix64

Sourceยง

fn clone(&self) -> SplitMix64

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) ยท Sourceยง

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Sourceยง

impl ConstInit for SplitMix64

Provides a fixed default initialized value.

Sourceยง

const INIT: Self

Returns the compile-time โ€œinitial valueโ€ for a type.
Sourceยง

impl Copy for SplitMix64

Sourceยง

impl Debug for SplitMix64

Sourceยง

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Sourceยง

impl Default for SplitMix64

Creates SplitMix64::INIT as the default value.

Sourceยง

fn default() -> Self

Returns the โ€œdefault valueโ€ for a type. Read more
Sourceยง

impl Eq for SplitMix64

Sourceยง

impl PartialEq for SplitMix64

Sourceยง

fn eq(&self, other: &SplitMix64) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Sourceยง

impl RandSeedable for SplitMix64

Sourceยง

type RandSeed = [u8; 8]

Byte-backed seed material accepted by this type.
Sourceยง

fn rand_from_seed(seed: Self::RandSeed) -> Self

Constructs this type from explicit seed material.
Sourceยง

fn rand_try_from_source<R>(source: &mut R) -> Result<Self, R::Error> โ“˜
where R: RandTry + ?Sized,

Attempts to construct this type by drawing seed material from source.
Sourceยง

fn rand_from_source<R>(source: &mut R) -> Self
where R: Rand + ?Sized,

Constructs this type by drawing seed material from an infallible source.
Sourceยง

impl RandTry for SplitMix64

Sourceยง

const RAND_OUTPUT_BITS: u32 = 64

Number of bits produced per output step. Read more
Sourceยง

const RAND_STATE_BITS: u32 = 64

Size of the source state owned by this value, in bits. Read more
Sourceยง

const RAND_QUALITIES: RandQualities = RandQualities::PRNG

Semantic qualities of this random source.
Sourceยง

type Error = Infallible

Error returned when complete random data could not be produced.
Sourceยง

fn rand_try_next_u64(&mut self) -> InfallibleResult<u64>

Attempts to produce the next 64 bits of randomness.
Sourceยง

fn rand_try_fill_bytes(&mut self, buffer: &mut [u8]) -> InfallibleResult<()>

Attempts to fill the buffer with generated bytes. Read more
Sourceยง

fn rand_qualities(&self) -> RandQualities

Returns the semantic qualities of this random source.
Sourceยง

fn rand_try_next_u128(&mut self) -> Result<u128, Self::Error> โ“˜

Attempts to produce the next random u128.
Sourceยง

fn rand_try_next_u32(&mut self) -> Result<u32, Self::Error> โ“˜

Attempts to produce the next random u32.
Sourceยง

fn rand_try_next_u16(&mut self) -> Result<u16, Self::Error> โ“˜

Attempts to produce the next random u16.
Sourceยง

fn rand_try_next_u8(&mut self) -> Result<u8, Self::Error> โ“˜

Attempts to produce the next random u8.
Sourceยง

fn rand_try_next_bool(&mut self) -> Result<bool, Self::Error> โ“˜

Attempts to produce a random boolean.
Sourceยง

fn rand_try_below(&mut self, upper: u64) -> Result<u64, Self::Error> โ“˜

Attempts to return a uniformly random integer in 0..upper. Read more
Sourceยง

fn rand_try_range(&mut self, low: u64, high: u64) -> Result<u64, Self::Error> โ“˜

Attempts to return a uniformly random integer in low..high. Read more
Sourceยง

fn rand_try_roll(&mut self, sides: u64) -> Result<u64, Self::Error> โ“˜

Attempts to roll a fair die with a number of sides. Read more
Sourceยง

fn rand_try_shuffle<T>(&mut self, slice: &mut [T]) -> Result<(), Self::Error> โ“˜

Attempts to shuffle the elements of the slice in place. Read more
Sourceยง

fn rand_try_choose_reservoir<I, F>( &mut self, iter: I, valid: F, ) -> Result<Option<I::Item>, Self::Error> โ“˜
where I: IntoIterator, F: FnMut(&I::Item) -> bool,

Attempts to choose one valid item using reservoir sampling. Read more
Sourceยง

fn rand_try_choose_scored<I, F>( &mut self, iter: I, valid: F, ) -> Result<Option<I::Item>, Self::Error> โ“˜
where I: IntoIterator, F: FnMut(&I::Item) -> bool,

Attempts to choose one valid item using random scores. Read more
Sourceยง

impl SeedableRng for SplitMix64

Available on crate feature dep_rand_core only.
Sourceยง

type Seed = <SplitMix64 as RandSeedable>::RandSeed

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

fn from_seed(seed: Self::Seed) -> Self

Create a new PRNG using the given seed. Read more
ยง

fn seed_from_u64(state: u64) -> Self

Create a new PRNG using a u64 seed. Read more
ยง

fn from_rng<R>(rng: &mut R) -> Self
where R: Rng + ?Sized,

Create a new PRNG seeded from an infallible Rng. Read more
ยง

fn try_from_rng<R>(rng: &mut R) -> Result<Self, <R as TryRng>::Error> โ“˜
where R: TryRng + ?Sized,

Create a new PRNG seeded from a potentially fallible Rng. Read more
ยง

fn fork(&mut self) -> Self
where Self: Rng,

Fork this PRNG Read more
ยง

fn try_fork(&mut self) -> Result<Self, Self::Error> โ“˜
where Self: TryRng,

Fork this PRNG Read more
Sourceยง

impl StructuralPartialEq for SplitMix64

Sourceยง

impl TryRng for SplitMix64

Available on crate feature dep_rand_core only.
Sourceยง

type Error = <SplitMix64 as RandTry>::Error

The type returned in the event of a RNG error. Read more
Sourceยง

fn try_next_u32(&mut self) -> Result<u32, Self::Error> โ“˜

Return the next random u32.
Sourceยง

fn try_next_u64(&mut self) -> Result<u64, Self::Error> โ“˜

Return the next random u64.
Sourceยง

fn try_fill_bytes(&mut self, dst: &mut [u8]) -> Result<(), Self::Error> โ“˜

Fill dst entirely with random data.

Auto Trait Implementationsยง

Blanket Implementationsยง

Sourceยง

impl<T> Any for T
where T: 'static + ?Sized,

Sourceยง

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Sourceยง

impl<T> AnyExt for T
where T: Any + ?Sized,

Sourceยง

fn type_id() -> TypeId

Returns the TypeId of Self. Read more
Sourceยง

fn type_of(&self) -> TypeId

Returns the TypeId of self. Read more
Sourceยง

fn type_name(&self) -> &'static str โ“˜

Returns the type name of self. Read more
Sourceยง

fn type_is<T: 'static>(&self) -> bool

Returns true if Self is of type T. Read more
Sourceยง

fn type_hash(&self) -> u64

Returns a deterministic hash of the TypeId of Self.
Sourceยง

fn type_hash_with<H: Hasher>(&self, hasher: H) -> u64

Returns a deterministic hash of the TypeId of Self using a custom hasher.
Sourceยง

fn as_any_ref(&self) -> &dyn Any
where Self: Sized,

Upcasts &self as &dyn Any. Read more
Sourceยง

fn as_any_mut(&mut self) -> &mut dyn Any
where Self: Sized,

Upcasts &mut self as &mut dyn Any. Read more
Sourceยง

fn as_any_box(self: Box<Self>) -> Box<dyn Any>
where Self: Sized,

Available on crate feature alloc only.
Upcasts Box<self> as Box<dyn Any>. Read more
Sourceยง

fn downcast_ref<T: 'static>(&self) -> Option<&T> โ“˜

Available on crate feature unsafe_layout and non-crate feature safe_code only.
Returns some shared reference to the inner value if it is of type T. Read more
Sourceยง

fn downcast_mut<T: 'static>(&mut self) -> Option<&mut T> โ“˜

Available on crate feature unsafe_layout and non-crate feature safe_code only.
Returns some exclusive reference to the inner value if it is of type T. Read more
Sourceยง

impl<T> Borrow<T> for T
where T: ?Sized,

Sourceยง

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Sourceยง

impl<T> BorrowMut<T> for T
where T: ?Sized,

Sourceยง

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Sourceยง

impl<T> ByteSized for T

Sourceยง

const BYTE_ALIGN: usize = _

The alignment of this type in bytes.
Sourceยง

const BYTE_SIZE: usize = _

The size of this type in bytes.
Sourceยง

fn byte_align(&self) -> usize

Returns the alignment of this type in bytes.
Sourceยง

fn byte_size(&self) -> usize

Returns the size of this type in bytes. Read more
Sourceยง

fn ptr_size_ratio(&self) -> [usize; 2]

Returns the size ratio between Ptr::BYTES and BYTE_SIZE. Read more
Sourceยง

impl<T> CloneToUninit for T
where T: Clone,

Sourceยง

unsafe fn clone_to_uninit(&self, dest: *mut u8)

๐Ÿ”ฌThis is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
ยง

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

ยง

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Sourceยง

impl<T> From<T> for T

Sourceยง

fn from(t: T) -> T

Returns the argument unchanged.

Sourceยง

impl<T> Hook for T

Sourceยง

fn hook<F>(self, f: F) -> Self
where F: FnOnce(&mut Self),

Hooks a mutation step into the value and returns it. Read more
Sourceยง

fn tap<F>(self, f: F) -> Self
where F: FnOnce(&Self),

Taps into the value for observation and returns it unchanged. Read more
Sourceยง

impl<T, U> Into<U> for T
where U: From<T>,

Sourceยง

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Sourceยง

impl<T> MemExt for T
where T: ?Sized,

Sourceยง

const NEEDS_DROP: bool = _

Know whether dropping values of this type matters, in compile-time.
Sourceยง

fn mem_align_of<T>() -> usize

Returns the minimum alignment of the type in bytes. Read more
Sourceยง

fn mem_align_of_val(&self) -> usize

Returns the alignment of the pointed-to value in bytes. Read more
Sourceยง

fn mem_size_of<T>() -> usize

Returns the size of a type in bytes. Read more
Sourceยง

fn mem_size_of_val(&self) -> usize

Returns the size of the pointed-to value in bytes. Read more
Sourceยง

fn mem_copy(&self) -> Self
where Self: Copy,

Bitwise-copies a value. Read more
Sourceยง

fn mem_needs_drop(&self) -> bool

Returns true if dropping values of this type matters. Read more
Sourceยง

fn mem_drop(self)
where Self: Sized,

Drops self by running its destructor. Read more
Sourceยง

fn mem_forget(self)
where Self: Sized,

Forgets about self without running its destructor. Read more
Sourceยง

fn mem_replace(&mut self, other: Self) -> Self
where Self: Sized,

Replaces self with other, returning the previous value of self. Read more
Sourceยง

fn mem_take(&mut self) -> Self
where Self: Default,

Replaces self with its default value, returning the previous value of self. Read more
Sourceยง

fn mem_swap(&mut self, other: &mut Self)
where Self: Sized,

Swaps the value of self and other without deinitializing either one. Read more
Sourceยง

unsafe fn mem_zeroed<T>() -> T

Available on crate feature unsafe_layout only.
Returns the value of type T represented by the all-zero byte-pattern. Read more
Sourceยง

unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst

Available on crate feature unsafe_layout only.
Returns the value of type T represented by the all-zero byte-pattern. Read more
Sourceยง

fn mem_as_bytes(&self) -> &[u8] โ“˜
where Self: Sync + Unpin,

Available on crate feature unsafe_slice only.
View a Sync + Unpin self as &[u8]. Read more
Sourceยง

fn mem_as_bytes_mut(&mut self) -> &mut [u8] โ“˜
where Self: Sync + Unpin,

Available on crate feature unsafe_slice only.
View a Sync + Unpin self as &mut [u8]. Read more
Sourceยง

impl<T, R> Morph<R> for T
where T: ?Sized,

Sourceยง

fn morph<F>(self, f: F) -> R
where F: FnOnce(Self) -> R, Self: Sized,

Morphs the value into a new one and returns it. Read more
Sourceยง

fn morph_ref<F>(&self, f: F) -> R
where F: FnOnce(&Self) -> R,

Morphs the value by shared reference and returns the result. Read more
Sourceยง

fn morph_mut<F>(&mut self, f: F) -> R
where F: FnOnce(&mut Self) -> R,

Morphs the value by exclusive reference and returns the result. Read more
Sourceยง

impl<R> Rand for R
where R: RandTry<Error = Infallible> + ?Sized,

Sourceยง

fn rand_next_u128(&mut self) -> u128

Returns the next random u128.
Sourceยง

fn rand_next_u64(&mut self) -> u64

Returns the next random u64.
Sourceยง

fn rand_next_u32(&mut self) -> u32

Returns the next random u32.
Sourceยง

fn rand_next_u16(&mut self) -> u16

Returns the next random u16.
Sourceยง

fn rand_next_u8(&mut self) -> u8

Returns the next random u8.
Sourceยง

fn rand_next_bool(&mut self) -> bool

Produces a random boolean.
Sourceยง

fn rand_fill_bytes(&mut self, buf: &mut [u8])

Fills the buffer with generated bytes.
Sourceยง

fn rand_below(&mut self, upper: u64) -> u64

Returns a uniformly random integer in 0..upper. Read more
Sourceยง

fn rand_range(&mut self, low: u64, high: u64) -> u64

Returns a uniformly random integer in low..high. Read more
Sourceยง

fn rand_roll(&mut self, sides: u64) -> u64

Rolls a fair die with a number of sides. Read more
Sourceยง

fn rand_shuffle<T>(&mut self, slice: &mut [T])

Shuffles the elements of the slice in place. Read more
Sourceยง

fn rand_choose_reservoir<I, F>(&mut self, iter: I, valid: F) -> Option<I::Item> โ“˜
where I: IntoIterator, F: FnMut(&I::Item) -> bool,

Chooses one valid item using reservoir sampling. Read more
Sourceยง

fn rand_choose_scored<I, F>(&mut self, iter: I, valid: F) -> Option<I::Item> โ“˜
where I: IntoIterator, F: FnMut(&I::Item) -> bool,

Chooses one valid item using random scores. Read more
ยง

impl<R> Rng for R
where R: TryRng<Error = Infallible> + ?Sized,

ยง

fn next_u32(&mut self) -> u32

Return the next random u32.
ยง

fn next_u64(&mut self) -> u64

Return the next random u64.
ยง

fn fill_bytes(&mut self, dst: &mut [u8])

Fill dest with random data. Read more
ยง

impl<R> RngCore for R
where R: Rng,

Sourceยง

impl<T> ToOwned for T
where T: Clone,

Sourceยง

type Owned = T

The resulting type after obtaining ownership.
Sourceยง

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Sourceยง

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Sourceยง

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Sourceยง

type Error = Infallible

The type returned in the event of a conversion error.
Sourceยง

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error> โ“˜

Performs the conversion.
Sourceยง

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Sourceยง

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Sourceยง

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error> โ“˜

Performs the conversion.
ยง

impl<R> TryRngCore for R
where R: TryRng,

ยง

type Error = <R as TryRng>::Error

๐Ÿ‘ŽDeprecated since 0.10.0:

use TryRng instead

Error type.