hashbrown 0.17.1

A Rust port of Google's SwissTable hash map
Documentation
//! This file contains benchmarks for the ops traits implemented by HashSet.
//! Each test is intended to have a defined larger and smaller set,
//! but using a larger size for the "small" set works just as well.
//!
//! Each assigning test is done in the configuration that is faster. Cheating, I know.
//! The exception to this is Sub, because there the result differs. So I made two benchmarks for Sub.
use criterion::Criterion;
use hashbrown::HashSet;

/// The number of items to generate for the larger of the sets.
const LARGE_SET_SIZE: usize = 1000;

/// The number of items to generate for the smaller of the sets.
const SMALL_SET_SIZE: usize = 100;

/// The number of keys present in both sets.
const OVERLAP: usize =
    [LARGE_SET_SIZE, SMALL_SET_SIZE][(LARGE_SET_SIZE < SMALL_SET_SIZE) as usize] / 2;

/// Creates a set containing end - start unique string elements.
fn create_set(start: usize, end: usize) -> HashSet<String> {
    (start..end).map(|nr| format!("key{nr}")).collect()
}

pub(crate) fn register_benches(c: &mut Criterion) {
    let large_set = create_set(0, LARGE_SET_SIZE);
    let small_set = create_set(
        LARGE_SET_SIZE - OVERLAP,
        LARGE_SET_SIZE + SMALL_SET_SIZE - OVERLAP,
    );

    c.bench_function("set_ops_bit_or", |b| {
        b.iter(|| &large_set | &small_set);
    });

    c.bench_function("set_ops_bit_and", |b| {
        b.iter(|| &large_set & &small_set);
    });

    c.bench_function("set_ops_bit_xor", |b| {
        b.iter(|| &large_set ^ &small_set);
    });

    c.bench_function("set_ops_sub_large_small", |b| {
        b.iter(|| &large_set - &small_set);
    });

    c.bench_function("set_ops_sub_small_large", |b| {
        b.iter(|| &small_set - &large_set);
    });

    c.bench_function("set_ops_bit_or_assign", |b| {
        b.iter(|| {
            let mut set = large_set.clone();
            set |= &small_set;
            set
        });
    });

    c.bench_function("set_ops_bit_and_assign", |b| {
        b.iter(|| {
            let mut set = small_set.clone();
            set &= &large_set;
            set
        });
    });

    c.bench_function("set_ops_bit_xor_assign", |b| {
        b.iter(|| {
            let mut set = large_set.clone();
            set ^= &small_set;
            set
        });
    });

    c.bench_function("set_ops_sub_assign_large_small", |b| {
        b.iter(|| {
            let mut set = large_set.clone();
            set -= &small_set;
            set
        });
    });

    c.bench_function("set_ops_sub_assign_small_large", |b| {
        b.iter(|| {
            let mut set = small_set.clone();
            set -= &large_set;
            set
        });
    });
}