# rand-bits
[](https://crates.io/crates/rand-bits)
[](https://docs.rs/rand-bits)
[](https://github.com/ventaquil/rand-bits/blob/master/Cargo.toml)
[](https://deps.rs/crate/rand-bits/0.0.0)
[](https://github.com/rust-secure-code/safety-dance)
[](https://github.com/ventaquil/rand-bits/blob/master/LICENSE)
Random number generators with a fixed number of set bits (ones).
## Setup
Add the following entry to the `dependencies` section of your `Cargo.toml` file:
```toml
[dependencies]
rand-bits = "0.0.0"
```
Alternatively, you can use the [`cargo add`](https://doc.rust-lang.org/cargo/commands/cargo-add.html) subcommand:
```shell
cargo add rand-bits
```
## Usage
```rust
use rand::thread_rng;
use rand_bits::RngBits;
let mut rng = thread_rng();
let x: u8 = rng.gen_bits(4); // generates a u8 with 4 set bits
assert_eq!(x.count_ones(), 4);
let y: u16 = rng.gen_bits(15); // generates a u16 with 15 set bits
assert_eq!(y.count_ones(), 15);
let z: u64 = rng.gen_bits(1); // generates a u64 with 1 set bits
assert_eq!(z.count_ones(), 1);
```
For more usage examples, refer to the documentation available at [docs.rs](https://docs.rs/rand-bits).
## License
This crate is licensed under the MIT License.