Struct sp_runtime::random_number_generator::RandomNumberGenerator [−][src]
pub struct RandomNumberGenerator<Hashing: Hash> { /* fields omitted */ }
Pseudo-random number streamer. This retains the state of the random number stream. It’s as secure as the combination of the seed with which it is constructed and the hash function it uses to cycle elements.
It can be saved and later reloaded using the Codec traits.
Example:
use sp_runtime::traits::{Hash, BlakeTwo256}; use sp_runtime::RandomNumberGenerator; let random_seed = BlakeTwo256::hash(b"Sixty-nine"); let mut rng = <RandomNumberGenerator<BlakeTwo256>>::new(random_seed); assert_eq!(rng.pick_u32(100), 59); assert_eq!(rng.pick_item(&[1, 2, 3]), Some(&1));
This can use any cryptographic Hash
function as the means of entropy-extension, and avoids
needless extensions of entropy.
If you’re persisting it over blocks, be aware that the sequence will start to repeat. This won’t be a practical issue unless you’re using tiny hash types (e.g. 64-bit) and pulling hundred of megabytes of data from it.
Implementations
impl<Hashing: Hash> RandomNumberGenerator<Hashing>
[src]
impl<Hashing: Hash> RandomNumberGenerator<Hashing>
[src]pub fn new(seed: Hashing::Output) -> Self
[src]
A new source of random data.
pub fn pick_u32(&mut self, max: u32) -> u32
[src]
Returns a number at least zero, at most max
.
pub fn pick_usize(&mut self, max: usize) -> usize
[src]
Returns a number at least zero, at most max
.
This returns a usize
, but internally it only uses u32
so avoid consensus problems.
pub fn pick_item<'a, T>(&mut self, items: &'a [T]) -> Option<&'a T>
[src]
Pick a random element from an array of items
.
This is guaranteed to return Some
except in the case that the given array items
is
empty.
Trait Implementations
impl<Hashing: Hash> Decode for RandomNumberGenerator<Hashing> where
Hashing::Output: Decode,
Hashing::Output: Decode,
[src]
impl<Hashing: Hash> Decode for RandomNumberGenerator<Hashing> where
Hashing::Output: Decode,
Hashing::Output: Decode,
[src]impl<Hashing: Hash> Encode for RandomNumberGenerator<Hashing> where
Hashing::Output: Encode,
Hashing::Output: Encode,
[src]
impl<Hashing: Hash> Encode for RandomNumberGenerator<Hashing> where
Hashing::Output: Encode,
Hashing::Output: Encode,
[src]fn encode_to<__CodecOutputEdqy: Output + ?Sized>(
&self,
__codec_dest_edqy: &mut __CodecOutputEdqy
)
[src]
&self,
__codec_dest_edqy: &mut __CodecOutputEdqy
)
pub fn size_hint(&self) -> usize
[src]
pub fn encode(&self) -> Vec<u8, Global>
[src]
pub fn using_encoded<R, F>(&self, f: F) -> R where
F: FnOnce(&[u8]) -> R,
[src]
F: FnOnce(&[u8]) -> R,
pub fn encoded_size(&self) -> usize
[src]
impl<Hashing: Hash> EncodeLike<RandomNumberGenerator<Hashing>> for RandomNumberGenerator<Hashing> where
Hashing::Output: Encode,
Hashing::Output: Encode,
[src]
Hashing::Output: Encode,
Hashing::Output: Encode,
Auto Trait Implementations
impl<Hashing> RefUnwindSafe for RandomNumberGenerator<Hashing> where
<Hashing as Hash>::Output: RefUnwindSafe,
<Hashing as Hash>::Output: RefUnwindSafe,
impl<Hashing> Send for RandomNumberGenerator<Hashing>
impl<Hashing> Sync for RandomNumberGenerator<Hashing>
impl<Hashing> Unpin for RandomNumberGenerator<Hashing> where
<Hashing as Hash>::Output: Unpin,
<Hashing as Hash>::Output: Unpin,
impl<Hashing> UnwindSafe for RandomNumberGenerator<Hashing> where
<Hashing as Hash>::Output: UnwindSafe,
<Hashing as Hash>::Output: UnwindSafe,
Blanket Implementations
impl<T> CheckedConversion for T
[src]
impl<T> CheckedConversion for T
[src]fn checked_from<T>(t: T) -> Option<Self> where
Self: TryFrom<T>,
[src]
Self: TryFrom<T>,
fn checked_into<T>(self) -> Option<T> where
Self: TryInto<T>,
[src]
Self: TryInto<T>,
impl<T> DecodeLimit for T where
T: Decode,
[src]
impl<T> DecodeLimit for T where
T: Decode,
[src]impl<T> Instrument for T
[src]
impl<T> Instrument for T
[src]pub fn instrument(self, span: Span) -> Instrumented<Self>
[src]
pub fn in_current_span(self) -> Instrumented<Self>
[src]
impl<T, Outer> IsWrappedBy<Outer> for T where
T: From<Outer>,
Outer: AsRef<T> + AsMut<T> + From<T>,
[src]
impl<T, Outer> IsWrappedBy<Outer> for T where
T: From<Outer>,
Outer: AsRef<T> + AsMut<T> + From<T>,
[src]impl<T> SaturatedConversion for T
[src]
impl<T> SaturatedConversion for T
[src]pub fn saturated_from<T>(t: T) -> Self where
Self: UniqueSaturatedFrom<T>,
[src]
Self: UniqueSaturatedFrom<T>,
pub fn saturated_into<T>(self) -> T where
Self: UniqueSaturatedInto<T>,
[src]
Self: UniqueSaturatedInto<T>,
impl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
[src]
impl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
[src]pub fn unchecked_into(self) -> T
[src]
impl<T, S> UniqueSaturatedInto<T> for S where
T: Bounded,
S: TryInto<T>,
[src]
impl<T, S> UniqueSaturatedInto<T> for S where
T: Bounded,
S: TryInto<T>,
[src]pub fn unique_saturated_into(self) -> T
[src]
impl<S> Codec for S where
S: Decode + Encode,
[src]
S: Decode + Encode,
impl<'_, '_, T> EncodeLike<&'_ &'_ T> for T where
T: Encode,
[src]
T: Encode,
impl<'_, T> EncodeLike<&'_ T> for T where
T: Encode,
[src]
T: Encode,
impl<'_, T> EncodeLike<&'_ mut T> for T where
T: Encode,
[src]
T: Encode,
impl<T> EncodeLike<Arc<T>> for T where
T: Encode,
[src]
T: Encode,
impl<T> EncodeLike<Box<T, Global>> for T where
T: Encode,
[src]
T: Encode,
impl<T> EncodeLike<Rc<T>> for T where
T: Encode,
[src]
T: Encode,
impl<S> FullCodec for S where
S: Decode + FullEncode,
[src]
S: Decode + FullEncode,
impl<S> FullEncode for S where
S: Encode + EncodeLike<S>,
[src]
S: Encode + EncodeLike<S>,
impl<T> MaybeRefUnwindSafe for T where
T: RefUnwindSafe,
[src]
T: RefUnwindSafe,