12 releases
0.3.7 | Dec 13, 2024 |
---|---|
0.3.4 | Nov 15, 2024 |
0.2.1 | Jun 5, 2024 |
0.1.1 | Mar 12, 2024 |
#713 in Data structures
25 downloads per month
Used in 2 crates
245KB
4K
SLoC
SBWT: A Burrows-Wheeler transform for DNA k-mers
This crate provides an implementation of the Bit Matrix SBWT data structure, as described in Small Searchable k-Spectra via Subset Rank Queries on the Spectral Burrows-Wheeler Transform, for the DNA alphabet ACGT. The data structure uses a variant of the Burrows-Wheeler transform to compress a set of k-mers in way that allows fast lookup queries. If the input k-mers are consecutive k-mers from longer underlying sequences, the index takes typically around 5 bits per distinct k-mer, supporting k-mer lookup queries at a speed of around 1 μs / k-mer on modern hardware.
Queries can be further sped up by using the Longest common suffix array, (see here) taking roughly log(k) bits of space per k-mer. The LCS array also enables the computation of k-bounded matching statistics and shortest frequency-bounded suffixes (both described here). Finally, the crate provides an interface for traversing the node-centric de Bruijn graph of the k-mers.
API documentation available at https://docs.rs/sbwt/latest/sbwt/.
A CLI for key features of the API can be found at https://github.com/jnalanko/sbwt-rs-cli. The API is developed together with the CLI at https://github.com/jnalanko/sbwt-rs-cli/tree/master/api.
Changes between releases are documented in the changelog.
Dependencies
~14MB
~240K SLoC