Skip to content

Latest commit

 

History

History
93 lines (73 loc) · 4.46 KB

README.md

File metadata and controls

93 lines (73 loc) · 4.46 KB

Cami Benchmarks

Purpose

Benchmarks of (public API only of) Rust crate cami-rs/cami.

Naming Conventions

Name of eacmost benches has three parts, separated with -. The parts indicate:

  • whether it uses alloc (or not), or std (if it's std, that implies alloc). That pts benches into three groups:
    • stack-...: no_std-compatible, and no allocation,
    • alloc-...: no_std-compatible, but requiring alloc,
    • stdlb-: requires std;
  • the collection/storage being used. That is the collection/storage of "out" items, ones being sorted or searched for - not necessarily the same kind of collection/storage as used for "own" items (in case the "out" items refer to/borrow from "own" items).
  • the item type.

For example

stack-* benches do use alloc, but only for their own operation. These benches allocate a Vec, but before calling cami they convert that Vec into a slice. They invoke cami's allocation-free functionality only.

All benches use iai-callgrind, except for any legacy Criterion-based benches. Those have -criterion suffix. iai-callgrind

How to run

You must specify any features required by the appropriate bench. Even if a chosen bench declares such feature(s) as required (in required-features in Cargo.toml), specifying such a bench, as with cargo bench --bench ... or cargo check --bench ..., will not "match" that bench (will not run/check it), unless you specify all features that it requires.

Relevant features:

  • alloc - required for alloc-... benches, and
  • std - for std-... benches - currently: no std benches yet,
  • deref_pure is optional
  • fastrand is optional, but the only currently supported randomness generator - so, de-facto required.
  • iai-callgrind is optional, but soon-to-be the only (then currently) supported benchmarking harness - so, de-facto required.

Invoke cargo bench or cargo check --benches like:

cargo check --bench stack-slice-u8     --features iai-callgrind,fastrand
cargo check --bench stack-slice-u8     --features fastrand,deref_pure
cargo bench --bench stack-slice-u8     --features fastrand
cargo bench --bench stack-slice-u8     --features fastrand,deref_pure

cargo check --bench alloc-vec-u8       --features fastrand,alloc
cargo check --bench alloc-vec-u8       --features fastrand,alloc,deref_pure
cargo bench --bench alloc-vec-u8       --features fastrand,alloc
cargo bench --bench alloc-vec-u8       --features fastrand,alloc,deref_pure

cargo check --bench alloc-vec-u8_slice --features fastrand,alloc
cargo check --bench alloc-vec-u8_slice --features fastrand,alloc,deref_pure
cargo bench --bench alloc-vec-u8_slice --features fastrand,alloc
cargo bench --bench alloc-vec-u8_slice --features fastrand,alloc,deref_pure

cargo check --bench alloc-vec-str      --features fastrand,alloc
cargo check --bench alloc-vec-str      --features fastrand,alloc,deref_pure
cargo bench --bench alloc-vec-str      --features fastrand,alloc
cargo bench --bench alloc-vec-str      --features fastrand,alloc,deref_pure

cargo check --bench alloc-vec-string   --features fastrand,alloc
cargo check --bench alloc-vec-string   --features fastrand,alloc,deref_pure
cargo bench --bench alloc-vec-string   --features fastrand,alloc
cargo bench --bench alloc-vec-string   --features fastrand,alloc,deref_pure

cargo check --bench alloc-btreeset-u8  --features fastrand,alloc
cargo check --bench alloc-btreeset-u8  --features fastrand,alloc,deref_pure
cargo bench --bench alloc-btreeset-u8  --features fastrand,alloc
cargo bench --bench alloc-btreeset-u8  --features fastrand,alloc,deref_pure

cargo check --benches                  --features fastrand,alloc
cargo check --benches                  --features fastrand,alloc,deref_pure
cargo bench                            --features fastrand,alloc
cargo bench                            --features fastrand,alloc,deref_pure

alloc is required by the benches. But, because alloc is not a default feature in cami, those benches won't be run until you specify it.