比较LlamaIndex和LangChain,选择适合的大模型RAG框架

news2024/9/20 15:03:15

大家好,大型语言模型(LLMs)正引领人工智能技术的创新浪潮。自从OpenAI推出ChatGPT,企业、开发者纷纷寻求定制化的AI解决方案,从而催生了对开发和管理这些模型的工具和框架的巨大需求。

LlamaIndex和LangChain作为两大领先框架,二者各自的特点和优势,将决定它们在不同场景下的应用。本文介绍这两个框架的主要差异,帮助大家做出明智的选择。

1 LlamaIndex

图片

LlamaIndex 流程

LlamaIndex框架简化了对大型语言模型的个性化数据索引和查询,支持多种数据类型,包括结构化、非结构化及半结构化数据。

LlamaIndex通过将专有数据转化为嵌入向量,使数据能够被最新型的LLMs广泛理解,从而省去了重新训练模型的步骤,提高数据处理的效率和智能化水平。

1.1 工作原理

图片

LlamaIndex 架构

LlamaIndex框架推动了大型语言模型(LLMs)的定制化发展。通过将专属数据嵌入内存,使模型在提供上下文相关回答时表现更佳,将LLMs塑造成领域知识专家。无论是作为AI助手还是对话机器人,LlamaIndex都能根据权威资料(如仅限高层访问的业务信息PDF)准确回应查询。

LlamaIndex采用检索增强生成(RAG)技术,定制化LLMs,包括两个核心步骤:

  • 索引阶段:将专有数据转化为富含语义信息的向量索引。

  • 查询阶段:系统接收到查询后,迅速匹配并返回最相关的信息块,结合原始问题,由LLM生成精准答案。

1.2 LlamaIndex快速入门

安装llama-index:

pip install llama-index

使用 OpenAI 的 LLM 需要 OpenAI API 密钥。获得秘钥后,在 .env 文件中这样设置:

import os
os.environ["OPENAI_API_KEY"] = "your_api_key_here"

1.3 构建问答应用:LlamaIndex实践

为了展示LlamaIndex的能力,下面进行代码演示,开发一个基于自定义文档回答问题的问答应用程序。

安装依赖项:

pip install llama-index openai nltk

使用LlamaIndex的SimpleDirectoryReader函数加载文档,开始构建索引:

from llama_index.core import (
    VectorStoreIndex,
    SimpleDirectoryReader
)

# 定义SDR函数内的路径,然后构建索引
documents = SimpleDirectoryReader("docs").load_data()
index = VectorStoreIndex.from_documents(documents, show_progress=True)

查询索引并检查响应:

# 查询引擎
query_engine = index.as_query_engine()

