dary_heap

CI Crates.io Docs.rs

You're looking at version 0.2.x, which does not use const generics to allow for a lower minimum supported Rust version (MSRV) of 1.31.0. If a MSRV of 1.51.0 is acceptable, consider switching to version >=0.3.0.

Rust implementation of a d-ary heap. The d = 2 version is present in the standard library as BinaryHeap, but using a higher value for d can bring performance improvements in many use cases. This is because a higher arity d (maximum number of children each node can have) means the heap contains less layers, making adding elements to the heap faster. However, removing elements is slower, because then the amount of work per layer is higher as there are more children. The latter effect is often diminished due to higher cache locality. Therefore, overall performance is often increased if d > 2 but not too high. Benchmarking is necessary to determine the best value of d for a specific use case.

Compatibility and stability

The API of this crate aims to be analogous to that of BinaryHeap in the standard library. Feature-gated API in the standard library is also feature-gated in dary_heap, see the section on features for more information. In fact, the code in dary_heap is directly based on that of the standard library. The BinaryHeap provided by this crate should therefore provide similar performance as that of the standard library, and the other heap types provided by this crate may provide performance improvements.

The version of the standard library this crate is based on is currently 1.69.0. The aim is to keep the crate in sync with the latest stable Rust release.

The MSRV is currently 1.31.0. There are some minor features that depend on a higher minimum version of Rust and are automatically detected:

The MSRV can be increased in a minor level release, but not in a patch level release.

There are no stability guarantees for the unstable and unstable_nightly features. Changes to the behavior of nullary heaps (that should not be used anyway) are also not considered to be breaking and can happen in a patch level release.

Features

License

dary_heap is licensed under either of

at your option.