首页 > 数据库 >Milvus向量数据库06-RAG检索增强

Milvus向量数据库06-RAG检索增强

时间:2024-12-10 16:57:33浏览次数:6  
标签:检索 RAG 06 模型 Elasticsearch Milvus 数据库 向量

Milvus向量数据库06-RAG检索增强

文章目录

网上关于RAG的讲解太多,导致内容不聚焦,大家说的越来越不具象了,在此进行整理,各位按需取用

鸣谢:感谢每一位无私奉献的传道者,在此不一一具名!


1-学习目标

  • 1)到底什么是RAG
  • 2)RAG和Elasticsearch对比
  • 3)RAG和向量数据库之间是什么关系
  • 4)RAG和大模型什么关系
  • 5)如何将输入Embedding向量化
  • 6)RAG的具体实现方案

2-参考网址

  • 个人尝试代码仓库:XXXXXX
  • 彻底搞懂大模型RAG(检索、增强、生成):https://blog.csdn.net/a2875254060/article/details/142468037
  • Milvus向量数据库03-搜索理论:https://blog.csdn.net/2301_77717148/article/details/144314159

3-执行过程记录

1-到底什么是RAG

检索增强生成(Retrieval-augmented Generation),简称RAG

查询向量数据库(Vector Database)是 Retrieval-Augmented Generation (RAG) 流程中的一部分,但并不等同于整个 RAG 流程。RAG
是一种结合了检索和生成的技术,旨在提高语言模型的性能,特别是在需要处理大量上下文或实时数据更新的场景中。

RAG 的基本流程:
  1. 检索(Retrieval):

    • 使用向量数据库或其他检索机制,根据输入查询检索相关文档或信息片段。
    • 向量数据库通常用于存储和检索高维向量,如文本的嵌入表示,以便快速找到最相关的文档。
  2. 生成(Generation):

    • 将检索到的相关文档与原始查询一起输入到语言模型中。
    • 语言模型根据这些信息生成回复或答案。
为什么 RAG 优于传统的基于检索的方法:
  • 上下文理解:

    • 传统的检索方法可能只能提供相关文档的列表,而 RAG 能够结合这些文档的内容生成更连贯和准确的回答。
  • 减少幻觉:

    • 语言模型有时会产生不准确或不存在的信息(称为“幻觉”),而 RAG 通过引入外部知识来减少这种现象。
  • 实时更新:

    • 向量数据库可以定期更新,确保检索到的信息是最新和最准确的。
示例流程:
  1. 用户查询:

    • 用户向系统提出一个查询,例如:“Zilliz Cloud 的主要功能是什么?”
  2. 检索阶段:

    • 系统将查询转换为向量,并在向量数据库中查找最相关的文档。
    • 假设检索到两个文档:
      • 文档1:描述 Zilliz Cloud 是一个全面管理的向量数据库和服务,帮助用户释放非结构化数据的潜力,用于 AI 应用。
      • 文档2:描述它能够存储、索引和管理由深度神经网络和其他机器学习模型生成的大量嵌入向量。
  3. 生成阶段:

    • 将检索到的文档与原始查询一起输入到语言模型中。
    • 语言模型生成回复,整合从多个文档中获取的信息,提供一个全面的答案。

通过这种方式,RAG 充分利用了向量数据库的强大检索能力以及语言模型的生成能力,为用户提供更准确和有用的信息。


2-RAG和Elasticsearch对比

  • Milvus向量数据库03-搜索理论:https://blog.csdn.net/2301_77717148/article/details/144314159

RAG相对于elasticsearch,理念上更先进,替换【传递的倒排索引的查找方式】为【向量距离关系查找方式】,而【向量】天生就和【LLM大模型】就耦合在一起,所以【RAG】在【大模型】场景中更适用

RAG(Retrieval-Augmented Generation,检索增强生成)和Elasticsearch是两种不同的技术,它们在某些应用场景中可以相互配合,但各自有不同的特点和用途。以下是它们之间的一些对比:

  1. 技术类型和用途

    • RAG:RAG是一种结合了检索(Retrieval)和生成(Generation)能力的自然语言处理技术。它通过从外部知识库中检索相关信息片段,然后将这些片段与用户输入一起送入生成模型,以生成更加准确和上下文相关的回答。
    • Elasticsearch:Elasticsearch是一个分布式、RESTful风格的搜索和数据分析引擎,主要用于存储、搜索和分析大量数据。
  2. 数据处理和检索

    • RAG:RAG模型可以有效地利用外部知识库,提供更深入、准确且有价值的答案,提高了生成文本的可靠性。
    • Elasticsearch:Elasticsearch以其快速的搜索能力著称,能够处理PB级数据,服务大公司;也可以运行在单机上,服务小公司。
  3. 可扩展性和性能

    • RAG:RAG模型具有高扩展性,检索和生成模块可以独立扩展,适应不同规模数据。
    • Elasticsearch:Elasticsearch可以在笔记本电脑上运行,也可以在承载了PB级数据的成百上千台服务器上运行,具有很好的水平扩展性。
  4. 实时性和动态性

    • RAG:RAG能通过外部知识库实时更新内容,避免依赖模型静态知识。
    • Elasticsearch:Elasticsearch提供近实时的搜索和分析能力,能够在海量数据下实现秒级响应。
  5. 成本效益

    • RAG:RAG是一个成本效益较高的选项,因为它需要的计算和存储资源较少,无需拥有自己的大型语言模型(LLM),也无需花费时间和资金对模型进行微调。
    • Elasticsearch:Elasticsearch作为一个成熟的搜索引擎,其成本效益取决于部署规模和使用情况,但通常需要一定的硬件和维护成本。
  6. 安全性和隐私管理

    • RAG:RAG可以通过限制知识库的权限来实现安全控制,确保敏感信息不被泄露。
    • Elasticsearch:Elasticsearch提供了跨集群复制功能,可以作为热备份随时投入使用,确保数据的安全性和可用性。
  7. 应用场景

    • RAG:RAG适用于需要结合检索和生成的场景,如问答系统、内容推荐等。
    • Elasticsearch:Elasticsearch适用于需要全文搜索、数据分析和日志分析的场景,如站内搜索、BI系统、商品价格监控等。

