当前位置: 首页 > news >正文

LangChain+LLM实战---向量数据库介绍

原文:Vector Databases

Embeddings是由人工智能模型(如大型语言模型)生成的,具有大量的属性或特征,使其表示难以管理。在人工智能和机器学习的背景下,这些特征代表了数据的不同维度,这些维度对于理解模式、关系和底层结构至关重要。

这就是为什么我们需要一个专门为处理这类数据而设计的专门数据库。向量数据库通过为Embeddings提供优化的存储和查询功能来满足这一要求。向量数据库具有传统数据库独立向量索引所不具备的能力,并且具有传统基于标量的数据库所缺乏的处理向量Embeddings的专门化能力。

使用向量Embeddings的挑战在于,传统的基于标量的数据库无法跟上此类数据的复杂性和规模,从而难以提取见解并执行实时分析。这就是向量数据库发挥作用的地方——它们被有意设计为处理这类数据,并提供充分利用数据所需的性能、可伸缩性和灵活性。

向量数据库是如何工作的?

我们都知道传统数据库是如何工作的(或多或少)——它们将字符串、数字和其他类型的标量数据存储在行和列中。另一方面,向量数据库对向量进行操作,因此它的优化和查询方式是完全不同的。

在传统数据库中,我们通常查询数据库中值通常与查询完全匹配的行。在向量数据库中,我们应用相似度度量来找到与我们的查询最相似的向量。

向量数据库使用不同算法的组合,这些算法都参与了近似最近邻(ANN)搜索。这些算法通过散列、量化或基于图的搜索来优化搜索。

这些算法组合成一个管道,提供查询向量的邻居的快速和准确的检索。由于向量数据库提供了近似的结果,我们主要考虑的是准确性和速度之间的权衡。结果越准确,查询速度就越慢。然而,一个好的系统可以提供近乎完美的超快速搜索。

下面是向量数据库的常见管道::

img

  1. 索引:向量数据库使用PQ、LSH或HNSW等算法对向量进行索引。这一步将向量映射到一个数据结构,以实现更快的搜索;
  2. 查询:向量数据库将索引的查询向量与数据集中的索引向量进行比较,以找到最近的邻居(应用该索引使用的相似性度量);
  3. 后处理:在某些情况下,向量数据库从数据集中检索最后最近的邻居,并对它们进行后处理以返回最终结果。这一步可以包括使用不同的相似度度量对最近的邻居重新排序。

有了向量数据库,我们可以为我们的人工智能添加高级功能,比如语义信息检索、长期记忆等等。上图让我们更好地理解了向量数据库在这类应用中的作用。

为什么使用向量数据库?

在生产中,向量搜索是使用向量数据库的最常见原因。向量搜索将多个对象与搜索查询或主题项的相似性进行比较。为了找到相似的匹配项,您可以使用用于创建向量Embeddings的相同ML embedding模型将主题项或查询转换为向量。向量数据库比较这些对象的相似性以找到最接近的匹配,提供准确的结果,同时消除传统搜索技术可能返回的不相关结果。

让我们看看向量搜索的一些常见用例:

1. 语义搜索

搜索文本和文档通常可以通过两种方式完成。词汇搜索查找模式和精确的单词或字符串匹配,而语义搜索使用搜索查询或问题的含义并将其置于上下文中。向量数据库存储和索引来自自然语言处理模型的向量Embeddings,以理解文本字符串、句子和整个文档的含义和上下文,从而获得更准确和相关的搜索结果。

使用自然语言查询来查找相关结果是一种更好的体验,并允许用户更快地找到他们需要的内容,而无需了解数据分类的具体方式。

2. 对图像、音频、视频、JSON和其他形式的非结构化数据进行相似性搜索

图像、音频、视频和其他非结构化数据集在传统数据库中分类和存储非常具有挑战性。这通常需要手动将关键字、描述和元数据应用于每个对象。一个人对一个复杂数据对象进行分类的方式对另一个人来说可能并不明显。因此,搜索复杂的数据可能非常容易出错。这种方法要求搜索者了解数据的结构,并构建与原始数据模型匹配的查询。

3. 排名和推荐引擎

向量数据库是为排名和推荐引擎提供动力的一个很好的解决方案。对于在线零售商来说,它们可以用来推荐与过去购买的商品相似的商品,或者客户正在研究的当前商品。流媒体服务可以应用用户的歌曲评级,为个人量身定制完美匹配的推荐,而不是依赖于协同过滤或流行列表。

