ChaCha-based RandomNumberGenerator
.
Compatible with Rust’s rand_chacha.
You should almost certainly use SystemRandomNumberGenerator
instead.
import ChaChaRNG
var rng = ChaCha8RNG() // Seeded via SystemRandomNumberGenerator, stream: 0.
SIMD2.random(in: 0..<1234, using: &rng)
var rng = ChaCha8RNG(seed: .zero) // All-zero seed, stream: 0.
Int.random(in: 0..<1234, using: &rng) // 1032
var rng = ChaCha20RNG(seed: .zero)
rng.next() as UInt8 // 118
rng.next() as UInt16 // 61856
rng.next() as UInt32 // 3848953152
rng.next() as UInt64 // 13265865887270667859
Equivalent Rust:
let mut rng = ChaChaRng::from_seed([0u8; 32]);
println!("{}", rng.gen::<u8>()); // 118
println!("{}", rng.gen::<u16>()); // 61856
println!("{}", rng.gen::<u32>()); // 3848953152
println!("{}", rng.gen::<u64>()); // 13265865887270667859
var rng = ChaCha20RNG(seed: .zero)
rng.next() as Float16 // Only supported on some hardware.
rng.next() as Float32 // 0.56344515
rng.next() as Float64 // 0.15914191768880792
Equivalent Rust:
let mut rng = ChaChaRng::from_seed([0u8; 32]);
println!("{}", rng.gen::<f32>()); // 0.6792102
println!("{}", rng.gen::<f32>()); // 0.56344515
println!("{}", rng.gen::<f64>()); // 0.15914191768880792
var rng = ChaCha20RNG(seed: .zero)
var array = [UInt8](repeating: 0, count: 5)
array.withUnsafeMutableBytes {
rng.fill($0)
}
array // [118, 184, 224, 173, 160]
Equivalent Rust:
let mut rng = ChaChaRng::from_seed([0u8; 32]);
let mut array = [0u8; 5];
rng.fill(&mut a[..]);
println!("{:?}", array); // [118, 184, 224, 173, 160]