English

Biff (Bloom Filter) Codes : Fast Error Correction for Large Data Sets

Data Structures and Algorithms 2015-03-20 v1

Abstract

Large data sets are increasingly common in cloud and virtualized environments. For example, transfers of multiple gigabytes are commonplace, as are replicated blocks of such sizes. There is a need for fast error-correction or data reconciliation in such settings even when the expected number of errors is small. Motivated by such cloud reconciliation problems, we consider error-correction schemes designed for large data, after explaining why previous approaches appear unsuitable. We introduce Biff codes, which are based on Bloom filters and are designed for large data. For Biff codes with a message of length LL and EE errors, the encoding time is O(L)O(L), decoding time is O(L+E)O(L + E) and the space overhead is O(E)O(E). Biff codes are low-density parity-check codes; they are similar to Tornado codes, but are designed for errors instead of erasures. Further, Biff codes are designed to be very simple, removing any explicit graph structures and based entirely on hash tables. We derive Biff codes by a simple reduction from a set reconciliation algorithm for a recently developed data structure, invertible Bloom lookup tables. While the underlying theory is extremely simple, what makes this code especially attractive is the ease with which it can be implemented and the speed of decoding. We present results from a prototype implementation that decodes messages of 1 million words with thousands of errors in well under a second.

Keywords

Cite

@article{arxiv.1208.0798,
  title  = {Biff (Bloom Filter) Codes : Fast Error Correction for Large Data Sets},
  author = {Michael Mitzenmacher and George Varghese},
  journal= {arXiv preprint arXiv:1208.0798},
  year   = {2015}
}

Comments

5 pages, Corrected typos from ISIT 2012 conference version

R2 v1 2026-06-21T21:45:59.140Z