总的来说,RAG和Elasticsearch在技术特点和应用场景上有所不同,它们可以单独使用,也可以结合使用以发挥各自的优势。例如,在构建基于RAG的搜索功能时,可以利用Elasticsearch来存储和搜索专有数据,以及搜索可从中提取背景信息的其他外部知识库。


3-RAG和向量数据库之间是什么关系

RAG底层核心就是使用Vector向量的距离计算,所以RAG底层的存储系统不是【传统的数据库】而是【向量数据库】

RAG(Retrieval-Augmented Generation,检索增强生成)与向量数据库之间的关系主要体现在以下几个方面:

  1. 数据检索与增强:RAG技术通过从外部数据源检索相关信息,并将其作为输入提供给大型语言模型(LLMs),以增强模型在特定任务中的表现。向量数据库因其高效的数据存储和检索能力,成为RAG技术实施的重要支持。

  2. 语义相似性搜索:向量数据库的核心优势在于能够通过语义相似性算法实现海量非结构化数据的快速检索,这使得它在复杂的知识库构建、客户服务高效搜索等方面展现出显著优势。

  3. 技术互补性:RAG技术与向量数据库的结合,可以看作是一种技术互补。RAG通过检索系统提供具体、相关的事实和数据,而生成模型则能够灵活地构建回答,并融入更广泛的语境和信息。

  4. 解决大模型限制:RAG通过检索外部信息作为输入,辅助大型模型回答问题,这种方法能显著减少生成信息不准确的问题,增加回答的可追溯性。

  5. 私有数据管理:RAG提供了一个安全可落地的实践基础,同时也能更好地管理企业现有和新增的知识,解决知识依赖问题。向量数据库在这方面提供了访问权限控制和数据管理的支持。

  6. 技术实现:在业界实践中,RAG检索通常与向量数据库密切结合,催生了基于ChatGPT + Vector Database +
    Prompt的RAG解决方案,简称为CVP技术栈。这一解决方案依赖于向量数据库高效检索相关信息以增强大型语言模型(LLMs)。

  7. 信息载体:向量数据库作为存储向量化数据的载体,与RAG技术没有直接关系,但可以作为RAG技术的一种具体实现方式。

综上所述,RAG与向量数据库之间的关系是相互依存和互补的。RAG利用向量数据库的高效检索能力来增强大型语言模型的性能,而向量数据库则提供了存储和检索向量化数据的能力,两者共同作用于提升知识管理和内容生成的效率和准确性。


4-RAG和大模型什么关系

RAG(Retrieval-Augmented
Generation,检索增强生成)是一种结合了信息检索技术与语言生成模型的人工智能技术。它通过从外部知识库中检索相关信息,并将其作为提示(Prompt)输入给大型语言模型(LLMs),以增强模型处理知识密集型任务的能力,如问答、文本摘要、内容生成等。RAG模型由Facebook
AI Research(FAIR)团队于2020年首次提出,并迅速成为大模型应用中的热门方案。

RAG与大模型的关系主要体现在以下几个方面:

  1. 互补性:RAG作为大语言模型(LLM)的应用开发架构,通过拓展访问特定领域数据库或内部知识库,补足通用模型在垂直领域的知识短板。

  2. 性能提升:RAG通过整合外部数据库的知识,提高了生成内容的准确性和可信度,减少了大模型的幻觉问题和过时知识的问题。

  3. 数据安全性:RAG对接的私有数据库不参与大模型数据集训练,能在改善模型性能的同时,更好地保证数据隐私和安全。

  4. 减少模型幻觉:RAG能有效减少模型幻觉的发生,进一步提升大模型检索和生成性能。

  5. 无需重新训练:RAG使得开发人员无需为每一个特定任务重新训练整个庞大的模型,他们可以简单地给模型加上一个知识库,通过这种方式增加模型的信息输入,从而提高回答的精确性。

  6. 应用拓展:RAG作为大模型在垂直领域的应用拓展,允许持续知识更新和集成领域特定信息,推动其成为各类大模型落地项目不可缺少的技术组件。

