LlamaIndex 是一个基于 LLM(大语言模型)的应用程序数据框架,适用于受益于上下文增强的场景。

这类 LLM 系统被称为 RAG(检索增强生成)系统。

LlamaIndex 提供了必要的抽象层,以便更容易地摄取、结构化和访问私有或特定领域的数据,从而安全可靠地将这些数据注入 LLM 中,以实现更准确的文本生成。

它支持 Python(本文档)和 TypeScript。

提示:更新到 LlamaIndex v0.10.0?请查看迁移指南。

为什么选择上下文增强?

LLM 为人类与数据之间提供自然语言接口。广泛可用的模型预先训练在大量公开数据上,如维基百科、邮件列表、教科书、源代码等。

然而,尽管 LLM 接受了大量的数据训练,但它们并未针对您的数据进行训练,而这些数据可能是私有的,或者与您试图解决的问题密切相关。它们可能隐藏在 API 中、存放在 SQL 数据库中,或者困在 PDF 和幻灯片中。

您可能会选择使用您的数据对 LLM 进行微调,但:

  • 训练 LLM 成本高昂;
  • 由于训练成本高,难以用最新信息更新 LLM;
  • 观察性不足。当您向 LLM 提问时,无法明确得知 LLM 如何得出答案。

作为替代方案,可以采用名为检索增强生成(RAG)的上下文增强模式,以获得与您的特定数据相关的更准确文本生成。RAG 包括以下高级步骤:

  1. 首先从您的数据源检索信息;
  2. 将这些信息添加到问题中作为上下文;
  3. 请求 LLM 根据丰富后的提示回答问题。

通过这种方式,RAG 克服了微调方法的三个弱点:

  • 不涉及训练,因此成本低廉;
  • 数据仅在请求时抓取,始终保持最新;
  • LlamaIndex 可以显示检索到的文档,从而更具可信度。

为何选择 LlamaIndex 进行上下文增强?

首先,LlamaIndex 并不限制您如何使用 LLM。您仍然可以将其用作自动补全、聊天机器人、半自主代理等(参见左侧的使用案例)。它只是让 LLM 更贴近您的需求。

LlamaIndex 提供以下工具,帮助您快速构建生产级 RAG 系统:

  • 数据连接器:从原生来源和格式摄取现有数据,如 APIs、PDF、SQL 等;
  • 数据索引:将您的数据结构化为易于 LLM 消耗且性能优异的中间表示形式;
  • 引擎:提供对您数据的自然语言访问,例如:
    • 查询引擎:强大的检索界面,用于知识增强输出;
    • 聊天引擎:对话式接口,用于与数据进行多消息、“来回”交互;
    • 数据代理:由工具(从简单辅助函数到 API 集成等)增强的 LLM 动力知识工作者;
  • 应用集成:将 LlamaIndex 与您的生态系统其余部分(如 LangChain、Flask、Docker、ChatGPT 或任何其他工具)紧密关联。

‍‍‍ LlamaIndex 适合哪些人群?

LlamaIndex 为初学者、高级用户以及介于两者之间的所有人提供工具。

  • 初学者:通过高级 API,初学者只需用 5 行代码即可使用 LlamaIndex 摄取和查询其数据;
  • 高级用户:对于复杂应用,我们的低级 API 允许高级用户自定义和扩展任何模块(数据连接器、索引、检索器、查询引擎、重排序模块),以满足其特定需求。

开始使用

要安装库,请运行:

bash
 
pip install llama-index

我们建议从如何阅读这些文档开始,它会根据您的经验水平引导您找到正确的位置。

️ 生态系统

您可以在以下平台找到、下载或贡献 LlamaIndex:

社区

需要帮助?有功能建议?加入 LlamaIndex 社区:

关联项目

  • LlamaHub | 一个大型(且不断增长)的自定义数据连接器集合
  • SEC Insights | 一个由 LlamaIndex 提供支持的金融研究应用程序
  • create-llama | 一个 CLI 工具,快速为 LlamaIndex 项目搭建脚手架

AI 新世代

ChatAiOnline

Ref:https://docs.llamaindex.ai/en/stable/

Link:https://www.cnblogs.com/farwish/p/18133682

LlamaIndex 是什么的更多相关文章

  1. 读破万卷,神交古人,突破ChatGPT4096的Token限制,建立自己的垂直领域资料人工智能助理

    ChatGPT的泛用性极高,上知天文,下通地理,参考古今,博稽中外,几乎无所不知,无所不晓.但如果涉及垂直领域的专业知识点,ChatGPT难免也会有语焉不详,闪烁其词的毛病,本次我们将特定领域的学习材 ...

  2. 性能最快的代码分析工具,Ruff 正在席卷 Python 圈!

    几天前,Python 开源社区又出了一个不小的新闻:HTTPX 和 Starlette 在同一天将在用的代码分析工具(flake8.autoflake 和 isort)统一替换成了 Ruff. HTT ...

随机推荐

  1. java基础 韩顺平老师的 面向对象(中级) 自己记的部分笔记

    272,包基本介绍 包的三大作用 1,区分相同的类   2,当类很多时,可以很好的管理类   3,控制访问范围 包基本用法 package com.hspedu; 说明: 1,package 关键字, ...

  2. 3DCAT+东风日产:共建线上个性化订车实时云渲染方案

    近年来,随着5G网络和云计算技术的不断发展,交互式3D实时云看车正在成为一种新的看车方式. 与传统的到4S店实地考察不同,消费者可以足不出户,通过网络与终端设备即可实现全方位展示.自选汽车配色.模拟效 ...

  3. C#断字符串是否为数字,用正则表达式

  4. vue中elementui表格错位问题解决(一次到位)

    引入element-resize-detector 在项目引入插件(用来监听元素宽度变化) npm install element-resize-detector --save 在文件中引入(写在sc ...

  5. Nancy如何接收POST过来的Json数据

    当Nancy版本为2.0.0.0时 string postData = Request.Body.AsString; 当Nancy版本为1.4.5.0时 自己写一个扩展方法,代码如下 /// < ...

  6. 学习笔记-Kafka消息队列

    官网地址:https://kafka.apache.org/ 一.认识kafka 1.认识kafka Apache Kafka是Apache软件基金会的开源的流处理平台,该平台提供了消息的订阅与发布的 ...

  7. KingbaseES kdb_database_link客户端字符集导致的乱码问题

    前言 关于我们经常见到的字符集乱码问题,很可能因为数据库服务器端的操作系统字符集和客户端字符集不一致导致的. 当我们通过kdb_database_link插件访问oracle数据库出现乱码,只需要调整 ...

  8. Scala mutable.Map可变的Map

    1 package chapter07 2 3 import scala.collection.mutable 4 5 object Test09_MutableMap { 6 def main(ar ...

  9. Android记账本界面实现

    <!--activity_main.xml-->1 <?xml version="1.0" encoding="utf-8"?> 2 & ...

  10. #轮廓线dp#洛谷 2435 染色

    题目 有一个 \(n\) 行 \(m\) 列的格点图,你需要给每个点上染上 \(k\) 种颜色中的一种, 要求没有两个相邻点颜色相同.给定第一行与最后一行的染色,试求总染色方案数. 分析 首先对于 \ ...