基于最接近匹配找到相似项目的能力使向量数据库成为提供相关建议的理想选择,并且可以很容易地根据相似性分数对项目进行排名。

4. 重复数据删除和记录匹配

向量相似性搜索的另一个用例是记录匹配和重复数据删除。使用相似性服务查找几乎重复的记录可以在各种应用程序中使用。考虑一个应用程序,它从目录中删除重复项,以使其更可用和更相关。

5. 数据质检

向量数据库在查找相似对象方面做得很好,但它们也可以查找与预期结果相距甚远或不同的对象。这些异常在用于威胁评估、欺诈检测和IT操作的应用程序中是有价值的。可以识别出最相关的异常以进行进一步分析,而不会因高假警报率而占用大量资源。

最受欢迎的向量数据库:

Pinecone

Pinecone就是这样一个向量数据库,它在整个行业中被广泛接受,用于解决复杂性和维度等挑战。Pinecone是一个云原生向量数据库,用于处理高维向量数据。Pinecone的核心基础方法是基于近似最近邻(ANN)搜索,它可以有效地定位更快的匹配并在大型数据集中对它们进行排序。

Pinecone的一些主要特征包括:

  1. 高度可扩展:Pinecone可以处理数十亿个高维向量和水平缩放,使其适用于最苛刻的机器学习工作负载。

  2. 实时数据摄取:松果支持实时数据摄取,允许您存储和索引新数据,因为它变得可用而没有任何停机时间

  3. 低延迟搜索:Pinecone的高级索引算法确保最近邻查询和相似性搜索操作以低延迟执行,提供快速准确的结果。

  4. 易于集成:Pinecone的API设计简单直观,使其易于与现有的机器学习工作流程和数据管道集成。

  5. 完全管理的服务:Pinecone是一个完全管理的平台,这意味着您不必担心基础设施管理或维护,让您专注于开发和部署机器学习应用程序。

Weaviate

Weaviate是一个向量数据库和搜索引擎。它是一个低延迟的向量搜索引擎,支持各种媒体类型(文本、图像等)。Weaviate使用机器学习对数据进行向量化和存储,并找到对自然语言问题的回答。它包括语义搜索、问答提取、分类和可定制模型(PyTorch/TensorFlow/Keras)。您还可以使用Weaviate在生产中扩展自定义机器学习模型。

Weaviate存储媒体(文本,图像。等)对象及其相应的向量,允许将向量搜索与结构化过滤与云原生数据库的容错相结合。编织搜索可以通过不同的方法执行,例如GraphQL、REST和各种语言客户机。Python、Javascript、Go和Go是支持Weaviate客户端的流行编程语言。

如今,Weaviate被软件工程师用作其应用程序的ml优先数据库,数据工程师使用以人工神经网络为核心的向量数据库,数据科学家使用MLOps部署他们的搜索应用程序。

Weaviate特性:

快速查询 -在不到100毫秒的时间内,Weaviate在数百万个项目上运行10个最近邻(NN)搜索。

不同的媒体支持 -使用最先进的AI模型推理(例如变形金刚)图像,文本等。

结合标量和向量搜索 - Weaviate保存您的对象和向量,确保检索始终快速。不需要第三方对象存储系统。

水平可扩展性 - Weaviate可以根据用例在生产中水平扩展。

类图连接 -在数据项之间建立类图连接,以模拟数据点之间的实际连接。GraphQL用于遍历这些连接。

Milvus

Milvus是一个开源向量数据库,为用户提供高效、可扩展的解决方案,用于存储、管理和搜索大规模、高维数据。它的设计目标是满足对高级数据分析和机器学习应用快速增长的需求,这些应用需要快速准确地计算大量复杂数据。Milvus可用于各种行业,包括金融、电子商务、医疗保健等。在本文中,我们将深入了解Milvus及其关键特性、用例和优点。

Milvus的主要功能:

Milvus是一个高度可扩展和灵活的数据库,支持广泛的向量数据类型,包括图像,音频和文本数据。它的主要特点包括:

快速高效: Milvus可以处理大量的向量数据,低延迟和高吞吐量。它使用最先进的算法和技术来优化存储和检索速度,使其成为需要快速响应时间的实时应用的理想选择。

