使用 FAISS 进行高效相似性搜索:从文本检索到动态数据处理
-
在现代数据科学和人工智能应用中,处理大量高维数据并从中找到相似项是一个常见任务。无论是在推荐系统、搜索引擎,还是在自然语言处理应用中,如何高效地进行相似性搜索(Similarity Search)一直是一个挑战。为了解决这个问题,FAISS(Facebook AI Similarity Search)应运而生,成为了处理和检索高维数据的一个重要工具。
-
在本文中,我们将介绍FAISS的基本概念、如何使用它进行相似性搜索、以及如何处理动态数据的常见问题。
文章目录
- 什么是 FAISS?
- FAISS 的核心特点
- FAISS 的常见应用
- 如何使用 FAISS 进行相似性搜索?
- 步骤 1: 文本嵌入
- 步骤 2: 创建 FAISS 索引
- 步骤 3: 查询
- 示例代码(Python):
- 示例输出:
- 如何处理动态数据?
- 添加新数据
- 示例代码(添加新数据):
- 删除数据
- 动态数据管理
- 总结
什么是 FAISS?
FAISS(Facebook AI Similarity Search)是由Facebook AI Research团队开发的一个开源库,专门用于高效的相似性搜索和聚类任务。它的设计目标是处理大规模数据集和高维空间的向量检索,广泛应用于推荐系统、搜索引擎和自然语言处理等领域。
FAISS 的核心特点
- 高效性能:FAISS通过优化算法,使得对大规模数据集的相似性搜索变得快速且高效。
- 索引方法多样:支持多种索引方式,包括精确检索(Flat Index)和近似最近邻(ANN)方法。
- GPU 加速:支持GPU加速,能进一步提高查询速度,特别是在处理非常大规模的数据时。
- 易于扩展和灵活性:可以处理千万级别的向量,支持不同的距离度量(如L2距离、余弦相似度等)。
FAISS 的常见应用
- 推荐系统:根据用户的历史行为推荐相似的产品或内容。
- 搜索引擎:根据查询内容检索最相关的文档或图像。
- 自然语言处理:在NLP中使用嵌入向量查找与查询句子相似的句子或文档。
如何使用 FAISS 进行相似性搜索?
假设我们有一系列句子,并且想要根据一个查询句子找到最相关的内容。以下是使用 FAISS 进行文本相似性搜索的一个简单示例。
步骤 1: 文本嵌入
首先,我们需要将句子转化为向量(嵌入)。这可以通过使用如Sentence-Transformers等模型来完成。
步骤 2: 创建 FAISS 索引
将生成的嵌入向量添加到 FAISS 索引中。FAISS 会为我们创建一个数据结构,能够快速检索相似向量。
步骤 3: 查询
我们可以输入一个查询句子,FAISS 会返回最相似的句子,通常基于L2距离(欧几里得距离)或余弦相似度。
示例代码(Python):
from sentence_transformers import SentenceTransformer
import faiss
import numpy as np# Step 1: Prepare your data
sentences = ["The cat sat on the mat.","Dogs are great pets.","I love programming in Python.","The weather is sunny today.","I enjoy reading books about AI."
]
query = "What are some benefits of having a dog?"# Step 2: Convert sentences to embeddings
model = SentenceTransformer('all-MiniLM-L6-v2')
sentence_embeddings = model.encode(sentences)
query_embedding = model.encode([query])# Step 3: Set up FAISS index
dimension = sentence_embeddings.shape[1] # Dimensionality of embeddings
index = faiss.IndexFlatL2(dimension) # L2 distance metric
index.add(np.array(sentence_embeddings)) # Add sentence embeddings to the index# Step 4: Perform a search
k = 3 # Number of nearest neighbors to retrieve
distances, indices = index.search(np.array(query_embedding), k)# Step 5: Display the results
print("Query:", query)
print("\nMost relevant sentences:")
for i, idx in enumerate(indices[0]):print(f"{i+1}. {sentences[idx]} (Distance: {distances[0][i]:.4f})")
示例输出:
Copy code
Query: What are some benefits of having a dog?Most relevant sentences:
1. Dogs are great pets. (Distance: 0.3215)
2. The cat sat on the mat. (Distance: 0.5432)
3. I enjoy reading books about AI. (Distance: 0.7891)
如何处理动态数据?
- 在很多应用中,数据是动态变化的。例如,新的句子不断被添加,或者已有的句子被删除。在这种情况下,我们需要能够动态更新 FAISS 索引。
添加新数据
- FAISS 允许你不断地向现有索引添加新的向量,而不需要重新构建整个索引。这对于大规模数据集来说非常有用。
示例代码(添加新数据):
# Add a new sentence to the index
new_sentence = "I enjoy hiking in the mountains."
new_embedding = model.encode([new_sentence])# Add the new sentence to the index
index.add(np.array(new_embedding)) # Add embedding of new sentence# Add the sentence to the list
sentences.append(new_sentence)
删除数据
-
FAISS 本身对于删除数据的支持较为有限。对于简单的 IndexFlatL2 索引,删除数据项通常意味着需要重建整个索引。但在一些复杂的索引类型(如 IVF 或 PQ)中,FAISS 提供了 remove_ids() 方法来删除特定的向量。
-
如果删除频繁,重建索引是比较常见的做法:
# Rebuild the index after removing a sentence (for example, at index 1)
sentences_to_keep = [s for i, s in enumerate(sentences) if i != 1]
index = rebuild_index(sentences_to_keep)
动态数据管理
- 对于大规模或频繁变化的场景,可以考虑以下几种方法:
- 增量添加:通过 add() 方法,动态地向索引中添加新的向量。
- 定期重建索引:如果删除操作很频繁,或者数据量变化较大,定期重建索引会更高效。
- 使用更复杂的索引类型:如 IndexIVF(倒排文件索引)或 IndexPQ(产品量化索引),它们提供了更高效的更新和删除机制。
总结
- FAISS 是一个高效的工具,专门用于处理和检索高维嵌入向量,它能够帮助我们在海量数据中快速找到相似项。通过与嵌入模型(如 Sentence-BERT、BERT 等)结合使用,FAISS 可以大幅提升相似性搜索的性能。
- 对于动态数据,FAISS 也提供了灵活的更新和查询功能,虽然在频繁删除的场景下可能需要重建索引,但通过合理的使用方式,可以高效地处理大规模数据的检索任务。
相关文章:
使用 FAISS 进行高效相似性搜索:从文本检索到动态数据处理
在现代数据科学和人工智能应用中,处理大量高维数据并从中找到相似项是一个常见任务。无论是在推荐系统、搜索引擎,还是在自然语言处理应用中,如何高效地进行相似性搜索(Similarity Search)一直是一个挑战。为了解决这个…...
执行“go mod tidy”遇到“misbehavior”错误
执行“go mod tidy”报错下错误,执行“go clean -modcache”和删除“go env GOMODCACHE”指定目录均无效: SECURITY ERROR go.sum database server misbehavior detected!old database:go.sum database tree3397826xyyhzdyAOat5li/EXx/MK1gONQf3LAGqArh…...
深入详解人工智能机器学习:强化学习
目录 强化学习概述 强化学习的基本概念 定义 关键组件 强化学习过程 常用算法 应用示例 示例代码 代码解释 应用场景 强化学习核心概念和底层原理 核心概念 底层原理 总结 强化学习概述 强化学习(Reinforcement Learning, RL)是机器学习中的…...
力扣打卡11:合并区间(比较器内联,引用传参的优化)
链接:56. 合并区间 - 力扣(LeetCode) 这道题可以用贪心。 首先将intervals的left(intervals[i][0])排序。 然后拿出第一个区间,比较后面相邻的区间: 当前right<后left,表示下一…...
《 bilibili-起步级 用户模块接口文档 经验分享 ~》
bilibili - 用户模块接口文档 - 经验分享 ~ 数据库er关系图 : 迅速跳转链接 枚举码实体类 : 迅速跳转链接 使用apifox.json格式导入接口文档 步骤 登录Apifox。新建文件, 将代码粘贴到该文件, 并更改后缀为 .apifox.json进入项目,点击“导入”。选择“Apifox”格式…...
AES 与 SM4 加密算法:深度解析与对比
🧑 博主简介:CSDN博客专家,历代文学网(PC端可以访问:https://literature.sinhy.com/#/literature?__c1000,移动端可微信小程序搜索“历代文学”)总架构师,15年工作经验,…...
启保停电路如何接到PLC
传感器:NPN :棕:正 蓝:负 黑:信号 1M——>24V PNP:1M——>0V...
HTTP multipart/form-data 请求
序言 最近在写项目的过程中有一个需求是利用 HTTP 协议传输图片和视频,经过查询方法相应的方法发现使用 multipart/form-data 的方式,这是最常见处理二进制文件的表单编码类型。 学习了一下午,现在总结一下使用的方法和相关的知识点&#x…...
配置服务器的免密登录
在服务器中配置别名和免密登录 如果没有生成过公钥和密钥 ssh-keygen然后就生成了公钥和密钥,下一步进入.ssh文件夹 cd .ssh/可以看到文件夹中会多出来三个文件 id_rsa:密钥id_rsa.pub:公钥known_hosts:A通过ssh首次连接到B&am…...
普通遥控电动遮阳雨棚怎么接入米家并用苹果手机Siri控制
环境: 遥控电动遮阳雨棚 无线射频拷贝器 米家APP 问题描述: 普通遥控电动遮阳雨棚怎么接入米家并用苹果手机Siri控制 解决方案: 1.先看看遥控器射频参数,有些在里面板子上,要拆开才能看到,我这是433的 2.到网店…...
两种不同简缩极化的六个方程
方程1 (3*A*(b - a*1i 1) - A*((c d*1i)*(f1 f2*1i)*1i - (c d*1i)^2))*(a - b*1i)*1i 3*A*(b - a*1i 1) 2*(A*(c f2 d*1i - f1*1i) A*(c d*1i - (a b*1i)*(c d*1i)*1i))*(c - d*1i) (A*(c f2 d*1i - f1*1i) A*(c d*1i - (a b*1i)*(c d*1i)*1i))*(f1 - f2…...
环形缓冲区(Ring Buffer):概念、功能、使用场景与实现
一、概念 环形缓冲区(Ring Buffer),又称循环缓冲区,是一种用于数据缓冲的数据结构。其核心思想是将缓冲区视为一个环形结构,当数据写入到缓冲区的末尾时,会自动回绕到缓冲区的开头继续写入,形成…...
大连理工大学数据结构2003年硕士入学试题
大连理工大学2003年硕士入学试题 数据结构部分(共75分) 一、回答下列问题(20分) 1.循环队列用数组A[0..m—1)存放其数据元素。设tail指向其实际的队尾,front指向其实际队首的前一个位置,则当前队列中的数据元素有多少个…...
Master EDI 项目需求分析
Master Electronics 通过其全球分销网络,支持多种采购需求,确保能够为客户提供可靠的元件供应链解决方案,同时为快速高效的与全球伙伴建立合作,Master 选择通过EDI来实现与交易伙伴间的数据传输。 EDI为交易伙伴之间建立了一个安…...
图海寻径——图相关算法的奇幻探索之旅
一、图的表示 1. 邻接矩阵 (Adjacency Matrix) #include <iostream> #include <vector> #include <queue> #include <limits>using namespace std;class GraphMatrix { private:int numVertices;vector<vector<int>> adjMatrix;const st…...
亚马逊云科技re:Invent:生成式AI与全球布局
作为全球云计算和人工智能领域一年一度的顶级盛宴,亚马逊云科技2024 re:Invent全球大会吸引了超过6万名现场观众以及40多万名线上参会者。而大会上生成式AI的相关话题和内容,也成为了所有观众关注的焦点。 大会期间,亚马逊云科技全球服务副总…...
Android 因为混淆文件配置,打release包提示running R8问题处理
一、报错信息 Missing classes detected while running R8. Please add the missing classes or apply additional keep rules that are generated in E:\workplace\xxxxxx\app\build\outputs\mapping\release\missing_rules.txt. Missing class org.mediakit.R$layout (refer…...
20241209给Ubuntu20.04系统的的交换分区增加为20GB的步骤
20241209给Ubuntu20.04系统的的交换分区增加为20GB的步骤 2024/12/9 21:10 缘起,编译中科创达的高通CM6125模块的Android10的时候,老报错。 编译环境可以编译荣品的RK3566的Android13/Buildroot。 以前荣品的RK3566的Android13的编译环境是可以编译通CM6…...
Centos7环境下nifi单机部署
Centos7环境下nifi单机部署 前言一、安装Nifi1.1 下载并解压1.2 修改配置文件 二、启动Nifi程序三、Nifi的简单使用3.1 文件移动3.2 本地文件传到HDFS 参考博客 前言 本以为在服务器上部署nifi很简单,跟着教程走就好,但是并没有成功,可能是因…...
如何通过轻易云实现金蝶云星空与旺店通数据集成
案例分享:柏为金蝶退料申请退料开单08.03 在企业的供应链管理中,数据的准确性和实时性至关重要。本文将重点介绍如何通过轻易云数据集成平台,将金蝶云星空的数据高效集成到旺店通旗舰奇门系统中,以实现柏为金蝶退料申请退料开单0…...
条件运算符
C中的三目运算符(也称条件运算符,英文:ternary operator)是一种简洁的条件选择语句,语法如下: 条件表达式 ? 表达式1 : 表达式2• 如果“条件表达式”为true,则整个表达式的结果为“表达式1”…...
渲染学进阶内容——模型
最近在写模组的时候发现渲染器里面离不开模型的定义,在渲染的第二篇文章中简单的讲解了一下关于模型部分的内容,其实不管是方块还是方块实体,都离不开模型的内容 🧱 一、CubeListBuilder 功能解析 CubeListBuilder 是 Minecraft Java 版模型系统的核心构建器,用于动态创…...
linux arm系统烧录
1、打开瑞芯微程序 2、按住linux arm 的 recover按键 插入电源 3、当瑞芯微检测到有设备 4、松开recover按键 5、选择升级固件 6、点击固件选择本地刷机的linux arm 镜像 7、点击升级 (忘了有没有这步了 估计有) 刷机程序 和 镜像 就不提供了。要刷的时…...
剑指offer20_链表中环的入口节点
链表中环的入口节点 给定一个链表,若其中包含环,则输出环的入口节点。 若其中不包含环,则输出null。 数据范围 节点 val 值取值范围 [ 1 , 1000 ] [1,1000] [1,1000]。 节点 val 值各不相同。 链表长度 [ 0 , 500 ] [0,500] [0,500]。 …...
DIY|Mac 搭建 ESP-IDF 开发环境及编译小智 AI
前一阵子在百度 AI 开发者大会上,看到基于小智 AI DIY 玩具的演示,感觉有点意思,想着自己也来试试。 如果只是想烧录现成的固件,乐鑫官方除了提供了 Windows 版本的 Flash 下载工具 之外,还提供了基于网页版的 ESP LA…...
【android bluetooth 框架分析 04】【bt-framework 层详解 1】【BluetoothProperties介绍】
1. BluetoothProperties介绍 libsysprop/srcs/android/sysprop/BluetoothProperties.sysprop BluetoothProperties.sysprop 是 Android AOSP 中的一种 系统属性定义文件(System Property Definition File),用于声明和管理 Bluetooth 模块相…...
UR 协作机器人「三剑客」:精密轻量担当(UR7e)、全能协作主力(UR12e)、重型任务专家(UR15)
UR协作机器人正以其卓越性能在现代制造业自动化中扮演重要角色。UR7e、UR12e和UR15通过创新技术和精准设计满足了不同行业的多样化需求。其中,UR15以其速度、精度及人工智能准备能力成为自动化领域的重要突破。UR7e和UR12e则在负载规格和市场定位上不断优化…...
uniapp中使用aixos 报错
问题: 在uniapp中使用aixos,运行后报如下错误: AxiosError: There is no suitable adapter to dispatch the request since : - adapter xhr is not supported by the environment - adapter http is not available in the build 解决方案&…...
基于Java Swing的电子通讯录设计与实现:附系统托盘功能代码详解
JAVASQL电子通讯录带系统托盘 一、系统概述 本电子通讯录系统采用Java Swing开发桌面应用,结合SQLite数据库实现联系人管理功能,并集成系统托盘功能提升用户体验。系统支持联系人的增删改查、分组管理、搜索过滤等功能,同时可以最小化到系统…...
AI病理诊断七剑下天山,医疗未来触手可及
一、病理诊断困局:刀尖上的医学艺术 1.1 金标准背后的隐痛 病理诊断被誉为"诊断的诊断",医生需通过显微镜观察组织切片,在细胞迷宫中捕捉癌变信号。某省病理质控报告显示,基层医院误诊率达12%-15%,专家会诊…...
