Crates.io | QuantumRandom |
lib.rs | QuantumRandom |
version | 0.2.0 |
source | src |
created_at | 2019-02-25 19:48:11.394108 |
updated_at | 2019-03-17 01:03:17.464801 |
description | This is the rust implementation of the ANU Quantum Random Number System. You can easily generate an arbitrary number of u8's, u16's, u32's, u64's, and u128's |
homepage | https://github.com/tbraun96/quantumrandom |
repository | |
max_upload_size | |
id | 117181 |
size | 6,692 |
A Rust quantum-random number generator
All credit goes to qrng.anu.edu.au for the source of quantum-random data
The ANU rng is a nearly perfect random number generator. I take the data and mix it with the rand rng library to help increase entropy in the case that the HTTPS download stream is comprimised remotely; in that case, the data would be modified based on local parameters anyways, and as such, wouldn't matter if the data is comprimised remotely.
The ANU API limits requests to 1024 random numbers at a time per connection*. This program allows you to retrieve more than that.
extern crate QuantumRandom;
let mut idx = 0;
let loop_display = match QuantumRandom::random::next_u128s(40) {
Some(T) => T,
_ => panic!("Please check your internet connection. Halting execution")
}.into_iter().for_each( |value| {
println!("[{}] {}", idx, value);
idx = idx+1;
});
You may view my website here: https://thomaspbraun.com/