可扩展: Milvus设计为水平扩展,允许用户随着数据增长向集群添加新节点。这使得用户即使使用大量数据集也能获得高性能和可伸缩性。

搜索和相似度: Milvus提供了一个强大的搜索和相似度查询引擎,允许用户在他们的数据集中搜索相似的向量。这对于图像和面部识别、自然语言处理和推荐系统等应用程序尤其有用。

多接口: Milvus支持多种编程接口,包括Python, Java和Go,使其易于与现有的数据分析和机器学习工具集成。

FAISS

Faiss背后的科学原理有详细的描述在这里。Faiss的想法是,向量可以被转换成更像我们习惯搜索的文本的东西——一种码字。一旦有了这个码字,就可以使用标准的颠倒索引技术来检索类似的结果。使用精确的向量比较,结果可以基于这个近似结果集重新排序。

相关文章:

  • Langchain-Chatchat-win10本地安装部署成功笔记(CPU)
  • 基于.NET、Uni-App开发支持多平台的小程序商城系统 - CoreShop
  • Mybatis-Plus自动填充功能配置和使用 [MyBatis-Plus系列] - 第494篇
  • 设计模式之策略模式(Strategy)
  • hdlbits系列verilog解答(always块case语句2)-34
  • Kotlin 进阶函数式编程技巧
  • Node.js、Chrome V8 引擎、非阻塞式I/O介绍
  • 面试问题?
  • Mac苹果电脑分辨率修改管理 安装SwitchResX 完美解决
  • RISC-V处理器设计(四)—— Verilog 代码设计
  • leetcode做题笔记215. 数组中的第K个最大元素
  • 软件开发必备神器!一文读懂10款热门看板工具推荐!
  • [尚硅谷React笔记]——第9章 ReactRouter6
  • 轻量封装WebGPU渲染系统示例<18>- 材质多pass实现GPU Compute计算(源码)
  • 【二进制转换和与其有关的操作符详解】
  • JavaScript 如何正确处理 Unicode 编码问题!
  • Apache的80端口被占用以及访问时报错403
  • CSS3 聊天气泡框以及 inherit、currentColor 关键字
  • docker python 配置
  • iOS动画编程-View动画[ 1 ] 基础View动画
  • js
  • Terraform入门 - 1. 安装Terraform
  • Vue UI框架库开发介绍
  • 分布式任务队列Celery
  • 关键词挖掘技术哪家强(一)基于node.js技术开发一个关键字查询工具
  • 蓝海存储开关机注意事项总结
  • 如何使用Mybatis第三方插件--PageHelper实现分页操作
  • 在GitHub多个账号上使用不同的SSH的配置方法
  • 阿里云服务器如何修改远程端口?
  • #、%和$符号在OGNL表达式中经常出现
  • #define 用法
  • (C语言)字符分类函数
  • (javascript)再说document.body.scrollTop的使用问题
  • (笔记)Kotlin——Android封装ViewBinding之二 优化
  • (附源码)spring boot校园拼车微信小程序 毕业设计 091617
  • (规划)24届春招和25届暑假实习路线准备规划
  • (机器学习的矩阵)(向量、矩阵与多元线性回归)
  • (三)uboot源码分析
  • (十五)Flask覆写wsgi_app函数实现自定义中间件
  • (原創) 如何安裝Linux版本的Quartus II? (SOC) (Quartus II) (Linux) (RedHat) (VirtualBox)
  • (原創) 物件導向與老子思想 (OO)
  • (转)IOS中获取各种文件的目录路径的方法
  • (转)Mysql的优化设置
  • (转)setTimeout 和 setInterval 的区别
  • (转载)微软数据挖掘算法:Microsoft 时序算法(5)
  • .equal()和==的区别 怎样判断字符串为空问题: Illegal invoke-super to void nio.file.AccessDeniedException
  • .NET NPOI导出Excel详解
  • .net redis定时_一场由fork引发的超时,让我们重新探讨了Redis的抖动问题
  • .NET(C#) Internals: as a developer, .net framework in my eyes
  • .Net环境下的缓存技术介绍
  • .net开发时的诡异问题,button的onclick事件无效
  • .net中的Queue和Stack
  • .vue文件怎么使用_我在项目中是这样配置Vue的
  • @cacheable 是否缓存成功_让我们来学习学习SpringCache分布式缓存,为什么用?
  • @WebServiceClient注解,wsdlLocation 可配置