From e0402542bbc8849ff5d237bfb21b751922318ba3 Mon Sep 17 00:00:00 2001 From: Johannes Hengstler Date: Thu, 8 Aug 2024 17:45:36 +0200 Subject: [PATCH] more documentation about the constructor variants --- src/wavelet/mod.rs | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/src/wavelet/mod.rs b/src/wavelet/mod.rs index c1bbb5c..877c8bb 100644 --- a/src/wavelet/mod.rs +++ b/src/wavelet/mod.rs @@ -19,7 +19,14 @@ use std::ops::Range; /// The implementation is designed to allow for extremely large alphabet sizes, without /// sacrificing performance for small alphabets. /// -/// Encodes a sequence of `n` `k`-bit words into a wavelet matrix which supports constant-time +/// There are two constructor algorithms available: +/// - [`from_bit_vec`] and [`from_slice`] construct the wavelet matrix by repeatedly sorting the elements. +/// These constructors have linear space overhead and run in `O(kn * log n)` time complexity. +/// - [`from_bit_vec_pc`] and [`from_slice_pc`] construct the wavelet matrix by counting the +/// prefixes of the elements. These constructors have a space complexity of `O(2^k)` and run +/// in `O(kn)`, which makes this constructor preferable for large sequences over small alphabets. +/// +/// They encode a sequence of `n` `k`-bit words into a wavelet matrix which supports constant-time /// rank and select queries on elements of its `k`-bit alphabet. /// All query functions are mirrored for both `BitVec` and `u64` query elements, so /// if `k <= 64`, no heap allocation is needed for the query element.