response = query_engine.query("If i miss my assignments and projects, 
what grade and percentage will i end up with?")
print(response)

图片

使用 LlamaIndex 建立的 LLM 响应

查询引擎将搜索数据索引,并以相关片段的形式返回响应。还可以通过修改函数将此查询引擎转换为具有记忆的聊天引擎:

chat_engine = index.as_chat_engine()
response = chat_engine.chat("If i miss my assignments and projects, 
what grade and percentage will i end up with?")
print(response)
follow_up = chat_engine.chat("And if i only miss my projects, 
then what grade would i get?")
print(follow_up)

为了避免每次重建索引,可以将其持久化到磁盘:

index.storage_context.persist()

稍后加载回来:

from llama_index.core import (
    StorageContext,
    load_index_from_storage,
)

storage_context = StorageContext.from_defaults(persist_dir="./storage")
index = load_index_from_storage(storage_context)

2 LangChain

图片

Langchain流程

LangChain是一个框架,专门用于基于自定义数据构建个性化的大型语言模型(LLMs)。它能够整合多种数据源,包括关系型数据库、非关系型数据库、APIs,以及自定义知识库。

LangChain通过链式机制运作,将一系列请求和集成工具的输出依次传递,形成连续的处理流程。利用这一机制,LangChain不仅能够确保从您的专有数据中提取相关上下文,还能生成恰当的响应,无论是用于公司的定制问答机器人、内部分析还是与数据源协同工作的AI助手。其内置的链式结构,便于开发者将多样的工具整合进LLM应用,构建出功能全面的系统。

2.1 工作原理

图片

Langchain架构

LangChain框架由以下核心组件构成:

  • 提示(Prompts):这是向模型发出的指令,用以引导模型产生预期的输出或响应。

  • 模型接口:LangChain提供了一个用户界面,允许用户快速更换并测试不同的语言模型,包括最新的GPT-4、Gemini 1.5 pro、Hugging Face LLM、Claude 3等。

  • 索引技术:框架采用嵌入和内存向量存储等技术,以优化数据的索引和检索。

  • 组件链式连接:LangChain简化了不同组件之间的连接流程,使得构建复杂的处理链变得轻而易举。

  • AI智能体:提供一系列智能体,协助用户管理和分配任务,以及工具的使用。

2.2 LangChain快速入门

安装LangChain:

pip install langchain

这里使用cohere API密钥。在.env文件中使用 API 密钥设置 cohere 环境变量:

import os
os.environ["cohere_apikey"] = "your_api_key_here"

2.3 构建问答应用:LangChain实践

下面进行代码演示,开发一个基于自定义文档回答问题的问答应用程序。

第一步是安装依赖项:

pip install langchain cohere chromadb ## 我们使用cohere而不是OpenAI的LLM

接着,加载文档数据并创建索引。还将使用 cohere 嵌入生成嵌入:

from langchain.document_loaders import OnlinePDFLoader
from langchain.vectorstores import Chroma
from langchain.embeddings import CohereEmbeddings
from langchain.text_splitter import RecursiveCharacterTextSplitter

loader = OnlinePDFLoader(document)
documents = loader.load()

# 初始化文本分割器
text_splitter = RecursiveCharacterTextSplitter(chunk_size=chunksize,chunk_overlap=10,
   separators=[" ", ",", "\n"])

# 初始化Cohere嵌入
embeddings = CohereEmbeddings(model="large", cohere_api_key=st.secrets["cohere_apikey"])

    
texts = text_splitter.split_documents(documents)
global db
db = Chroma.from_documents(texts, embeddings)
retriever = db.as_retriever()
global qa

查询索引并检查响应:

query = "Compare indian constitution's approach to secularism with 
that of other countries?"
result = db.query(query)
print(result)

图片

使用 Langchain 建立的 LLM 响应

查询将对数据进行语义搜索,并检索出对查询的适当回应。如果需要可以使用 langchain 的RetrievalQA模块进行链式处理,这里也使用 cohere 的 LLM:

from langchain.llms import Cohere
from langchain.chains import RetrievalQA

qa = RetrievalQA.from_chain_type(
        llm=Cohere(
            model="command-xlarge-nightly",
            temperature=temp_r,
            cohere_api_key=st.secrets["cohere_apikey"],
        ),
        chain_type="stuff",
        retriever=retriever,
        return_source_documents=True,
        chain_type_kwargs=chain_type_kwargs,
    )

3 LlamaIndex与LangChain应用场景

3.1 LlamaIndex

  • 构建具有特定知识库的查询和基于搜索的信息检索系统。

  • 开发能够针对用户查询仅提供相关信息片段的问答聊天机器人。

  • 对大型文档进行摘要、文本补全、语言翻译等。

3.2 LangChain

  • 构建端到端的会话聊天机器人和AI智能体。

  • 将自定义工作流程集成到大型语言模型(LLMs)中。

  • 通过APIs和其他数据源扩展LLMs的数据连接选项。

3.3 LlamaIndex和LangChain的结合使用案例

  • 构建专家级AI智能体:LangChain能够整合多种数据源,而LlamaIndex能够根据相似性语义搜索能力进行策划、摘要,并生成更快的响应。

  • 高级研发工具:利用LangChain的链式机制同步管理工具和工作流程,同时使用LlamaIndex帮助生成更具上下文意识的LLM,并获取最相关的响应。

4 选择框架:LlamaIndex vs LangChain

在选择LlamaIndex与LangChain这两个框架之前,需要思考几个关键问题:

  • 项目需求:如果目标是构建基础的索引、查询搜索和数据检索系统,LlamaIndex将是合适的选择。若项目需要集成复杂的自定义工作流程,则LangChain将更加合适。

  • 易用性:LlamaIndex以其简洁的界面著称,易于上手。相比之下,LangChain则要求用户对自然语言处理(NLP)的概念和组件有更深入的了解。

  • 定制程度:LangChain的模块化设计让其在定制化和工具集成方面更为灵活。而LlamaIndex则专注于提供高效的搜索和检索功能。

综上所述,LlamaIndex和LangChain都是构建定制化LLM应用的有力工具。LlamaIndex擅长搜索和检索,而LangChain则以其模块化和集成性胜出。如何选择取决于具体的项目需求、易用性偏好和定制化程度。

如果追求多功能集成和AI智能体,LangChain是理想选择。若目标是高效的信息索引和检索,LlamaIndex则更加合适,并且这两个框架可以协同工作。

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1859990.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Hadoop集群搭建】实验2:客户机操作系统CentOS的配置

1. 配置hadoop100 在finalshell中连接hadoop100 1.1 在CentOS7中配置静态ip vim /etc/sysconfig/network-scripts/ifcfg-ens33 将bootproto改成static,即ip地址改为静态,并添加刚才配置ip地址、网关和域名解析器。 1.2 将虚拟机名称改成hadoop100 编辑/…

「2024中国数据要素产业图谱1.0版」重磅发布,景联文科技凭借高质量数据采集服务入选!

近日,景联文科技入选数据猿和上海大数据联盟发布的《2024中国数据要素产业图谱1.0版》数据采集服务板块。 景联文科技是专业数据服务公司,提供从数据采集、清洗、标注的全流程数据解决方案,协助人工智能企业解决整个AI链条中数据采集和数据标…

IDEA 2024.01版本 git分支merge合并

使用idea工具来进行merge合并 1、拉取远端分支信息 2、我的分支是sprint-240627,我要将test分支合并到我这个分支上 找到test分支 3、选择【Merge origin/test into sprint-240627】 从test合并到我们要合并得分支上,结束 4、如果有冲突,就解决冲突即可…

【机器学习】ChatTTS:开源文本转语音(text-to-speech)大模型天花板

目录 一、引言 二、TTS(text-to-speech)模型原理 2.1 VITS 模型架构 2.2 VITS 模型训练 2.3 VITS 模型推理 三、ChatTTS 模型实战 3.1 ChatTTS 简介 3.2 ChatTTS 亮点 3.3 ChatTTS 数据集 3.4 ChatTTS 部署 3.4.1 创建conda环境 3.4.2 拉取源…

iptables(9)网络防火墙

简介 我们在第一篇介绍iptables的时候提到过,iptables是一个包过滤防火墙,那么防火墙是怎么分类的呢?都有哪些防火墙?下面我们先简单介绍下防火墙的分类: 按部署位置分类 网络层防火墙(网络边界防火墙):位于网络边界处,监控网络流量进出。主机防火墙:安装在单…

discuz迪恩cul!教育课程培训网站模板

Discuz x3.2模板 迪恩cul!教育课程培训 GBK,程序包中内附详细的安装教程,下载后按照教程安装即可 discuz迪恩cul!教育课程培训网站模板

区块链革命:Web3引领数字资产的全新篇章

随着区块链技术的发展和Web3的兴起,数字资产正迎来一场革命性的变革。本文将深入探讨区块链如何引领数字资产进入全新篇章,其背后的技术原理、应用场景以及对未来的深远影响。 ​1. 区块链技术的基础概念 区块链是一种去中心化的分布式账本技术&#xf…

【性能优化】Android冷启动优化

文章目录 常见现象APP的启动流程计算启动时间Displayed Timeadb dump 启动优化具体策略总结参考链接 常见现象 各种第三方工具初始化和大量业务逻辑初始化,影响启动时间,导致应用启动延迟、卡顿等现象 APP的启动流程 加载和启动应用程序; …

Pytorch之视频流猫狗识别

1. 导入资源包 // An highlighted block var foo bar;注: 1. import cv2: 导入OpenCV库,这是一个非常强大的计算机视觉库,用于处理图像和视频数据。 2. import tkinter as tk: 导入Tkinter库,这是Python的标准GUI库,…

“用友审批,工行付款”,YonSuite让企业采购更便利

随着市场竞争的日益激烈,成长型企业面临着越来越大的挑战。其中,采购管理作为企业运营的重要一环,其效率和便捷性直接关系到企业的成本和竞争力。然而,传统的采购管理方式往往存在诸多难点和痛点,如审批流程繁琐、付款…

海外青云私有云:企业的数字化转型得力助手

在全球化日益加深的今天,海外企业对于云计算的需求也愈发迫切。青云(QingCloud)作为一家领先的云计算服务提供商,其私有云产品在海外市场上受到了广泛的关注和认可。那么,海外青云私有云究竟有何用处呢?本文将从多个角度为您科普。 首先&…

# Kafka_深入探秘者(5):kafka 分区

Kafka_深入探秘者(5):kafka 分区 一、kafka 副本机制 1、Kafka 可以将主题划分为多个分区(Partition),会根据分区规则选择把消息存储到哪个分区中,只要如果分区规则设置的合理,那么所有的消息将会被均匀的…

Linux_生产消费模型_Block_Queue

目录 一、互斥锁 1.1 错误的抢票 1.1.1 类的成员函数与构造 1.1.2 start 函数 1.1.3 线程的回调函数 1.1.4 main 函数 1.1.5 结果 1.2 概念 1.3 相关系统调用 1.3.1 锁的创建 1.3.2 锁的初始化 1.3.2.1 动态初始化 1.3.2.2 静态初始化 1.3.3 锁的销毁 1.3.4…

如何在电脑上免费下载并安装 VMware Workstation Pro

下载 VMware 首先我们先来看一看免费下载VMware Workstation Pro 的具体步骤: 首先我们可以先进入 Broadcom 注册页面:https://profile.broadcom.com/web/registration,然后这时候就需要注册,我们可以使用电子邮件进行注册。 在…

B端系统:增删改查中的新建(增)页面如何设计体验更爽。

在B系统中,增删改查是最基本、最常用的功能之一。这四个操作对于系统的正常运行和数据管理至关重要。其中,新增(新建)页面的设计尤为关键,因为它直接影响着用户体验和系统功能的完整性。 一、新增(新建&…

springboot加载注入bean的方式

在SpringBoot的大环境下,基本上很少使用之前的xml配置Bean,主要是因为这种方式不好维护而且也不够方便。 springboto注入bean主要采用下图几种方式,分为本地服务工程注解声明的bean和外部依赖包中的bean。 一、 springboot装配本地服务工程…

Linux环境下安装MySQL5.7.20(源码安装)

📣📣📣 哈喽!大家好,本专栏主要发表mysql实战的文章,文章主要包括: 各版本数据库的安装、备份和恢复,性能优化等内容的学习。。 📣 ***如果需要观看配套视频的小伙伴们,请…

单体架构改造为微服务架构之痛点解析

1.微服务职责划分之痛 1.1 痛点描述 微服务的难点在于无法对一些特定职责进行清晰划分,比如某个特定职责应该归属于服务A还是服务B? 1.2 为服务划分原则的痛点 1.2.1 根据存放主要数据的服务所在进行划分 比如一个能根据商品ID找出商品信息的接口,把…

Redis持久化(RDB、AOF)详解

Redis持久化详解 一、Redis为什么需要持久化? Redis 是一个基于内存的数据库,拥有极高的读写性能,但是内存中的数据在断电或服务器重启时会全部丢失,因此需要一种持久化机制来将数据保存到硬盘上,以便在需要时进行恢复…

R语言数据分析案例34-基于ARIMA模型的武汉市房价趋势与预测研究

一、背景阐述 房地产行业对于国民经济和社会及居民的发展和生活具有很大的影响,而房价能够体现经济运转的好坏,因而房价的波动牵动着开发商和购房者的关注,城市房价预测是一个研究的热点问题,研究房价对民生问题具有重要意义。 …