向量化召回算法ANN、IVF、HNSW、IVF-PQ

ANN(Approximate Nearest Neighbor) 意为近似近邻搜索,即通过模型预计算,建立索引或图以便在线检索时通过剪枝或图检索从而加速检索过程,通常为非穷尽检索。目前常用的ANN 检索方式有 IVF, HNSW, BTree, IVF-PQ。

IVF

IVF(lnverted File)通过在模型预计算时将所有候选进行KMeans聚类,即检索距离最近的m个聚类蔟,遍历这m个聚类蔟下所有候选,计算得出距离最近的topk候选。扩大IVF检索覆盖范围或增加聚类数都可以提高检索精度,这也正是IVF-PQ以及BTree分别采用的思路。

HNSW

HNSW(Hierarchical Navigable Small World) 类似于跳表的思想,在构建阶段,在搜索时,从最高层的入点出发,逐层贪心搜索距离query vec最近的点,当一层达到收敛后,进入下一层,直至到达底层,在底层L0中,包含候选集中所有的点,即全量数据图网络。在L0层中开始深度优先搜索距离query vec最近的候选点集,每次将距离query vec最近的点加入候选点集中,若候选点集已满,则弹出最远候选点,直至候选点集收敛。

微软、FB、阿里的相关论文(DistANN,NSG,SSG)对HNSW的性能做了大量的研究与改进,经验上来说,召回的topk比较小的情况下(例如召回只有几百的情况下),HNSW的召回率较高,因此HNSW更适合推荐场景;但如果召回的topk比较大的情况下(例如召回达到2000左右的规模),IVF更适合一些,因此IVF和后面的PQ-IVF也更适合广告场景

图片来自 https://www.pinecone.io/learn/series/faiss/hnsw/

BTree

BTree和IVF相比主要是通过使用GPU来大幅度增加聚类中心点来优化。IVF跑在CPU上如果聚类中心点过多,速度会比较慢。

IVF-PQ

IVF-PG中的PQ意思是Product Quantization,常用的量化方式有Fix16、Int8和PQ

Fix16

通过全局的scale,把float32量化到fix16,从而节省一半的存储

int8

int8就不能像Fix16直接使用全局的scale,精度丢失的太厉害,因此常有的有两种思路:

QAT (Quantization-aware Training / 量化感知训练)

简单来说就是把量化带来的误差引入到模型训练中,使得模型能够学习到全局唯一的scale(对称量化

PTQ(Post Training Quantization /训练后量化)

逐条向量中的每一条根据最大元素放缩,每一条向量都有自己的scale和offset(非对称量化

Product Quantization

In short, PQ is the process of:

  • Taking a big, high-dimensional vector,
    Splitting it into equally sized chunks --- our subvectors,
  • Assigning each of these subvectors to its nearest centroid (also called reproduction/reconstruction values),
  • Replacing these centroid values with unique IDs --- each ID represents a centroid

在PQ中,每个subvector的量化器还是由kmeans得到

图片来自https://www.pinecone.io/learn/series/faiss/product-quantization/

IVF-PQ

IVF_PQ先将所有的候选向量通过kmeans划分到多个聚类簇中,然后将每个候选向量与其中心点做差得到残差向量,得到残差向量矩阵,再对此残差向量矩阵进行PQ量化。如果不用残差的话,原始向量可能会有特别大的分布差异/不平衡

相关推荐
焜昱错眩..13 分钟前
代码随想录算法训练营第三十九天|62.不同路径 63.不同路径ll
算法
焦耳加热4 小时前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn4 小时前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6064 小时前
常用排序算法核心知识点梳理
算法·排序
蒋星熠7 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小欣加油7 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展
3Cloudream7 小时前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
算法·leetcode·字符串·双指针·滑动窗口·哈希表·中等
王璐WL7 小时前
【c++】c++第一课:命名空间
数据结构·c++·算法
空白到白8 小时前
机器学习-聚类
人工智能·算法·机器学习·聚类
索迪迈科技8 小时前
java后端工程师进修ing(研一版 || day40)
java·开发语言·学习·算法