[−][src]Struct rand::ChaChaRng
A random number generator that uses the ChaCha20 algorithm [1].
The ChaCha algorithm is widely accepted as suitable for
cryptographic purposes, but this implementation has not been
verified as such. Prefer a generator like OsRng that defers to
the operating system for cases that need high security.
[1]: D. J. Bernstein, ChaCha, a variant of Salsa20
Methods
impl ChaChaRng[src]
impl ChaChaRngpub fn new_unseeded() -> ChaChaRng[src]
pub fn new_unseeded() -> ChaChaRngCreate an ChaCha random number generator using the default fixed key of 8 zero words.
Examples
use rand::{Rng, ChaChaRng}; let mut ra = ChaChaRng::new_unseeded(); println!("{:?}", ra.next_u32()); println!("{:?}", ra.next_u32());
Since this equivalent to a RNG with a fixed seed, repeated executions of an unseeded RNG will produce the same result. This code sample will consistently produce:
- 2917185654
- 2419978656
pub fn set_counter(&mut self, counter_low: u64, counter_high: u64)[src]
pub fn set_counter(&mut self, counter_low: u64, counter_high: u64)Sets the internal 128-bit ChaCha counter to a user-provided value. This permits jumping arbitrarily ahead (or backwards) in the pseudorandom stream.
Since the nonce words are used to extend the counter to 128 bits,
users wishing to obtain the conventional ChaCha pseudorandom stream
associated with a particular nonce can call this function with
arguments 0, desired_nonce.
Examples
use rand::{Rng, ChaChaRng}; let mut ra = ChaChaRng::new_unseeded(); ra.set_counter(0u64, 1234567890u64); println!("{:?}", ra.next_u32()); println!("{:?}", ra.next_u32());
Trait Implementations
impl Rand for ChaChaRng[src]
impl Rand for ChaChaRngimpl Rng for ChaChaRng[src]
impl Rng for ChaChaRngfn next_u32(&mut self) -> u32[src]
fn next_u32(&mut self) -> u32fn next_u64(&mut self) -> u64[src]
fn next_u64(&mut self) -> u64Return the next random u64. Read more
fn next_f32(&mut self) -> f32[src]
fn next_f32(&mut self) -> f32Return the next random f32 selected from the half-open interval [0, 1). Read more
fn next_f64(&mut self) -> f64[src]
fn next_f64(&mut self) -> f64Return the next random f64 selected from the half-open interval [0, 1). Read more
fn fill_bytes(&mut self, dest: &mut [u8])[src]
fn fill_bytes(&mut self, dest: &mut [u8])Fill dest with random data. Read more
fn gen<T: Rand>(&mut self) -> T where
Self: Sized, [src]
fn gen<T: Rand>(&mut self) -> T where
Self: Sized, Return a random value of a Rand type. Read more
ⓘImportant traits for Generator<'a, T, R>fn gen_iter<'a, T: Rand>(&'a mut self) -> Generator<'a, T, Self> where
Self: Sized, [src]
fn gen_iter<'a, T: Rand>(&'a mut self) -> Generator<'a, T, Self> where
Self: Sized, Return an iterator that will yield an infinite number of randomly generated items. Read more
fn gen_range<T: PartialOrd + SampleRange>(&mut self, low: T, high: T) -> T where
Self: Sized, [src]
fn gen_range<T: PartialOrd + SampleRange>(&mut self, low: T, high: T) -> T where
Self: Sized, Generate a random value in the range [low, high). Read more
fn gen_weighted_bool(&mut self, n: u32) -> bool where
Self: Sized, [src]
fn gen_weighted_bool(&mut self, n: u32) -> bool where
Self: Sized, Return a bool with a 1 in n chance of true Read more
ⓘImportant traits for AsciiGenerator<'a, R>fn gen_ascii_chars<'a>(&'a mut self) -> AsciiGenerator<'a, Self> where
Self: Sized, [src]
fn gen_ascii_chars<'a>(&'a mut self) -> AsciiGenerator<'a, Self> where
Self: Sized, Return an iterator of random characters from the set A-Z,a-z,0-9. Read more
fn choose<'a, T>(&mut self, values: &'a [T]) -> Option<&'a T> where
Self: Sized, [src]
fn choose<'a, T>(&mut self, values: &'a [T]) -> Option<&'a T> where
Self: Sized, Return a random element from values. Read more
fn choose_mut<'a, T>(&mut self, values: &'a mut [T]) -> Option<&'a mut T> where
Self: Sized, [src]
fn choose_mut<'a, T>(&mut self, values: &'a mut [T]) -> Option<&'a mut T> where
Self: Sized, Return a mutable pointer to a random element from values. Read more
fn shuffle<T>(&mut self, values: &mut [T]) where
Self: Sized, [src]
fn shuffle<T>(&mut self, values: &mut [T]) where
Self: Sized, Shuffle a mutable slice in place. Read more
impl<'a> SeedableRng<&'a [u32]> for ChaChaRng[src]
impl<'a> SeedableRng<&'a [u32]> for ChaChaRngfn reseed(&mut self, seed: &'a [u32])[src]
fn reseed(&mut self, seed: &'a [u32])fn from_seed(seed: &'a [u32]) -> ChaChaRng[src]
fn from_seed(seed: &'a [u32]) -> ChaChaRngCreate a ChaCha generator from a seed, obtained from a variable-length u32 array. Only up to 8 words are used; if less than 8 words are used, the remaining are set to zero.
impl Clone for ChaChaRng[src]
impl Clone for ChaChaRngfn clone(&self) -> ChaChaRng[src]
fn clone(&self) -> ChaChaRngfn clone_from(&mut self, source: &Self)1.0.0[src]
fn clone_from(&mut self, source: &Self)Performs copy-assignment from source. Read more
impl Copy for ChaChaRng[src]
impl Copy for ChaChaRngimpl Debug for ChaChaRng[src]
impl Debug for ChaChaRngAuto Trait Implementations
Blanket Implementations
impl<T> From for T[src]
impl<T> From for Timpl<T, U> Into for T where
U: From<T>, [src]
impl<T, U> Into for T where
U: From<T>, impl<T> ToOwned for T where
T: Clone, [src]
impl<T> ToOwned for T where
T: Clone, impl<T, U> TryFrom for T where
T: From<U>, [src]
impl<T, U> TryFrom for T where
T: From<U>, type Error = !
try_from)The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>impl<T> Borrow for T where
T: ?Sized, [src]
impl<T> Borrow for T where
T: ?Sized, impl<T> BorrowMut for T where
T: ?Sized, [src]
impl<T> BorrowMut for T where
T: ?Sized, fn borrow_mut(&mut self) -> &mut T[src]
fn borrow_mut(&mut self) -> &mut Timpl<T, U> TryInto for T where
U: TryFrom<T>, [src]
impl<T, U> TryInto for T where
U: TryFrom<T>, type Error = <U as TryFrom<T>>::Error
try_from)The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>impl<T> Any for T where
T: 'static + ?Sized, [src]
impl<T> Any for T where
T: 'static + ?Sized, fn get_type_id(&self) -> TypeId[src]
fn get_type_id(&self) -> TypeId