微信扫码
添加专属顾问
01
随着自然语言处理和深度学习的高速发展,向量检索为提升搜索用户体验发挥出重要作用,近似最近邻(ANN)搜索是在有限时空条件下实现向量搜索的主要方式。ANN的核心思想是近似,所有ANN算法都致力于在低规模计算开销下保证最后选择的邻居是查询向量的最近邻概率很高,但不追求100%的准确性。根据近似思路的不同,ANN检索算法主要分为四类:基于树的ANN算法、基于LSH的ANN算法、基于量化的ANN算法和基于图的ANN算法。接下来对本文涉及的几种ANN算法原理进行简要介绍。
△IVF_FLAT
IVF_FLAT:如上图所示,基于量化[2]的方案是通过一组特定的点来表示全部的向量空间,每个特定点代表一个子空间,它常与倒排索引相结合[3],首先对向量空间进行划分,每个数据点按照与其最近的子空间质心形成倒排拉链,这样每条倒排拉链对应一个子空间,拉链中元素为落在该子空间的向量id。检索时首先通过与质心的距离计算选取若干个子空间,然后只计算所选子空间内数据点与查询向量的距离,排序后得到最后结果,该思路被称作IVF_FLAT方案。
△IVF_PQ
IVF_PQ:除了借助向量量化选取子空间减少计算以外,量化对于ANN检索的贡献还在于可以使用量化点计算量化距离从而代替精确距离的计算,这样减少了计算但会带来精度损失,这就要求量化的精度不能太低。乘积量化[3](PQ)可以借助几组子向量器的质心,产生大量的质心,降低量化学习的复杂度。它与残差量化[4]相结合可以在有限的时空条件下提升整体量化的精度。基于乘积量化的IVF方案经典思路如上图所示,它是在构建时先对所有数据进行一次向量量化,根据这次向量量化的簇心形成倒排拉链,然后计算出所有数据与其质心的残差,然后再对残差进行乘积量化,记录对应其量化点的编码。检索时同样先与向量量化的质心计算决定候选拉链减少计算量,然后计算查询与质心的残差后对候选点进行距离计算,计算距离时是计算查询残差与候选点的量化距离,最后进行距离排序后返回检索结果,该思路被称作IVF_PQ方案。
Cagra[6]:基于图的ANN方案进行向量检索的过程都是通过图索引中点的邻接关系逼近到和查询向量点距离最近的若干个结果,图索引的构造和检索策略是基于图的ANN搜索方案研究的重点,需要考虑准召、搜索效率和空间开销等多方面因素。经过业界的不懈研究,以HNSW[5]为代表的诸多基于图的方案凭借优异性能都得到了广泛应用,但大部分的图算法在构建流程和检索路由过程中很难充分利用到GPU的并行能力,NVIDIA针对图算法这一挑战自研了名为Cagra[6]的基于GPU的ANN图算法,如上图所示。该算法以NN-descent[7]图为基础,然后借鉴NGT[8]的路径调整的思路对边进行剪枝,最后对剪枝后的正向图与对应的反向图各取一半的边进行合并,生成最终的Cagra图索引。检索过程维护一个top-M(M大于等于返回结果数目K)的列表和一个长度固定的候选列表,每轮迭代局部排序出距离最小的top-M并更新,然后将top-M的未被检索的邻居添加到候选列表中,直至top-M列表的节点都被遍历,然后选取top-K作为结果返回。Milvus[9]数据库就是借助Cagra算法实现了出色的性能加速。
02
在百度的某一类搜索业务场景下,对单次用户查询,会进行扩展检索以召回更多样化的相关结果。具体的业务场景需求:
03
3.1 索引算法选择
RAFT[1]代码库是NVIDIA设计开发的一套开源代码库,包含了可广泛应用于机器学习和信息检索场景的基本算法和原语,这些算法经过CUDA加速优化并可以通过构建块使编程简易化。它提供了四种GPU-ANN算法:BruteForce、IVF_FLAT、IVF_PQ和Cagra,这些算法都通过相同名称的顶层接口来实现索引的构建(build)、存储(serialize)、加载(deserialize)、检索(search),为用户的使用提供了便利,以IVF_FLAT为例:
//T为数据的类型,IdxT为数据id的类型template <typename T, typename IdxT>auto build(raft::resources const& handle,//资源句柄const index_params& params,//构建索引参数raft::device_matrix_view<const T, IdxT, row_major> dataset) //显存中存储的数据集-> index<T, IdxT>;template <typename T, typename IdxT>void serialize(raft::resources const& handle,//资源句柄const std::string& filename,//存储文件名const index<T, IdxT>& index);//索引对象template <typename T, typename IdxT>index<T, IdxT> deserialize(raft::resources const& handle, //资源句柄const std::string& filename);//加载文件名template <typename T, typename IdxT>void search(raft::resources const& handle,//资源句柄const search_params& params,//检索参数const index<T, IdxT>& index,//索引对象const T* queries,//查询指针uint32_t n_queries,//查询数目uint32_t k,//每条查询返回结果数IdxT* neighbors,//返回结果id的指针float* distances,//返回结果距离的指针rmm::mr::device_memory_resource* mr = nullptr) //可选的内存资源指针
我们对RAFT支持的四种算法进行了对比测试以找到适合我们场景最佳的算法选型,主要结论如下:
因此我们的场景下,最终选择采用 IVF_INT8 索引算法。
3.2 离线建库
std::shared_ptr<rmm::mr::device_memory_resource> resource_ptr = std::make_shared<rmm::mr::managed_memory_resource>();rmm::mr::set_current_device_resource(resource_ptr.get());raft::device_resourcesdev_resources(rmm::cuda_stream_per_thread, {nullptr}, resource_ptr);索引调参
拉链长度控制:
IVF_INT8在构建阶段需要训练簇心,训练数据从构建索引数据中按一定比例获取,由kmeans_trainset_fraction参数控制。而构建多少条倒排链由n_lists参数决定,该建库参数影响着达到目标召回率时的检索计算量,因此需要调参以获得更佳的检索性能。
我们实践的经验规律是控制平均链长在一千到两千之间时,有较好的综合性能表现。
//DataT为输入数据的类型,MathT为实际进行kmeans的类型,IndexT为数据id的类型,MappingOpT为数据类型映射的类型template <typename DataT, typename MathT, typename IndexT, typename MappingOpT = raft::identity_op>void fit(const raft::resources& handle, //资源句柄 kmeans_balanced_params const& params, //kmeans平衡聚类所需的参数 raft::device_matrix_view<const DataT, IndexT> X, //训练数据集 raft::device_matrix_view<MathT, IndexT> centroids, //聚类中心 MappingOpT mapping_op = raft::identity_op()) //输入数据类型到计算数据类型的映射
3.3 在线检索
下图展示了我们所设计的基于GPU的ANN在线检索方案,通过batch检索来达到充分发挥GPU并行计算能力的目的。在上游查询到达时,查询将会放入查询队列中,检索线程会按照batchsize取出对应数量的query组成BatchQuery,并将其作为输入进行基于GPU的ANN检索。在检索过程中需要先将BatchQuery拷贝到显存中,然后在GPU上进行IVF_INT8算法检索,返回对应query顺序的BatchResult结果并将其从显存拷贝取出,检索服务模块对BatchResult按query拆分后进行算分、过滤等后置操作后返回结果到上游。
△在线检索方案
向量距离计算并行化 & 显存数据复用
基于实时流量统计的动态 batchsize 控制
整体上,通过借助RAFT代码中IVF_INT8算法的高效实现、动态batchsize控制和显存数据复用逻辑充分发挥了GPU的并行计算优势,使得检索服务单实例可以达到更高的查询的吞吐能力,降低了高流量场景下副本数,大大降低了所需成本。
3.4 达到的效果
根据上述方案实现并测试后,对2500w256维数据集构建索引,索引所占显存<10G,建库时间<10分钟,检索服务单实例在返回结果top30的条件下可以承载约2w qps,平均查询延时在ms级。在我们的高检索流量落地场景中,总成本相比于CPU方案分别可以节省30%~50%资源。
04
4.1 GPU在ANN检索场景的讨论
在ANN算法设计上,CPU方案可以进行步骤繁杂的流程,而GPU方案需要简化搜索逻辑,减少数据依赖和同步阶段,加强并行度以发挥GPU的高并发能力。所以对延时要求相对宽容、查询流量较高的场景更适合GPU方案。
对于大规模数据ANN在线检索场景,由于单实例资源有限,全部数据索引很难存放于同一个实例中,因此要对数据进行划分成若干个库层,查询会分发给每个库层进行检索得到局部结果后进行合并从而得到最终结果;另一方面,每个实例能够处理的流量也是有限的,因此根据上游下发的流量需要建立若干个副本共同承担查询流量。一个库种的检索成本与其库层数和每个库层的副本数高度相关。
对于低流量下的ANN在线检索场景,每个库层只需要少数副本,因为CPU资源足以承担计算,应用GPU只会浪费算力并放大GPU价格昂贵的缺点,导致总资源成本增加。而对于高流量下ANN在线检索场景,高流量所带来的巨额总计算量为GPU取代CPU创造了可能。因为CPU算力有限,基于CPU的ANN方案处理检索的能力也是有限的,因此需要对每个库层增添大量副本,这无疑会对成本造成极大的压力。虽然GPU的价格要比CPU昂贵,但如果能够有效发挥出GPU的并发处理计算能力,那么使用GPU替代CPU进行ANN检索势必能够实现高吞吐处理请求的效果,这样单副本可以承载更多的流量,从而减少每个库层的副本数节省资源。
4.2 未来展望
53AI,企业落地大模型首选服务商
产品:场景落地咨询+大模型应用平台+行业解决方案
承诺:免费POC验证,效果达标后再合作。零风险落地应用大模型,已交付160+中大型企业
2026-06-28
Om AI第二弹!VLX-Seek来了:3B小模型,细粒度感知反超Gemini
2026-06-22
小参数,大能力 | 星际视觉语言大模型再进化,0.8B轻量版正式发布
2026-06-16
RapidOCR: 从 setup.py 迁移到 pyproject.toml 打包实践
2026-06-12
PaddleOCR 3.7 正式接入ONNX Runtime,一个参数换后端,轻量部署新选择
2026-06-11
本地部署OCR,可能是AI进单位的第一道门
2026-06-08
正式推出 Gemma 4 12B: 一款统一、免编码器的多模态模型
2026-05-30
还在用 MinerU 解析 PDF?这个 2B 小模型直接把 olmOCR-bench 刷到 87.6%,速度还快 3.68 倍
2026-05-30
Qwen-VLA:迈向通用具身智能的统一动作框架
2026-04-22
2026-04-01
2026-04-02
2026-04-27
2026-04-21
2026-04-09
2026-04-15
2026-04-02
2026-04-01
2026-04-01
2026-03-12
2025-12-31
2025-08-04
2025-05-26
2025-05-13
2025-04-08
2025-04-05
2025-03-30
欢迎您使用【53AI 官方网站】(以下简称“本网站”或“我们”)。本《会员服务协议》(以下简称“本协议”)是您(以下简称“会员”或“用户”)与【深圳市博思协创网络科技有限公司】之间关于注册、登录及使用本网站会员服务所订立的法律协议。
在您注册或登录前,请务必审慎阅读、充分理解各条款内容,特别是免除或限制责任的条款、知识产权条款、争议解决条款等。此类条款将以加粗形式提示您注意。 当您通过微信公众号授权、手机验证码验证或其他方式成功登录本网站时,即视为您已完全理解并同意接受本协议的全部内容。
一、 定义
本网站:指由【深圳市博思协创网络科技有限公司】运营的,域名为【53ai.com】的网站及相关移动端页面。
会员服务:指本网站向注册会员提供的知识库文章查阅、内容检索及其他相关增值服务。
知识库内容:指本网站发布的包括但不限于文字、图表、数据、研究报告、行业分析等数字化内容资源。
二、 账号注册与登录
登录方式:本网站支持以下登录方式,您可根据实际情况选择:
微信公众号授权登录:您同意将您的微信OpenID信息授权给本网站,用于创建或关联会员账号。
手机验证码登录:您需提供真实有效的手机号码,并通过短信验证码完成身份验证与登录/注册。
账号安全:您的账号仅限您本人使用,禁止赠与、借用、租用、转让或售卖。因您保管不善导致的账号被盗、密码泄露等损失,由您自行承担。
实名认证:根据相关法律法规要求,我们可能要求您在特定功能下完成实名认证。如您拒绝提供,可能无法使用部分或全部服务。
未成年人保护:若您未满18周岁,请在法定监护人的陪同下阅读本协议,并在征得监护人同意后使用本服务。
三、 服务内容与规范
知识库查阅权限:会员登录后,有权按照其会员等级对应的权限范围,在线浏览、检索本网站知识库中的相关文章及内容。
服务变更:我们有权根据业务发展需要,调整、变更或终止部分服务内容,并将以网站公告、公众号消息等方式提前通知。
禁止行为:您在使用服务时不得实施以下行为:
利用技术手段批量爬取、下载、转存知识库内容;
将知识库内容用于商业目的或未经授权地向第三方传播;
干扰本网站正常运行或侵犯其他用户合法权益;
发布违法违规信息或从事违反公序良俗的活动。
四、 知识产权声明
权利归属:本网站知识库中的排版设计、软件代码等内容的知识产权均归【公司全称】或原权利人所有,受《中华人民共和国著作权法》等法律保护。
有限许可:本网站授予会员一项非独占、不可转让、不可转授权的普通许可,仅限于个人学习、研究之目的在线查阅知识库内容。
侵权追责:未经书面许可,任何单位或个人不得以任何形式复制、转载、摘编、镜像、汇编或以其他方式使用上述内容。一经发现,我们保留追究其法律责任的权利。
五、 个人信息保护
我们重视对您个人信息的保护。关于我们如何收集、使用、存储和保护您的个人信息,请单独阅读 《隐私政策》。
您通过微信公众号授权或手机号验证所提供的信息,我们将严格按照《个人信息保护法》的规定处理,仅用于身份识别、服务提供及安全验证等必要用途。
您可以随时通过网站设置或联系客服行使查阅、更正、删除个人信息及撤回授权同意的权利。
六、 免责声明
内容准确性:知识库内容仅供参考,不构成专业建议。我们不对其完整性、准确性、时效性作任何明示或暗示的保证,您应自行判断并承担使用风险。
不可抗力:因自然灾害、政策法规变化、网络故障、第三方平台接口异常(如微信接口维护、运营商短信通道故障)等不可抗力导致的服务中断或延迟,我们不承担违约责任。
第三方链接:本网站可能包含指向第三方网站的链接,该等网站的内容和服务不受我们控制,请您自行甄别风险。
七、 违约责任
如您违反本协议约定,我们有权视情节采取警告、限制功能、暂停服务、注销账号等措施,并保留要求赔偿损失的权利。
如因您的违约行为导致我们遭受行政处罚、第三方索赔或商誉损失,您应承担全部赔偿责任(包括但不限于罚款、赔偿金、律师费、公证费等)。
八、 法律适用与争议解决
本协议的订立、执行和解释均适用中华人民共和国大陆地区法律。
因本协议产生的或与本协议有关的任何争议,双方应友好协商解决;协商不成的,任何一方均可向【公司所在地】有管辖权的人民法院提起诉讼。
九、 其他
本协议构成双方就本服务达成的完整协议,取代此前任何口头或书面约定。
本协议任一条款被认定为无效或不可执行的,不影响其他条款的效力。
我们对本协议享有最终解释权,并在法律允许的范围内保留随时修改的权利。修改后的协议一经公布即生效,继续使用服务即视为同意修订内容。