Skip to content

jonahharris/libcuckoofilter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Cuckoo Filter Library

Similar to a Bloom filter, a Cuckoo filter provides a space-efficient data structure designed to answer approximate set-membership queries (e.g. "is item x contained in this set?") Unlike standard Bloom filters, however, Cuckoo filters support deletion. Likewise, Cuckoo filters are more optimal than Bloom variants which support deletion, such as counting Bloom filters, in both space and time.

Cuckoo filters are based on cuckoo hashing. A Cuckoo filter is essentially a cuckoo hash table which stores each key's fingerprint. As Cuckoo hash tables are highly compact, a cuckoo filter often requires less space than conventional Bloom filters for applications that require low false positive rates (< 3%).

Implementation Details

This library was designed to provide a target false positive probability of ~P(0.001) and was hard-coded to use sixteen bits per item and four nests per bucket. As it uses two hashes, it's a (2, 4)-cuckoo filter.

Interface

A Cuckoo filter supports following operations:

  • cuckoo_filter_new(filter, max_key_count, max_kick_attempts, seed): creates a filter
  • cuckoo_filter_free(filter): destroys a filter
  • cuckoo_filter_add(filter, item, item_length_in_bytes): add an item to the filter
  • cuckoo_filter_remove(filter, item, item_length_in_bytes): remove an item from the filter
  • cuckoo_filter_contains(filter, item, item_length_in_bytes): test for approximate membership of an item in the filter

Repository structure

  • example/example.c: an example demonstrating the use of the filter
  • include/cuckoo_filter.h: the public header file
  • src/cuckoo_filter.c: a C-based implementation of a (2, 4)-cuckoo filter
  • tests/test.c: unit tests

Usage

To build this example:

$ make test

Authors

Jonah H. Harris jonah.harris@gmail.com

License

The MIT License

References

  • "Cuckoo Filter: Better Than Bloom" by Bin Fan, Dave Andersen, and Michael Kaminsky

About

A C library implementation of a Cuckoo Filter

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •