SuRF(Succinct Range Filter)是一种快速而紧凑的过滤器,同时支持点查询和范围查询(包括开区间查询、闭区间查询、范围计数),可以在RocksDB中用SuRF来替换Bloom过滤器。

FAST SUCCINCT TRIES

SuRF是基于FST(Fast Succinct Tries)的,这是一种同时支持点查询和范围查询,且具有高效的空间利用率的静态字典树。FST的设计是基于如下观察结果:字典树的上层包含了相对较少的节点,但却发生了相对较多的访问,而字典树的下层包含了相对较多的节点,但发生的访问较少。因此FST包含了LOUDS-Dense和LOUDS-Sparse两个部分,LOUDS-Dense优先考虑性能而不是空间占用,LOUDS-Sparse高效地利用空间从而限制了FST的总体空间占用。

下图(引用自论文)是一个FST的例子:

LOUDS-Dense

LOUDS-Dense中的每个节点包含了3个256位的bitmap和一个字节序列,他们的含义如下:

  1. D-Labels:标记该节点的分支表示的字符。如果一个节点的分支表示的字符在bitmap中的相应位是1,该位的下标为这个字符的ASCII码值。$是一个特殊字符,表示到该节点某个分支位置的前缀也是一个合法的key。
  2. D-HasChild:标记该节点的每个分支是否还有子节点。
  3. D-IsPrefixKey:标记到该节点某个分支为止的前缀是否也是一个合法的key。
  4. D-Values:是按序排列的一些与每个key对应的定长的值。

两个公式:

  1. D-ChildNodePos(pos) = 256 ×rank1(D-HasChild, pos):计算第一个子节点的位置。
  2. ParentNodePos(pos) = 256 ×select1 (D-HasChild, ⌊pos/256⌋) :计算父节点的位置。

LOUDS-Sparse

LOUDS-Dense中的每个节点包含了2个字节序列和2个bitmap,他们的含义如下:

  1. S-Labels:标记该节点的分支表示的字符。
  2. S-HasChild:标记该节点的每个分支是否还有子节点。
  3. S-LOUDS:标记该节点的每个分支是否是该节点的第一个分支。
  4. S-Values:和D-Values一样。

三个公式:

  1. S-ChildNodePos(pos) = select1(S-LOUDS, rank1(S-HasChild, pos) + 1)
  2. S-ParentNodePos(pos) = select1(S-HasChild, rank1(S-LOUDS, pos) - 1)
  3. S-ValuePos(pos) = pos - rank1(S-HasChild, pos) - 1

FST的优化

FST中最典型的操作就是rank、select和label search,FST对这三个都做了优化。

下图(引用自论文)是FST优化的一个例子:

  1. rank优化:对于一个bit-vector,每B位作为一个block,每个block在LUT中分配32位的空间来存储这个block起始位置的rank值。LOUD-Dense的B是64,这就保证了popcount指令在每次rank计算时只需要调用一次,LOUD-Sparse的B是512,适应于cacheline的大小,而且可以节省空间。
  2. select优化:对于每一个采样查询,在LUT中分配32位的空间来存储这次采样查询得到的select的值。

SUCCINCT RANGE FILTERS

为了平衡FPR和空间占用,基于FST的SuRF采用了删减的字典树,并有四种模式:

  1. SuRF-Base:对于用于构建SuRF的key,只截取在所有key中能唯一区分这个key的最短的前缀。这种模式的空间占用最小,但是FPR最高。
  2. SuRF-Hash:在SuRF-Base的基础上,对于每个key,在叶节点的Values里存储这个key的哈希值的后n位,当搜索到叶节点后,还需要比较这个哈希值的后n位。这种模式能极大的减小点查询的FPR,但是并不会减小范围查询的FPR,因为key的哈希值无法用于比较key的顺序。
  3. SuRF-Real:在SuRF-Base的基础上,对于每个key,存储这个key用于构建SuRF的前缀之后的n位,当搜索到叶节点后,还需要比较这n位。这种模式可以同时提升点查询和范围查询的FPR,但是提升的效果不如SuRF-Hash。
  4. SuRF-Mixed:SuRF-Hash和SuRF-Real的结合。

382 Love u

