布隆过滤器、计数布隆过滤器与其应用课件.pptx
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《布隆过滤器、计数布隆过滤器与其应用课件.pptx》由用户(三亚风情)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 过滤器 计数 与其 应用 课件
- 资源描述:
-
1、信息安全课程报告Bloom filter - The course report of Information security布隆过滤器组长: 汇报人:目录CONTENTS1背景介绍2算法描述3误判概率证明和计算4优劣详解6布隆过滤器设计和应用5布隆过滤器改进方案布隆过滤器 背景介绍The background of Bloom filter01比如在字处理软件中,需要检查一个英语单词是否拼写正确(也就是要判断 它是否在已知的字典中);在 FBI,一个嫌疑人的名字是否已经在嫌疑名单上;在网络爬虫里,一个网址是否被访问过等等。背景介绍 一般来讲,计算机中的集合是用哈希表(hash table)
2、来存储的。 Hash函数作用就是把要存的数据映射成hash表中的一个位置,这个位置就是你要存放该数据的地方。一般把hash表的每个位置都叫做“槽(slot)”。 它的好处是快速准确,缺点是浪费存储空间。当集合比较小时,这个问题不显著,但是当集合巨大时,哈希表存储效率低的问题就显现出来 了。Hash函数假设hash表的大小为9(即有9个槽),hash(k) = k mod 9,现在要把一串数据存到表里:5,28,19,15,20,33,12,17,10 hash(5)=5, hash(28)=1,hash(19)=1, 0 1 2 3 4 5 6 7 8 n个关键字映射到k个槽中,n只要大于k,
3、一定至少有一个槽放了多于1个元素,所以不能完全避免碰撞(冲突) 。 Hash函数285位图法就是Bitmap的缩写。就是用每一位来存放某种状态,适用于大规模数据,但数据状态又不是很多的情况。通常是用来判断某个数据存不存在的。 位图法可以理解为通过一个bit数组来存储特定数据的一种数据结构;由于bit是数据的最小单位,所以这种数据结构往往是非常节省存储空间。位图法比如一个公司有8个员工,现在需要记录公司的考勤记录,传统的方案是记录下每天正常考勤的员工的ID列表,比如2012-01-01:1,2,3,4,5,6,7,8。 假如员工ID采用byte数据类型,则保存每天的考勤记录需要N个byte,其中
4、N是当天考勤的总人数。 1 2 3 4 5 6 7 8 这样可以每天采用恒定的1个byte即可保存当天的考勤记录。位图法01110011布隆过滤器(Bloom Filter),它结合了位图和Hash表两者的优点. 位图的优点是节省空间,但是只能处理整型值一类的问题,无法处理字符串一类的问题. 而Hash表却恰巧解决了位图无法解决的问题,然而Hash太浪费空间。布隆过滤器布隆过滤器计数计数布隆过滤器布隆过滤器 计数布隆过滤器是对基本布隆过滤器的改进,使布隆过滤器可以支持删除成员。 因为布隆过滤器的基本单位是1个bit,只能表达2种状态,即存在、不存在。 如果把基本单位1bit拓展成多个bit,这
5、样就能增加更多信息,表达出多种状态。布隆过滤器 算法描述The description of its core algorithm 02Bloom Filter 布隆过滤器(Bloom Filter)是一种概率空间高效的数据结构。用于检索一个元素是否在一个集合中用于检索一个元素是否在一个集合中。 存在“在集合内(可能错误)在集合内(可能错误)”和“不在集合内(绝对不在集不在集合内(绝对不在集合内)合内)”两种情况。 温故知新 核心思想核心思想就是利用多个不同的多个不同的Hash函数函数来解决“冲突”。 如何判断某元素x是否在一个集合中?X1,X2,X3.XnRX核心思想算法原理 Bloom F
6、ilter需要一个位数组位数组(和位图类似)和K个映射函数个映射函数(和Hash表类似)。包含两种操作:插入和查询插入和查询1.初始化:将所有位置置02. 集合R=r1,r2.rn,通过k个相互独立的映射函数h1,h2,.hk,将集合R中的每个元素rj(1=j 忽略碰撞并且只存储元素是否在其中的二进制信息时k=1的布隆过滤器 使用k1的布隆过滤器,即k个哈希函数将每个元素改为对应于k个bits,因为误判度会降低很多,并且如果参数k和m选取得好,一半的m可被置为1,这充分说明了布隆过滤器的空间效率性。优点 布隆过滤器可以表示全集,其它任何数据结构都不能。 k和m相同,使用同一组散列函数的两个布隆
7、过滤器的交并差运算可以使用位操作进行。优点 在增加了错误率这个因素之后,布隆过滤器通过允许少量的错误来节省大量的存储空间。优点 有误判的概率,即存在假阳性(False Position),无法获取集合中的元素数据。 随着存入的元素数量增加,误算率随之增加。但是如果元素数量太少,则使用散列表足矣。(误判补救方法是:再建立一个小的白名单,存储那些可能被误判的信息。)缺点 一般情况下不能从布隆过滤器中删除元素。 另外计数器回绕也会造成问题。缺点布隆过滤器 改进方案The design and application in Bloom filter0500000000001亿邮箱随机数生成器随机数生成
8、器F1-8f1 = F1 f2 = F2f3 = F3f4 = F4 f5 = F5f6 = F6f7 = F7f8 = F8信息信息指纹指纹随机数生成器随机数生成器G10111111102111111110f1 = F1 = f1 f2 = F2 f3 = F3 = m2f4 = F4 = m3 f5 = F5 = m4f6 = F6 = m5f7 = F7 = m6f8 = F8 = m7CounterCounting Bloom FilterCounting Bloom Filter的出现解的出现解决了这个问题,它将标准决了这个问题,它将标准Bloom Bloom FilterFilte
9、r位数组的每一位扩展为一个位数组的每一位扩展为一个小的计数器小的计数器(Counter)(Counter),在插入元素,在插入元素时给对应的时给对应的k(kk(k为哈希函数个数为哈希函数个数) )个个CounterCounter的值分别加的值分别加1 1,删除元素时,删除元素时给对应的给对应的k k个个CounterCounter的值分别减的值分别减1 1,Counting Bloom FilterCounting Bloom Filter通过多占用通过多占用的存储空间的代价,给的存储空间的代价,给Bloom Bloom FilterFilter增加了删除操作。增加了删除操作。10110102
10、10BFCBFn n:集合元素个数,集合元素个数,k k:HashHash函数个数,函数个数,k = 0.7 * m / n M M:位数组的大小位数组的大小从从nknk次哈希中选择次哈希中选择j j次次j j次哈希都选中了第次哈希都选中了第i i个个CounterCounter其它其它nkjnkj次哈希没有次哈希没有选中第选中第i i个个CounterCounter基本思想:基本思想:1.1.元素元素x x对应的对应的k k个个countercounter中的最小值中的最小值m mx x=出现频率出现频率f fx x2.2.f fx x m mx x的概率和标准的概率和标准bloom fil
11、terbloom filter的误判概率相同的误判概率相同5016111210k k个位置全个位置全部发生碰撞部发生碰撞索引结构索引结构co1co2co3co4o1o2o3o4子串长度子串长度log3N位位Coarse VectorCoarse Vectorco1co2o1o2子串长度子串长度(loglogN)3位位LOOK UP TABLEOffset VectorOffset Vector子串长度子串长度=(loglogN)3位位loglog2 2N N个个countercounterlogN/loglogNlogN/loglogN025701026527Counter0000010001
展开阅读全文