Fast and Space-Efficient Maps for Large Data Sets

Total Page:16

File Type:pdf, Size:1020Kb

Fast and Space-Efficient Maps for Large Data Sets Fast and Space-Efficient Maps for Large Data Sets A Dissertation presented by Prashant Pandey to The Graduate School in Partial Fulfillment of the Requirements for the Degree of Doctor of Philosophy in Computer Science Stony Brook University December 2018 Stony Brook University The Graduate School Prashant Pandey We, the dissertation committee for the above candidate for the Doctor of Philosophy degree, hereby recommend acceptance of this dissertation Michael A. Bender, Thesis Advisor Professor, Computer Science Rob Johnson, Thesis Advisor Research Assistant Professor, Computer Science Michael Ferdman, Thesis Committee Chair Associate Professor, Computer Science Rob Patro Assistant Professor, Computer Science Guy Blelloch Professor, Computer Science Carnegie Mellon University This dissertation is accepted by the Graduate School Dean of the Graduate School ii Abstract of the Dissertation Fast and Space-Efficient Maps for Large Data Sets by Prashant Pandey Doctor of Philosophy in Computer Science Stony Brook University 2018 Approximate Membership Query (AMQ) data structures, such as the Bloom filter, have found numerous applications in databases, storage systems, networks, computa- tional biology, and other domains. However, many applications must work around limitations in the capabilities or performance of current AMQs, making these appli- cations more complex and less performant. For example, many current AMQs cannot delete or count the number of occurrences of each input item, nor can they store values corresponding to items. They take up large amounts of space, are slow, cannot be resized or merged, or have poor locality of reference and hence perform poorly when stored on SSD or disk. In this dissertation, we show how to use recent advances in the theory of compact and succinct data structures to build a general-purpose AMQ. We further demonstrate how we use this new feature-rich AMQ to improve applications in computational biology and streaming in terms of space, speed, and simplicity. First, we present a new general-purpose AMQ, the counting quotient filter (CQF). The CQF supports approximate membership testing and counting occurrences of items in a data set and offers an order-of-magnitude faster performance than the Bloom filter. The CQF can also be extended to be a fast and space-efficient map for small keys and values. Then we discuss three applications in computational biology and streaming that use the CQF to solve big data problems. In the first application, Squeakr, we show how iii we can compactly represent huge weighted de Bruijn Graphs in computational biology using the CQF as an approximate multiset representation. In deBGR, we further show how to use a weighted de Bruijn Graph invariant to iteratively correct all the approximation errors in the Squeakr representation. In the third application, Mantis, we show how to use the CQF as a map for small keys and values to build a large- scale sequence-search index for large collections of raw sequencing data. In the fourth application, we show how to extend the CQF to build a write-optimized key-value store (for small keys and values) for timely reporting of heavy-hitters using external memory. iv Dedication To my collaborators, cohabitators, and everyone else who had to put up with me. Especially, my parents, Sudha and Dharmen- dra, who taught me the importance of hard work and humbleness in life. My brother and sister-in-law, Siddharth and Pooja, who helped me at every step of my career and encouraged me to pur- sue research. And finally, my wife, Kavita, who stood with me as a friend all through the good and bad times of my grad life. v Contents List of Figures ix List of Tables xi 1 Introduction 1 1.1 Outline . .3 2 AMQ and counting structures 4 2.1 AMQ data structures . .4 2.2 Counting data structures . .5 2.3 Succinct data structures . .7 3 The counting quotient filter (CQF) 8 3.1 Rank-and-select-based metadata scheme . .8 3.2 Fast x86 rank and select . 13 3.3 Lookup performance . 14 3.4 Space analysis . 14 3.5 Enumeration, resizing, and merging . 15 3.6 Counting Quotient Filter . 16 3.7 CQF space analysis . 18 3.8 Configuring the CQF . 20 3.9 Evaluation . 20 3.9.1 Experiment setup . 21 3.9.2 In-RAM performance . 24 3.9.3 On-SSD performance . 24 3.9.4 Performance with skewed data sets . 24 3.9.5 Applications . 25 3.9.6 Mergeability . 25 3.9.7 Impact of optimizations . 26 vi 4 Squeakr: An exact and approximate k-mer counting system 33 4.1 k-mer counting . 33 4.2 Methods . 36 4.2.1 Squeakr design . 36 4.2.2 Squeakr can also be an exact k-mer counter . 39 4.3 Evaluation . 40 4.3.1 Experimental setup . 41 4.3.2 Memory requirement . 43 4.3.3 Counting performance . 44 4.3.4 Query performance . 45 4.3.5 Inner-product queries . 46 5 deBGR: An efficient and near-exact representation of the weighted de Bruijn Graph 47 5.1 de Bruijn Graphs . 47 5.2 Background . 50 5.2.1 Prior approximate de Bruijn Graph representations . 50 5.2.2 Lower bounds on weighted de Bruijn Graph representation . 51 5.3 Methods . 52 5.3.1 A weighted de Bruijn Graph invariant . 52 5.3.2 deBGR: A compact de Bruijn graph representation . 56 5.3.3 Local error-correction rules . 56 5.3.4 Global, CQF-specific error-correction rules . 58 5.3.5 An algorithm for computing abundance corrections . 60 5.3.6 Implementation . 61 5.4 Evaluation . 62 5.4.1 Experimental setup . 64 5.4.2 Space vs accuracy trade-off . 64 5.4.3 Performance . 64 6 Large-scale sequence-search index 68 6.1 Sequence-search indexes . 68 6.2 Methods . 73 6.2.1 Method details . 73 6.2.2 Quantification and statistical analysis . 78 6.3 Evaluation . 78 6.3.1 Evaluation metrics . 78 6.3.2 Experimental procedure . 78 6.3.3 Experimental setup . 80 6.3.4 Experiment results . 81 vii 7 Timely reporting of heavy-hitters using external memory 84 7.1 Online event detection problem . 84 7.2 The Misra-Gries algorithm and heavy hitters . 88 7.3 External-memory Misra-Gries and online event detection . 89 7.3.1 External-memory Misra-Gries . 90 7.4 Online event-detection . 91 7.5 Online event detection with time-stretch . 93 7.6 Online event detection on power-law distributions . 95 7.6.1 Power-law distributions . 96 7.6.2 Popcorn filter . 96 7.7 Implementation . 100 7.7.1 Time-stretch filter . 100 7.7.2 Popcorn filter . 101 7.8 Greedy shuffle-merge schedule . 102 7.9 Deamortizing . 102 7.10 Evaluation . 103 7.10.1 Experimental setup . 104 7.10.2 Timely reporting . 107 7.10.3 I/O performance . 109 7.10.4 Scaling with multiple threads . 110 Bibliography 117 viii List of Figures 3.1 Rank-and-select-based quotient filter . 10 3.2 Procedure for computing offset Oj given Oi................ 10 3.3 Rank-and-select-based-quotient-filter block . 12 3.4 A simple example of pdep instruction [87]. The 2nd operand acts as a mask to deposit bits from the 1st operand. 13 3.5 Space analysis of AMQs . 15 3.6 Space analysis of counting filters . 19 3.7 In-memory performance of AMQs . 28 3.8 On-SSD performance of AMQs . 29 3.9 In-memory performance of counting filters . 30 3.10 In-memory performance of the CQF with real-world data sets . 31 3.11 Impact of x86 instruction on RSQF performance . 32 4.1 Squeakr system design . 37 5.1 Weighted de Bruijn Graph invariant. 54 5.2 Types of edges in a de Bruijn Graph. 55 5.3 Total number of distinct k-mers in First QF, Last QF, and Main QF. 62 6.1 The Mantis indexing data structures. 74 6.2 The distribution of the number of k-mers in a color class and ID assigned to the color class. 76 7.1 Active-set generator dataset . 104 7.2 Count stretch vs. lifetime in active-set generator dataset . 107 7.3 Time stretch vs. lifetime in active-set generator dataset . 108 7.4 Time stretch vs. lifetime in active-set generator dataset . 109 7.5 Time stretch vs. lifetime in active-set generator dataset . 110 7.6 Time stretch vs. lifetime in active-set generator dataset . 111 ix 7.7 Scalability with increasing number of threads. 113 7.8 Scalability with increasing number of threads. 114 x List of Tables 3.1 Space usage of several AMQs. 15 3.2 Encodings for C occurrences of remainder x in the CQF. 18 3.3 Data sets used in multi-threaded experiments . 25 3.4 CQF K-way merge performance . 25 4.1 Datasets used in Squeakr experiments . 40 4.2 RAM used by KMC2, Squeakr, Squeakr (exact), and Jellyfish2. 43 4.3 k-mer counting performance for k = 28. 44 4.4 k-mer counting performance for k = 55. 44 4.5 Random query performance for k = 28. 45 4.6 de Bruijn Graph query.
Recommended publications
  • A General-Purpose High Accuracy and Space Efficient
    countBF: A General-purpose High Accuracy and Space Efficient Counting Bloom Filter 1st Sabuzima Nayak 2nd Ripon Patgiri, Senior Member, IEEE Dept. Computer Science & Engineering Dept. Computer Science & Engineering National Institute of Technology Silchar National Institute of Technology Silchar Cachar-788010, Assam, India Cachar-788010, Assam, India sabuzima [email protected] [email protected] Abstract—Bloom Filter is a probabilistic data structure for Delete operation is crucial for Bloom Filter. Suppose a the membership query, and it has been intensely experimented database management system integrates Bloom Filter to avoid in various fields to reduce memory consumption and enhance unnecessary disk accesses and enhance its performance sig- a system’s performance. Bloom Filter is classified into two key categories: counting Bloom Filter (CBF), and non-counting nificantly with a tiny amount of memory [18]. Thus, the Bloom Filter. CBF has a higher false positive probability than database management system requires to insert, query, and standard Bloom Filter (SBF), i.e., CBF uses a higher memory delete operation for which conventional Bloom Filter is not footprint than SBF. But CBF can address the issue of the false suitable. Therefore, counting Bloom Filter is used in such negative probability. Notably, SBF is also false negative free, but kind of requirements. Another example is a network router. it cannot support delete operations like CBF. To address these issues, we present a novel counting Bloom Filter based on SBF Older packets are removed from the router databases. There- and 2D Bloom Filter, called countBF. countBF uses a modified fore, the router requires counting Bloom Filter.
    [Show full text]
  • Efficient Data Structures for High Speed Packet Processing
    Efficient data structures for high speed packet processing Paolo Giaccone Notes for the class on \Computer aided simulations and performance evaluation " Politecnico di Torino November 2020 Outline 1 Applications 2 Theoretical background 3 Tables Direct access arrays Hash tables Multiple-choice hash tables Cuckoo hash 4 Set Membership Problem definition Application Fingerprinting Bit String Hashing Bloom filters Cuckoo filters 5 Longest prefix matching Patricia trie Giaccone (Politecnico di Torino) Hash, Cuckoo, Bloom and Patricia Nov. 2020 2 / 93 Applications Section 1 Applications Giaccone (Politecnico di Torino) Hash, Cuckoo, Bloom and Patricia Nov. 2020 3 / 93 Applications Big Data and probabilistic data structures 3 V's of Big Data Volume (amount of data) Velocity (speed at which data is arriving and is processed) Variety (types of data) Main efficiency metrics for data structures space time to write, to update, to read, to delete Probabilistic data structures based on different hashing techniques approximated answers, but reliable estimation of the error typically, low memory, constant query time, high scaling Giaccone (Politecnico di Torino) Hash, Cuckoo, Bloom and Patricia Nov. 2020 4 / 93 Applications Probabilistic data structures Membership answer approximate membership queries e.g., Bloom filter, counting Bloom filter, quotient filter, Cuckoo filter Cardinality estimate the number of unique elements in a dataset. e.g., linear counting, probabilistic counting, LogLog and HyperLogLog Frequency in streaming applications, find the frequency of some element, filter the most frequent elements in the stream, detect the trending elements, etc. e.g., majority algorithm, frequent algorithm, count sketch, count{min sketch Giaccone (Politecnico di Torino) Hash, Cuckoo, Bloom and Patricia Nov.
    [Show full text]
  • Quotient Hash Tables-Efficiently Detecting Duplicates in Streaming
    Quotient Hash Tables - Efficiently Detecting Duplicates in Streaming Data Rémi Gérauda,c, Marius Lombard-Platet∗a,b, and David Naccachea,c aDépartement d’informatique de l’ENS, École normale supérieure, CNRS, PSL Research University, Paris, France bBe-Studys, Geneva, Switzerland cIngenico Labs Advanced Research, Paris, France Abstract This article presents the Quotient Hash Table (QHT) a new data structure for duplicate detection in unbounded streams. QHTs stem from a corrected analysis of streaming quotient filters (SQFs), resulting in a 33% reduction in memory usage for equal performance. We provide a new and thorough analysis of both algorithms, with results of interest to other existing constructions. We also introduce an optimised version of our new data structure dubbed Queued QHT with Duplicates (QQHTD). Finally we discuss the effect of adversarial inputs for hash-based duplicate filters similar to QHT. 1 Introduction and Motivation bits. We consider in this paper the following problem: given a pos- Proof. A perfect duplicate filter must be able to store all sibly infinite stream of symbols, detect whether a given sym- streams Ei = (e1,...,en), i.e. must be able to store any bol appeared somewhere in the stream. It turns out that in- subset of Γ, which we denote by (Γ). Given that there are P stances of this duplicate detection problem arise naturally in (Γ) = 2 Γ = 2U of them, according to information theory |P | | | many applications: backup systems [11] or Web caches [10], any such filter requires at least log ( (Γ) ) = log (2U )= U 2 |P | 2 search engine databases or click counting in web advertise- bits of storage.
    [Show full text]
  • When the Levee Breaks: a Practical Guide to Sketching Algorithms for Processing the Flood of Genomic Data Will P
    Rowe Genome Biology (2019) 20:199 https://doi.org/10.1186/s13059-019-1809-x REVIEW Open Access When the levee breaks: a practical guide to sketching algorithms for processing the flood of genomic data Will P. M. Rowe1,2 Abstract Considerable advances in genomics over the past decade have resulted in vast amounts of data being generated and deposited in global archives. The growth of these archives exceeds our ability to process their content, leading to significant analysis bottlenecks. Sketching algorithms produce small, approximate summaries of data and have shown great utility in tackling this flood of genomic data, while using minimal compute resources. This article reviews the current state of the field, focusing on how the algorithms work and how genomicists can utilize them effectively. References to interactive workbooks for explaining concepts and demonstrating workflows are included at https://github.com/will-rowe/genome-sketching. Introduction made, such as the quantity, quality and distribution of data. To gain biological insight from genomic data, a genomicist In an ideal world, most genomicists would elect to include must design experiments, run bioinformatic software and all available data but this is growing harder to achieve as evaluate the results. This process is repeated, refined or theamountofdatadrivesupruntimesandcosts. augmented as new insight is gained. Typically, given the In response to being unable to analyze all the things,gen- size of genomic data, this process is performed using high omicists are turning to analytics solutions from the wider performance computing (HPC) in the form of local com- data science field in order to process data quickly and effi- pute clusters, high-memory servers or cloud services.
    [Show full text]
  • A Cuckoo Filter Modification Inspired by Bloom Filter
    AUT Journal of Electrical Engineering AUT J. Elec. Eng., 51(2) (2019) 187-200 DOI: 10.22060/eej.2019.16370.5287 A Cuckoo Filter Modification Inspired by Bloom Filter Ha. Sasaniyan Asl1,*, B. Mozaffari Tazehkand2, M.J. Museviniya2 1 MSc,Faculty of Electrical and Computer Engineering, University of Tabriz, Tabriz, Iran 2 PhD,Faculty of Electrical and Computer Engineering, University of Tabriz, Tabriz, Iran ABSTRACT: Probabilistic data structures are so popular in membership queries, network applications, Review History: and databases and so on. Bloom Filter and Cuckoo Filter are two popular space efficient models Received: 2019-05-20 that incorporate in set membership checking part of many important protocols. They are compact Revised: 2019-09-17 representations of data that use hash functions to randomize a set of items. Being able to store more Accepted: 2019-09-17 elements while keeping a reasonable false positive probability is a key factor of design. A new algorithm Available Online: 2019-12-01 is proposed to improve some of the performance properties of Cuckoo Filter such as false positive rate and insertion performance and solve some drawbacks of the Cuckoo algorithm such as endless loop. Keywords: Main characteristic of the Bloom Filter is used to improve Cuckoo Filter, so we have a smart Cuckoo Bloom Filter Filter which is modified by Bloom Filter so called as SCFMBF. SCFMBF uses the same table of buckets Cuckoo Filter as Cuckoo Filter but instead of storing constant Fingerprints, it stores Bloom Filters. Bloom Filters can be accumulated in the table’s buckets which leads to higher insertion feasibility.
    [Show full text]
  • Abstract Algorithms and Data Structures For
    ABSTRACT Title of Dissertation: ALGORITHMS AND DATA STRUCTURES FOR INDEXING, QUERYING, AND ANALYZING LARGE COLLECTIONS OF SEQUENCING DATA IN THE PRESENCE OR ABSENCE OF A REFERENCE Fatemeh Almodaresi Doctor of Philosophy, Dissertation Directed by: Professor Rob Patro Department of Computer Science High-throughput sequencing has helped to transform our study of biological organisms and processes. For example, RNA-seq is one popular sequencing assay that allows measuring dynamic transcriptomes and enables the discovery (via assem- bly) of novel transcripts. Likewise, metagenomic sequencing lets us probe natural environments to profile organismal diversity and to discover new strains and species that may be integral to the environment or process being studied. The vast amount of available sequencing data, and its growth rate over the past decade also brings with it some immense computational challenges. One of these is how do we design memory-efficient structures for indexing and querying this data. This challenge is not limited to only raw sequencing data (i.e. reads) but also to the growing collection of reference sequences (genomes, and genes) that are assembled from this raw data. We have developed new data structures (both reference-based and reference-free) to index raw sequencing data and assembled reference sequences. Specifically, we describe three separate indices, “Pufferfish”, an index over a set of genomes or tran- scriptomes, and “Rainbowfish” and “Mantis” which are both indices for indexing a set of raw sequencing data sets. All of these indices are designed with consideration of support for high query performance and memory efficient construction and query. The Pufferfish data structure is based on constructing a compacted, colored, reference de Bruijn graph (ccdbg), and then indexing this structure in an efficient manner.
    [Show full text]
  • {PDF} Probabilistic Data Structures and Algorithms for Big Data
    PROBABILISTIC DATA STRUCTURES AND ALGORITHMS FOR BIG DATA APPLICATIONS PDF, EPUB, EBOOK Andrii Gakhov | 220 pages | 11 Feb 2019 | BOOKS ON DEMAND | 9783748190486 | English | none Probabilistic Data Structures and Algorithms for Big Data Applications PDF Book Mousavi A. About this product Product Information A technical book about popular space-efficient data structures and fast algorithms that are extremely useful in modern Big Data applications. A simple proof of the restricted isometry property for random matrices. Global Ocean Sampling This service is more advanced with JavaScript available. Edition Location Original text Corrected text 1st, p. Rank We study data structures to estimate quantiles and percentiles in a data stream using only one pass through the data. On the other hand, calculating the exact cardinality requires an amount of memory proportional to the cardinality, which is impractical for very large data sets. Sectional minhash for near-duplicate detection. As the size of the reference databases terabytes to petabytes and the number of reads 10s of millions to billions in metagenomic samples increase, it becomes computationally intractable to perform exhaustive comparison of all k -mers in the reads against all k -mers within the reference databases, opening the door for efficient new tools. Emerging Research Trends and New Horizons. Finally, the containment index is converted to a score that approximates sequence similarity. Big Data Analytics. In addition to extensions and variations of fundamental methods, recent advances have developed by combining several core data structures and techniques. About this book The purpose of this book is to introduce probabilistic data structures and algorithms to technology practitioners, including software architects and developers, as well as technology decision makers.
    [Show full text]
  • Concurrent Expandable Amqs on the Basis of Quotient Filters
    Concurrent Expandable AMQs on the Basis of Quotient Filters Tobias Maier Karlsruhe Institute of Technology, Germany [email protected] Peter Sanders Karlsruhe Institute of Technology, Germany [email protected] Robert Williger Karlsruhe Institute of Technology, Germany Abstract A quotient filter is a cache efficient Approximate Membership Query (AMQ) data structure. De- pending on the fill degree of the filter most insertions and queries only need to access one or two consecutive cache lines. This makes quotient filters very fast compared to the more commonly used Bloom filters that incur multiple independent memory accesses depending on the false positive rate. However, concurrent Bloom filters are easy to implement and can be implemented lock-free while concurrent quotient filters are not as simple. Usually concurrent quotient filters work by using an external array of locks – each protecting a region of the table. Accessing this array incurs one additional memory access per operation. We propose a new locking scheme that has no memory overhead. Using this new locking scheme we achieve 1.6× times higher insertion performance and over 2.1× higher query performance than with the common external locking scheme. Another advantage of quotient filters over Bloom filters is that a quotient filter can change its capacity when it is becoming full. We implement this growing technique for our concurrent quotient filters and adapt it in a way that allows unbounded growing while keeping a bounded false positive rate. We call the resulting data structure a fully expandable quotient filter. Its design is similar to scalable Bloom filters, but we exploit some concepts inherent to quotient filters to improve the space efficiency and the query speed.
    [Show full text]
  • Arxiv:1208.0290V1 [Cs.DB] 1 Aug 2012 1
    Don’t Thrash: How to Cache Your Hash on Flash Michael A. Bender∗§ Martin Farach-Colton†§ Rob Johnson∗ Russell Kraner¶ Bradley C. Kuszmaul‡§ Dzejla Medjedovic∗ Pablo Montes∗ Pradeep Shetty∗ Richard P. Spillane∗ Erez Zadok∗ ∗{bender,rob,dmededov,pmontes,pshetty,spillane,ezk}@cs.stonybrook.edu †[email protected][email protected][email protected] ABSTRACT queries for elements that do not exist in the database, in This paper presents new alternatives to the well-known external storage, or on a remote network host. Bloom filter data structure. The Bloom filter, a compact The Bloom filter is the classic example of an approximate data structure supporting set insertion and membership membership query data structure (AMQ). A Bloom filter queries, has found wide application in databases, storage supports insert and lookup operations on a set of keys. For systems, and networks. Because the Bloom filter performs a key in the set, lookup returns “present.” For a key not frequent random reads and writes, it is used almost exclu- in the set, lookup returns “absent” with probability at least 1 ε, where ε is a tunable false-positive rate. There is sively in RAM, limiting the size of the sets it can represent. − This paper first describes the quotient filter, which sup- a tradeoff between ε and the space consumption. Other ports the basic operations of the Bloom filter, achieving AMQs, such as counting Bloom filters, additionally support roughly comparable performance in terms of space and time, deletes [3,11]. For a comprehensive review of Bloom filters, but with better data locality. Operations on the quotient fil- see Broder and Mitzenmacher [4].
    [Show full text]
  • Concurrent Dynamic Quotient Filters: Packing Fingerprints Into Atomics
    Master Thesis Concurrent Dynamic Quotient Filters: Packing Fingerprints into Atomics Robert Williger Date: 29. March 2019 Supervisors: Prof. Dr. Peter Sanders Tobias Maier Institute of Theoretical Informatics, Algorithmics Department of Informatics Karlsruhe Institute of Technology Hiermit versichere ich, dass ich diese Arbeit selbständig verfasst und keine anderen, als die angegebenen Quellen und Hilfsmittel benutzt, die wörtlich oder inhaltlich übernommenen Stellen als solche kenntlich gemacht und die Satzung des Karlsruher Instituts für Technolo- gie zur Sicherung guter wissenschaftlicher Praxis in der jeweils gültigen Fassung beachtet habe. ———————————— Karlsruhe, den 29. März 2019 Abstract Quotient filters are approximate membership data structures that can be used for a variety of applications, from speeding up database accesses to uses in computational biology. We look at several improvements to common quotient filters which are orthogonal to each other and can be combined as needed. We show how to use compact arbitrary length data types to reduce the memory usage by up to seven times and get very close to the theoretical optimum. We also present two different approaches to building concurrent quotient filters that use localized locking or no locking at all. This leads to a good speedup with increasing thread counts and an increase in performance of up to four times compared to traditional locking techniques. Using the compact packing technique with concurrent quotient filters also has the benefit of reducing atomic operations and enabling lock elision optimizations. Additionally, we describe how to use a multilevel quotient filter structure to implement dynamic growing while still allowing a user defined maximum false positive rate and being less than 10% slower compared to non-growing variants in scenarios where growing is not necessary.
    [Show full text]
  • Vector Quotient Filters: Overcoming the Time/Space Trade-Off in Filter Design
    Vector Quotient Filters: Overcoming the Time/Space Trade-Off in Filter Design Prashant Pandey Alex Conway Joe Durie [email protected] [email protected] [email protected] Lawrence Berkeley National Lab VMware Research Rutgers University and University of California Berkeley Michael A. Bender Martin Farach-Colton Rob Johnson [email protected] [email protected] [email protected] Stony Brook University Rutgers University VMware Research ABSTRACT International Conference on Management of Data (SIGMOD ’21), June Today’s filters, such as quotient, cuckoo, and Morton, havea 20–25, 2021, Virtual Event, China. ACM, New York, NY, USA, 14 pages. https://doi.org/10.1145/3448016.3452841 trade-off between space and speed; even when moderately full (e.g., 50%-75% full), their performance degrades nontrivially. The result is that today’s systems designers are forced to choose between speed 1 INTRODUCTION and space usage. Filters, such as Bloom [9], quotient [43], and cuckoo filters [31], In this paper, we present the vector quotient filter (VQF). Locally, maintain compact representations of sets. They tolerate a small the VQF is based on Robin Hood hashing, like the quotient filter, false-positive rate ε: a membership query to a filter for set S returns but uses power-of-two-choices hashing to reduce the variance of present for any x 2S, and returns absent with probability at least runs, and thus offers consistent, high throughput across load factors. 1−ε for any x <S. A filter for a set of size n uses space that depends Power-of-two-choices hashing also makes it more amenable to on ε and n but is much smaller than explicitly storing all items of S.
    [Show full text]
  • A Survey of Sketches in Traffic Measurement: Design, Optimization
    A survey of sketches in traffic measurement: Design, Optimization, Application and Implementation Shangsen Li, Lailong Luo, Deke Guo, Qianzhen Zhang, Pengtao Fu Science and Technology on Information System Engineering Laboratory, National University of Defense Technology, Changsha Hunan 410073, P.R. China. Abstract—Network measurement probes the underlying net- cardinality), the number of packets for a flow (flow size), the work to support upper-level decisions such as network manage- traffic volume contributed by a specific flow (flow volume) ment, network update, network maintenance, network defense and the time information. These statistics together profile and beyond. Due to the massive, speedy, unpredictable features of network flows, sketches are widely implemented in measurement the network and provide essential information for network nodes to approximately record the frequency or estimate the management and protection/defense. cardinality of flows. At their cores, sketches usually maintain one or multiple counter array(s), and rely on hash functions to select TABLE I: Comparison with existing surveys the counter(s) for each flow. Then the space-efficient sketches from the distributed measurement nodes are aggregated to First author # Variants #Measurement tasks Year provide statistics of the undergoing flows. Currently, tremendous Cormode [9] ≤ 15 3 2010 redesigns and optimizations have been proposed to improve the Cormode [10] ≤ 20 3 2011 sketches for better network measurement performance. However, Zhou [11] ≤ 10 4 2014 existing reviews or surveys mainly focus on one particular Yassine [12] — — 2015 aspect of measurement tasks. Researchers and engineers in the Gibbons [13] ≤ 10 1 2016 network measurement community desire an all-in-one survey that Yan [14] — 1 2016 This survey ≥ 90 13 2021 covers the entire processing pipeline of sketch-based network measurement.
    [Show full text]