快速上手LangChain(三)构建检索增强生成(RAG)应用

news/2025/1/8 12:30:19/

文章目录

  • 快速上手LangChain(三)构建检索增强生成(RAG)应用
    • 概述
    • 索引
      • 阿里嵌入模型 Embedding
    • 检索和生成
    • RAG应用(demo:根据我的博客主页,分析一下我的技术栈)

快速上手LangChain(三)构建检索增强生成(RAG)应用

langchain官方文档:https://python.langchain.ac.cn/docs/tutorials/rag/

概述

典型的 RAG 应用程序有两个主要组件

  • 索引:一个从源头摄取数据并对其进行索引的管道。这通常离线进行

  • 检索和生成:实际的 RAG 链,它在运行时获取用户查询,从索引中检索相关数据,然后将其传递给模型。

索引

在这里插入图片描述

  • 加载:首先我们需要加载数据。这可以使用文档加载器完成。
  • 拆分:文本拆分器将大型 Documents 分成更小的块。这对于索引数据和将其传递到模型中都很有用,因为大的块更难搜索,并且无法容纳在模型的有限上下文窗口中。
  • 存储:我们需要一个地方来存储和索引我们的拆分,以便稍后可以搜索它们。这通常使用向量存储和嵌入模型完成。

由于原始文档过大,超出了LLM的上下文窗口,需要将其分块才能让LLM识别。LangChain 提供了许多内置的文本分块工具,例如 CharacterTextSplitter

总结:RAG需要从向量数据库检索上下文然后输入LLM进行生成,因此需要提前将文本数据向量化并存储到向量数据库

阿里嵌入模型 Embedding

Embedding(也称为嵌入)是将文本、图片或音视频等数据转化为向量(数字序列)的一种方法。向量的特点在于可以用数学方式表示数据间的关系,向量之间的距离代表数据的相关性。距离越小,相关性越高;距离越大,相关性越低。

通用文本向量,是通义实验室基于LLM底座的多语言文本统一向量模型,面向全球多个主流语种,提供高水准的向量服务,帮助开发者将文本数据快速转换为高质量的向量数据。

通义官方文档:https://help.aliyun.com/zh/model-studio/user-guide/embedding
langchain相关代码:libs/community/langchain_community/embeddings/dashscope.py

检索和生成

  • 检索:给定用户输入,使用检索器从存储中检索相关拆分。
  • 生成:聊天模型 / LLM 使用包含问题和检索数据的提示来生成答案

在这里插入图片描述

一旦我们索引了数据,我们将使用LangGraph作为我们的编排框架来实现检索和生成步骤。

RAG应用(demo:根据我的博客主页,分析一下我的技术栈)

langchain官方文档:https://python.langchain.ac.cn/docs/tutorials/rag/

我们将构建一个应用程序,该应用程序可以回答有关网站内容的问题。我们将使用的特定网站是 Lilian Weng 的LLM Powered Autonomous Agents博客文章,这使我们可以询问有关该文章内容的问题。

这里我们把官方demo改造一下,指定我们自己的一篇博客文章,使用阿里的嵌入模型进行向量化,细节上做了一点优化。

  1. 安装依赖
pip install --upgrade langchain-text-splitters langchain-community
  1. 下载&加载语料
loader = WebBaseLoader(web_paths=(

http://www.ppmy.cn/news/1560568.html

相关文章

WordPress Crypto 插件 身份认证绕过漏洞复现(CVE-2024-9989)

0x01 产品简介 WordPress Crypto插件是指那些能够为WordPress网站提供加密货币支付、信息显示或交易功能的插件。这些插件通常与WordPress电子商务插件(如WooCommerce)集成,使网站能够接受多种加密货币支付,或展示加密货币实时信息。支持多种加密货币支付,付款直接进入钱…

性能测试中如何设计真实的负载呢?

引言: 性能测试是一项关键的软件开发活动,它可以帮助我们评估系统在不同负载下的响应能力,并找出系统的瓶颈。然而,要确保我们的性能测试结果真实可靠,我们需要设计一个真实的负载。本文将从零开始,详细介…

使用npm 插件[mmdc]将.mmd时序图转换为图片

使用npm 插件[mmdc]将.mmd时序图转换为图片 1. 安装 mmdc2. 转换为图片 可以使用 mmdc (Mermaid CLI)这个工具来将 .mmd 时序图(Mermaid语法描述的时序图)转换为图片,以下是使用步骤: 1. 安装 mmdc 确保…

组合模式——C++实现

1. 模式简介 组合模式是一种结构型模式。 组合模式又叫做部分整体模式,组合模式用于把一组相似的对象当做一个单一的对象。特别擅长处理树形的数据,对于非树形的数据不好用它。 对于树形的数据,一个典型的例子就是文件系统。在文件系统里大致…

Android多渠道打包【友盟方式详细讲解版】

开发环境: Mac OS 15.0.1 Android Studio Jellyfish | 2023.3.1 Patch 2 废话不讲,不浪费大家时间,每步骤后面有解释,直接开始上手干 第一步: 在程序的清单文件【app/src/main/AndroidManifest.xml】配置如下节点内容…

SCAU软件体系结构期末复习-名词解释题

名词解释 软件设计模式: 是对软件设计经验的总结,是对软件设计中反复出现的设计问题的成功解决方案的描述。为了记录这些成功的设计经验并方便以后使用,软件设计模式通常包含4个基本要素:模式名称、问题、解决方案以及效果。它最…

【GeekBand】C++设计模式笔记20_Composite_组合模式

1. “数据结构” 模式 常常有一些组件在内部具有特定的数据结构,如果让客户程序依赖这些特定的数据结构,将极大地破坏组件的复用。这时候,将这些特定数据结构封装在内部,在外部提供统一的接口,来实现与特定数据结构无…

Segment Anything论文详细翻译【Part1:作者+Figure1+摘要】

目录 写在前面 标题 作者 Alexander Kirillov Eric Mintun Nikhila Ravi Hanzi Mao 其他作者 发表机构 Figure 1 任务 模型 数据 摘要 翻译 写在前面 为啥要写这篇文章?因为找不到一篇写的特别好的【翻译并仔细解释】文章。网上大多千篇一律&#x…