SuRF: Practical Range Query Filtering with Fast Succinct Tries 阅读笔记的更多相关文章

  1. SuRF : Practical Range Query Filtering with Fast Succinct Tries

    1. Introduction 在数据库管理系统中查找某些关键字会导致很大的磁盘I/O开销,针对这一问题,通常会使用一个内存开销小并且常驻内存的过滤器来检测该关键字是否存.比如现在常用的bloom过滤 ...

  2. Fast R-CNN论文阅读笔记

    论文地址:Fast R-CNN R-CNN的缺陷 (1)训练是一个多级的流水线.R-CNN首先在候选目标上微调一个卷积神经网络,使用log loss.然后使用SVMs充当目标分类器,以取代softma ...

  3. elasticsearch term 查询二:Range Query

    Range Query 将文档与具有一定范围内字词的字段进行匹配. Lucene查询的类型取决于字段类型,对于字符串字段,TermRangeQuery,对于数字/日期字段,查询是NumericRang ...

  4. [论文阅读笔记] Fast Network Embedding Enhancement via High Order Proximity Approximati

    [论文阅读笔记] Fast Network Embedding Enhancement via High Order Proximity Approximation 本文结构 解决问题 主要贡献 主要 ...

  5. 【题解】【数组】【Prefix Sums】【Codility】Genomic Range Query

    A non-empty zero-indexed string S is given. String S consists of N characters from the set of upper- ...

  6. How to write date range query in Nest ElasticSearch client?

    Looking at the source code, there are two overloads of the OnField method. When I use the the that t ...

  7. SCU 4443 Range Query

    二分图最大匹配,枚举. 可以计算出每一个位置可以放哪些数字,每个数字可以放在哪些位置,这样就可以建二分图了. 如果二分图最大匹配不到$n$,则无解.否则构造字典序最小的解,可以枚举每一位放什么数字,然 ...

  8. 第十五届四川省省赛 SCU - 4443 Range Query

    先给你1~N的N个数 再给你每种最多50个的条件(ai,bi,ci) 或者[ai,bi,ci] (ai,bi,ci)表示下标ai到bi的最小值必为ci [ai,bi,ci]表示下标ai到bi的最大值必 ...

  9. Fast R-CNN论文阅读摘要

    论文链接: https://arxiv.org/pdf/1504.08083.pdf 代码下载: https://github.com/rbgirshick/fast-rcnn Abstract Co ...

随机推荐

  1. 用于模拟百度分享的errno错误代码

    0:成功;-1:由于您分享了违反相关法律法规的文件,分享功能已被禁用,之前分享出去的文件不受影响.;-2:用户不存在;请刷新页面后重试;-3:文件不存在;请刷新页面后重试;-4:登录信息有误,请重新登 ...

  2. dm_analysis

    # -*- coding: utf-8-*- # import sys import os import io import json reload(sys) sys.setdefaultencodi ...

  3. TCP/IP学习20180709-数据链路层-arp协议

    arp协议:address resolution protocol地址解析协议数据链路层,每个数据包都有MAC地址.主机是怎样根据对方主机的ip地址知道对方主机的mac地址呢?通过arp协议.主机里有 ...

  4. 【kubenetus】kubenetus运维

    重启K8S服务 systemctl stop kubelet systemctl stop kube-apiserver systemctl stop kube-proxy systemctl sto ...

  5. maven私库nexus2.3.0-04迁移升级到nexus-3.16.1-02(异机迁移备份)

    环境信息: nexus2.3.0-04安装在32位Windows server 2003系统上 安装位置信息如下: 仓库迁移 Nexus的构件仓库都保存在sonatype-work目录中,nexus2 ...

  6. 去中心化存储项目终极指南 | Filecoin, Storj 和 PPIO 项目技术对比(下)

    在上篇文章中,我们主要从价值定位.技术层次架构.服务质量.去中心化程度,和经济激励机制五个方面分析了三个项目的不同.在这一篇文章中,我们将着重从区块链的架构设计.数据传输技术设计和数据存储技术设计三方 ...

  7. visual studio 2015引入开源控件DockPanel(最简单的方法)

    一.DockPanel简介 DockPanel是一个开源控件,能够实现子窗口的浮动,在官方给的demo有演示,在vs2017微软已经集成进入常用控件中.我主要使用的是多窗口浮动,和tabControl ...

  8. C++调用JS函数

    1 调用方法 https://blog.csdn.net/donglinshengan/article/details/29828103 https://blog.csdn.net/sunmz_wjx ...

  9. python版本的简单贪吃蛇

    先看看效果,白色的条是蛇(简单勿怪,有研究的同学请告知做的美观点),做了一个笑脸是糖果,背景弄了一个图, 代码也是从其他人那边弄来的,改了一部分直接可以在window上直接运行 代码如下: #codi ...

  10. JS面试Q&A(续2): Rest parameter,Arrow function 等

    rest parameter 和 Destructuring assignment. function fun1(...theArgs) { console.log(theArgs.length);} ...