`

Bloom Filter 总结

 
阅读更多

1 Overview

    Bloom filter最早由 Burton Howard Bloom提出,是一种用于判断成员是否存在于某个集合中的数据结构。 Bloom filter的判断基于概率论:

  • 如果某个成员存在于集合中,那么Bloom filter不会返回假(即不存在),也就是说false negative是不可能的。
  • 如果某个成员实际上不存在于集合中,Bloom filter可能返回真(即存在),这种情况被称为false positive。

    Bloom filter通常被实现为一个包含 m 位的位数组(bit array),所有位的初始值都为0。 Bloom filter支持以下两种类型的操作:

  • add。将成员添加到Bloom filter中。以该成员为参数调用 k 个索引函数(index functions),得到 k 个位数组的索引值,取值范围是 [0, m), 然后将位数组的对应位设置为1。
  • query。判断某个成员是否已经添加到Bloom filter中。以该成员为参数调用 k 个索引函数,得到 k 个位数组的索引值,然后根据这些索引值检查位数组:当位数组中所有的对应位均为1时,那么认为该成员已经存在。

    如果query的结果为真(即positive),那么实际上存在以下两种可能性:

  • 该成员已经被add到集合中,即该成员的确存在。
  • 该成员未被add到集合中,但是query过程中检查的所有位均被设置为1(由于添加的其它成员导致)。这种情况被称为false positive。

    传统的Bloom filter 不支持从集合中删除成员。对于每个添加到Bloom filter中的成员,实际上将其位数组中的 k 位设置为1。尽管将这些位重置为0可以保证从Bloom filter中删除该成员,但是这样做的副作用是可能会影响某些其它成员,因为其它成员也可能被映射到这些被重置为0的位中的一位或者多位, 从而最终导致false negatives。对于Bloom filter而言,false negatives是不被允许的。 Counting Bloom filter由于采用了计数,因此支持remove操作。

    Bloom filter 使用的 k 个index functions,有时也被称为hash functions,它们通常被假定为彼此独立,返回值在可能的取值范围内均匀分布(这是以下一系列数学证明的基础)。

 

2 The Math

    Bloom filter的基本概念并不复杂,接下来分析一下query操作对某个未被添加的成员返回positive(即false positive)的概率:

    假设p是位数组中某一位为1的概率, 那么false positive的概率是 pk 。如果n是已经添加到Bloom filter中的成员个数,那么 p = 1 – (1 – 1/m)nk,经过一系列推导得到 p 1 – e-kn/m k 当 k = m / n * ln2 时(ln 即 loge ),p为最小值。 例如当k = 8, m/n = 10时, false positive的理论值为0.00846。以下是段计算false positive的实例代码:

 

public static double calculateFalsePositiveProbability(int k, int m, int n) {
	return Math.pow((1 - Math.exp(-k * (double) n  / (double) m)), k);
}

 

 

 

    对于某些应用而言,false positive的概率已经是一个足够好的判断Bloom filter准确性的指标,Peter C.Dillinger 和 Panagiotis Manolios 在其Bloom Filters in Probablistic Verfification的论文中指出,对于query过程中的不确定性, state omission 是一个更合适的指标。建议感兴趣的读者阅读该论文,顺便也可以复习一下相关的数学知识。

 

3 Refinement

    So far, so good。 跟普通的HashMap相比, Bloom filter不需要在内存中保存key和value, 而是位数组中的若干个位即可,这在内存使用上是个巨大的节省,当然前提是能容忍一定概率的false positives。但是传统的Bloom filter存在以下两个严重的缺陷:

  • 为了保证足够低的false positive概率,通常索引函数的个数 k 比较大(例如十几甚至几十,但通常不超过32)。 能找到这么多个random,uniform and independent的索引函数并不是一件容易的事情。
  • 数量众多的索引函数,导致add和query的性能不高。

    Peter C.Dillinger 和 Panagiotis Manolios在其论文中指出,fingerprinting Bloom filter可以有效地减少索引函数的个数,并且对准确性的影响可以小到忽略。这对于传统的Bloom filter来说,是个重大的改进。笔者使用了其中介绍的triple hashing,认为效果比较明显。

 

4 Implementation

    如果Google以Java实现的Bloom filter, java-bloomfilter 可能是最容易找到的实现之一。它采用的是传统的Bloom filter算法:使用的 k 个索引函数(默认都是MD5),只是索引函数在进行计算时对参数的加盐(salting)不同而已。笔者认为 java-bloomfilter 的性能可能有待提升。

    Hadoop common的util包中也提供了一个Bloom Filter的实现,此外其hash包还提供了JenkinsHash 和 MurmurHash 两个Hash算法。笔者感觉Hadoop 的Bloom filter的实现方式类似fingerprinting Bloom filter,但是没有使用double hashing 或者tripple hashing。

    此外关于位数组的实现方式,可能最直接想法的是使用java.util.BitSet。不过笔者认为如果处理的数据量很大、或者性能要求比较高,那么不建议使用java.util.BitSet, 因为java.util.BitSet的内存使用方式、总体性能都不是很理想。

 

 

5 Reference

  1. Bloom Filters in Probablistic Verfification. Peter C.Dillinger and Panagiotis Manolios
  2. Hadoop的Bloom filter实现。http://hadoop.apache.org/common/
  3. java-bloomfilter.  http://code.google.com/p/java-bloomfilter/
分享到:
评论

相关推荐

    bloom filter布隆过滤器学习资料大全

    bloom filter布隆过滤器学习资料大全,收集了很多相关的论文,并总结了各种布隆过滤器的变种

    大数据 海量数据 处理方法总结

    大数据量,海量数据 处理方法总结 包括Bloom filter 哈希 bit-map 堆 双层桶划分 数据库索引 倒排索引 外排序 trie树等。细分为适用范围、要点、实例等。

    常用大数据量、海量数据处理方法__算法总结.pdf

    大数据常用的处理算法总结,包括hash算法,分治算法,bloom filter,等等

    Java面试题比较全的知识点总结.docx

    1.什么是Redis? 答:Remote Dictionary Server(Redis)是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key- Value...如果你说还玩过Redis Module,像BloomFilter,RedisSearch,Redis-ML

    以太坊的数据结构(状态树、交易树、收据树)及代码分析

    文章目录一、状态树1.1 trie1.2 Patricia tree(trie)1.3 Merkle Patricia tree(trie)1.4 Modified Merkle Patricia tree(trie)1.5 账户状态值存储...Merkle Patricia tree(trie)2.3 布隆过滤器(bloom filter)2.4 总结...

    常用大数据量、海量数据处理方法__算法总结

    大数据量的问题是很多面试笔试中经常出现的问题,比如百度,谷歌,腾讯这样的一些涉及到海量数据的公司经常会问到。 本文的一些问题基本直接来源于...包括Bloom filter,Hashing,bit-map,双层桶划分,倒排索引等。

    php 大数据量及海量数据处理算法总结

    1.Bloom filter 适用范围:可以用来实现数据字典,进行数据的判重,或者集合求交集 基本原理及要点: 对于原理来说很简单,位数组+k个独立hash函数。将hash函数对应的值的位数组置1,查找时如果发现所有hash函数...

    bitmap和布隆过滤器简单总结

    字符串映射到 BitMap 存在Hash碰撞的问题(引入bloom filter) 3、不适合数据稀疏。比如要存入(10,10000,100000000)这三个数据(引入 Roaring BitMap) 3、应用场景 对 不重复的 密集整数 进行排序 查找数据是否存在...

    海量数据处理方法总结

    大数据量的问题是很多面试笔试中经常出现的问题,下面的方法是我对海量数据的处理方法进行了一个一般性的总结,当然这些方法可能并不能完全覆盖所有的问题,但是这样的一些方法也基本可以处理绝大多数遇到的问题。...

    布隆过滤器+CBF scala实现+代码详解

    文章目录简介BloomFilterBloomFilter的简单优化改进BloomFilterspark 的布隆过滤器scala实现BF、CBF 简介 ...BloomFilter 使用范围:可以用来实现数据字典,进行数据的判重,或者集合求交 原理:位数

    差分隐私技术研究进展

    随着大数据共享时代的...然后,着重对最新的基于本地差分隐私模型下的数据收集与数据分析进行阐述,涉及众包模型下的随机响应、BloomFilter、统计推断等技术。最后,对差分隐私技术面临的主要问题和解决方案进行总结。

    python实现布隆过滤器及原理解析

    本质上布隆过滤器( BloomFilter )是一种数据结构,比较巧妙的概率型数据结构(probabilistic data structure),特点是高效地插入和查询,可以用来告诉你 “某样东西一定不存在或者可能存在”。 相比于传统的 Set、...

    lrucacheleetcode-thinking-in-algorithm:flag:7天入门数据结构与算法

    位运算Bitwise,布隆过滤器BloomFilter LRU Cache 算法 if-else,switch for,while loop 递归Recursion(Divide & Conquer,Backtrace) 搜索Search:深度优先搜索Depth first search,广度优先搜索Breadth first ...

    leetcode_learning:LeetCode学习题解

    leetcode_learning 概述 java学习过程中源码 包说明 ...leetcode题解源码 类名规则:否+ leetcode原题编号+“ _” + leetcode原题名称 ...bloom_filter布隆过滤器 超级日志HyperLogLog(投影基数的近似最优算法)。

Global site tag (gtag.js) - Google Analytics