Lightweight Data Indexing and Compression in External Memory

  • Authors:
  • Paolo Ferragina;Travis Gagie;Giovanni Manzini

  • Affiliations:
  • Università di Pisa, Dipartimento di Informatica, Pisa, Italy;Aalto University, Department of Computer Science and Engineering, Helsinki, Finland;Università del Piemonte Orientale, Dipartimento di Informatica, Alessandria, Italy

  • Venue:
  • Algorithmica - Special Issue: Theoretical Informatics
  • Year:
  • 2012

Quantified Score

Hi-index 0.00

Visualization

Abstract

In this paper we describe algorithms for computing the Burrows-Wheeler Transform (bwt) and for building (compressed) indexes in external memory. The innovative feature of our algorithms is that they are lightweight in the sense that, for an input of size n, they use only n bits of working space on disk while all previous approaches use Θ(nlog n) bits. This is achieved by building the bwt directly without passing through the construction of the Suffix Array/Tree data structure. Moreover, our algorithms access disk data only via sequential scans, thus they take full advantage of modern disk features that make sequential disk accesses much faster than random accesses. We also present a scan-based algorithm for inverting the bwt that uses Θ(n) bits of working space, and a lightweight internal-memory algorithm for computing the bwt which is the fastest in the literature when the available working space is o(n) bits. Finally, we prove lower bounds on the complexity of computing and inverting the bwt via sequential scans in terms of the classic product: internal-memory space × number of passes over the disk data, showing that our algorithms are within an O(log n) factor of the optimal.