range-tree-rs 0.2.0

A range tree implement for slab allocator
Documentation
use criterion::{Criterion, Throughput, black_box, criterion_group, criterion_main};
use range_tree_rs::RangeTree;

fn bench_range_tree_insert_fragmented(c: &mut Criterion) {
    let count = 10000;
    let fragment_size = 4096;
    let gap_size = 4096;

    let ranges: Vec<(u64, u64)> =
        (0..count).map(|i| (i as u64 * (fragment_size + gap_size), fragment_size)).collect();

    let mut group = c.benchmark_group("range_tree_fragmented");
    group.throughput(Throughput::Elements(count as u64));
    group.bench_function("insert_10000_fragments", |b| {
        b.iter(|| {
            let mut tree = RangeTree::<u64>::new();
            for &(start, size) in &ranges {
                tree.add(black_box(start), black_box(size)).expect("add");
            }
        })
    });
    group.finish();
}

criterion_group!(benches, bench_range_tree_insert_fragmented);
criterion_main!(benches);