8000 GitHub - ashtum/bloom
[go: up one dir, main page]
More Web Proxy on the site http://driver.im/
Skip to content

ashtum/bloom

 
 

Repository files navigation

Candidate Boost Bloom Library

📢 Review announcement
Candidate Boost.Bloom will be officially reviewed for inclusion into Boost from May 13 to 22, 2025, see the review schedule page for details. All interested people are welcome to participate!

Branch CI Drone status Documentation
Branch CI Drone status Documentation
BSL 1.0 C++11 required Header-only library

(Candidate) Boost.Bloom provides the class template boost::bloom::filter that can be configured to implement a classical Bloom filter as well as variations discussed in the literature such as block filters, multiblock filters, and more.

#include <boost/bloom/filter.hpp>
#include <cassert>
#include <string>

int main()
{
  // Bloom filter of strings with 5 bits set per insertion
  using filter = boost::bloom::filter<std::string, 5>;

  // create filter with a capacity of 1'000'000 **bits**
  filter f(1'000'000);

  // insert elements (they can't be erased, Bloom filters are insert-only)
  f.insert("hello");
  f.insert("Boost");
  //...

  // elements inserted are always correctly checked as such
  assert(f.may_contain("hello") == true);

  // elements not inserted may incorrectly be identified as such with a
  // false positive rate (FPR) which is a function of the array capacity,
  // the number of bits set per element and generally how the boost::bloom::filter
  // was specified
  if(f.may_contain("bye")) { // likely false
    //...
  }
}

Learn about Boost.Bloom

Install Boost.Bloom

Clone this repo, adjust your include paths and enjoy. Boost.Bloom is header-only and requires no building. A recent version of Boost is required.

Support

Contribute

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 82.3%
  • Jsonnet 10.7%
  • CMake 5.3%
  • Other 1.7%
0