综上所述,RAG通过检索外部信息来增强大模型的能力,解决大模型在知识更新、准确性和数据安全性方面的挑战,是大模型应用中的一个重要方向。


5-如何将输入Embedding向量化

Embedding示例如下,输出embedding维度就是embedding列表的个数;如果是768位,列表就是768个向量

  • Embedding后的数据示例如下:
{
    "data": [
        {
            "embedding": [
                -0.013840336352586746,
                0.050973281264305115
            ],
            "index": 0,
            "object": "embedding"
        }
    ],
    "model": "embedding-2",
    "object": "list",
    "usage": {
        "completion_tokens": 0,
        "prompt_tokens": 9,
        "total_tokens": 9
    }
}

6-RAG的具体实现方案

当前使用【Milvus向量数据库】进行实现,在下一篇文档中进行详细补充

标签:检索,RAG,06,模型,Elasticsearch,Milvus,数据库,向量
From: https://blog.csdn.net/2301_77717148/article/details/144376007

相关文章

  • 手把手教你用python一键抢12306火车票(附代码)
    源码直接在pycharm里面打开即可用github链接:w1a2b3c/123061:12306抢票脚本,学生票,为了买票纯手写gitee链接:eric/12306抢票脚本,学生票,为了买票纯手写哈喽,哈喽~,一年一度的抢火车票大战正式拉开序幕…然饿大多数人碰到的是这种情况:当你满心期待摩拳擦掌准备抢票的时候,你会发现......
  • 牛客小白月赛106
    牛客小白月赛106比赛链接:牛客小白月赛106//也就写写水题骗自己了A.最后DISCO直接秒,注意一下c可以等于0#include<bits/stdc++.h>usingnamespacestd;#defineintlonglong#defineinfINT32_MAX#definePIIpair<int,int>#defineendl'\n'inlinevoidsolve(){......
  • 【开源】A067—基于JavaWeb的大学生科创项目在线管理系统的设计与实现
    ......
  • Adaptive-RAG:让查询处理更智能,检索更精准!
    今天分享的是韩国科学技术院发布的一篇工作。论文题目:Adaptive-RAG:LearningtoAdaptRetrieval-AugmentedLargeLanguageModelsthroughQuestionComplexityAdaptive-RAG:智能检索策略,提升问答模型效率论文链接:https://arxiv.org/pdf/2403.14403论文概述RAG(Retri......
  • springboot湿地公园旅游信息管理系统-计算机毕业设计源码00658
     目录摘要1绪论1.1选题背景与意义1.2国内外研究现状1.3论文结构与章节安排2系统分析2.1可行性分析2.2系统流程分析2.2.1 数据流程3.3.2 业务流程2.3 系统功能分析2.3.1功能性分析2.3.2非功能性分析2.4 系统用例分析2.5本章小结3 系......
  • springboot育婴经验分享平台-计算机毕业设计源码06078
     摘要随着现代社会对育儿知识的需求不断增长,家长们渴望找到一个可靠、便捷的平台来分享和获取育婴经验。为此,我们设计并实现了一个基于SpringBoot的育婴经验分享平台。该平台旨在为家长们提供一个互动交流的空间,让他们能够分享自己的育婴心得、求助育儿问题,并从中获得有价值......
  • 『玩转Streamlit』--片段Fragments
    在Streamlit应用开发中,Fragments组件是一种用于更精细地控制页面元素更新和显示顺序的工具。它允许开发者将内容分解成多个小的片段,这些片段可以按照特定的顺序或者逻辑进行更新,而不是一次性地更新整个页面或容器中的所有内容。这为创建动态且交互性强的用户界面提供了更多的......
  • 063Java基于SpringBoot的复兴村医疗管理系统-java vue.js idea
    所需该项目可以在最下面查看联系方式,为防止迷路可以收藏文章,以防后期找不到项目介绍063Java基于SpringBoot的复兴村医疗管理系统-javavue.jsidea系统实现截图技术栈介绍JDK版本:jdk1.8+编程语言:java框架支持:springboot数据库:mysql版本不限数......
  • 「Java EE开发指南」如何在Web项目中使用Web Fragments?
    本教程将向您展示如何在MyEclipse中使用关联的Web项目创建WebFragments项目的机制,还提供了示例项目供您检查。在本教程中,您将学习如何:创建一个webfragment和相关的web项目部署并测试一个包含webfragment的示例web项目MyEclipsev2024.1离线版下载MyEclipse技术交流群:742......
  • (全新整理)2006-2022年农民专业合作社数量 30个省面板数据
    文章目录数据下载地址数据指标说明项目备注数据下载地址数据下载地址点击这里下载数据数据指标说明2006-2022年农民专业合作社数量30个省面板数据无缺失值,真实可靠各省农民专业合作社数量:指按照《中华人民共和国农民专业合作社法》《农民专业合作社登记管理......