Fast_Rands: Get (non-cryptographically secure!) Random Numbers Faster.
The faster_rands crate is a collection of a range of fast RNGs, such as RomuRand and others.
It can be used together with LibAFL or any place that needs random numbers, as long as you don't rely on the randomness for security.
Usage
use ;
use NonZeroUsize;
// Create a new random number generator with a random seed
let mut rand = new;
// Get a random u64
let n = rand.next;
// Get a random number below 100
let below_100 = rand.below;
// Get a random number between 50 and 100 (inclusive)
let between_50_and_100 = rand.between;
The LibAFL Project
The LibAFL project is part of AFLplusplus and maintained by
- Andrea Fioraldi andrea@aflplus.plus
- Dominik Maier dominik@aflplus.plus
- s1341 github@shmarya.net
- Dongjia Zhang toka@aflplus.plus
- Addison Crump me@addisoncrump.info
Contributing
For bugs, feel free to open issues or contact us directly. Thank you for your support. <3
Even though we will gladly assist you in finishing up your PR, try to
- keep all the crates compiling with stable rust (hide the eventual non-stable code under
cfgs.) - run
cargo nightly fmton your code before pushing - check the output of
cargo clippy --allor./clippy.sh - run
cargo build --no-default-featuresto check forno_stdcompatibility (and possibly add#[cfg(feature = "std")]) to hide parts of your code.
Some parts in this list may sound hard, but don't be afraid to open a PR if you cannot fix them by yourself. We will gladly assist.