Swiftpack.co - nixberg/chacha-rng-swift as Swift Package

Swiftpack.co is a collection of thousands of indexed Swift packages. Search packages.
See all packages published by nixberg.
nixberg/chacha-rng-swift 0.8.0
ChaCha-based RNG for Swift
⭐️ 0
🕓 3 weeks ago
.package(url: "https://github.com/nixberg/chacha-rng-swift.git", from: "0.8.0")

[Swift](https://raw.github.com/nixberg/chacha-rng-swift/main/ https://github.com/nixberg/chacha-rng-swift/actions/workflows/swift.yaml)

chacha-rng-swift

ChaCha-based [RandomNumberGenerator](https://raw.github.com/nixberg/chacha-rng-swift/main/ https://developer.apple.com/documentation/swift/randomnumbergenerator). Compatible with Rust’s [rand_chacha](https://raw.github.com/nixberg/chacha-rng-swift/main/ https://crates.io/crates/rand_chacha).

Usage

CSRNG

You should almost certainly use SystemRandomNumberGenerator instead.

import ChaChaRNG

var rng = ChaCha8RNG() // Seeded via SystemRandomNumberGenerator, stream: 0.

SIMD2.random(in: 0..<1234, using: &rng)

CSPRNG

var rng = ChaCha8RNG(seed: .zero) // All-zero seed, stream: 0.

Int.random(in: 0..<1234, using: &rng) // 1032

Individual unsigned integers

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

Individual floating-point numbers

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

Fill buffers:

var rng = ChaCha20RNG(seed: .zero)
        
var array = [UInt8](https://raw.github.com/nixberg/chacha-rng-swift/main/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]

GitHub

link
Stars: 0
Last commit: 3 weeks ago
jonrohan Something's broken? Yell at me @ptrpavlik. Praise and feedback (and money) is also welcome.

Release Notes

Swiftpack is being maintained by Petr Pavlik | @ptrpavlik | @swiftpackco | API | Analytics