SimplyRetrieve

SimplyRetrieve

私密轻量化的检索中心生成AI工具

SimplyRetrieve是一款开源的检索中心生成(RCG)平台,提供本地化、轻量级的GUI和API接口。它具有检索调优、私有知识库构建和本地大语言模型访问等功能,旨在推动安全可解释的AI系统开发。该工具可在单个NVIDIA GPU上运行,适合各类机器学习研究人员使用。

SimplyRetrieve检索生成开源工具大语言模型本地化Github开源项目

SimplyRetrieve:私密轻量级的检索中心生成式AI工具

DOI GitHub GitHub release (with filter)

📰新闻2023年8月21日 -- 用户现在可以通过GUI中新增的"知识标签"即时创建和追加知识。此外,配置和知识标签中还添加了进度条。

🤔 什么是SimplyRetrieve?

SimplyRetrieve是一个开源工具,旨在为机器学习社区提供完全本地化、轻量级且用户友好的GUI和API平台,用于检索中心生成(RCG)方法。

使用您的文档和语言模型创建聊天工具,高度可定制。特点包括:

  • 📚 基于GUI和API的检索中心生成平台
  • 🔧 检索调优模块,包括提示工程、工具配置和检索分析
  • 🏡 私有知识库构建器
  • 🧠 完全本地化、私密且轻量级访问各种规模的开源大型语言模型(LLMs)
  • 🚥 多用户并发访问UI,利用Gradio的队列功能

关于这个工具的技术报告可在arXiv上获取。📖

关于这个工具的短视频可在YouTube上观看。🎞️

工具概览

💡 为什么要开发这个工具?

我们的目标是通过分享我们的开源工具来实现RCG方法,从而促进安全、可解释和负责任的LLMs的发展。我们希望这个工具能让机器学习社区以更高效的方式探索LLMs的使用,同时保持隐私和本地实现。检索中心生成在检索增强生成(RAG)概念的基础上,强调LLMs在上下文解释中的关键作用,并将知识记忆委托给检索器组件,有潜力产生更高效和可解释的生成,并减少生成任务所需的LLMs规模。这个工具可以在单个Nvidia GPU上运行,如T4、V100或A100,使其对广泛的用户都可访问。

这个工具主要基于Hugging FaceGradioPyTorchFaiss这些优秀且熟悉的库构建。该工具中默认配置的LLM是经过指令微调的Wizard-Vicuna-13B-Uncensored。检索器的默认嵌入模型是multilingual-e5-base。我们发现这些模型在这个系统中运行良好,Hugging Face中还有许多其他不同规模的开源LLMs和检索器可用。这个工具也可以使用英语以外的其他语言运行,只需根据目标语言选择适当的LLMs并自定义提示模板即可。

🔍 使用这个工具可以探索哪些潜在的发展?

  • 检验检索中心生成在开发更安全、更可解释和负责任的AI系统中的有效性
  • 优化检索中心生成方法中上下文解释和知识记忆分离的效率
  • 改进检索中心生成的提示工程技术
  • 实现完全本地和边缘计算的聊天AI
  • 创建针对个别用户定制的个性化AI助手

🔨 运行此工具的先决条件是什么?

  • Git克隆此仓库。
  • 在基于GPU的Linux机器上,激活你喜欢的Python虚拟环境,安装必要的包
    • pip install -r requirements.txt
  • 可选:如果你想使用自己的数据作为知识源,可以按以下步骤操作。但是,如果你想从更简单的示例开始,可以跳过这些步骤,使用工具提供的默认简单样本知识源。请注意,样本知识源仅用于演示目的,不应用于性能评估。为了获得准确的结果,建议使用你自己的知识源或维基百科源进行一般用途。
    • 准备用于检索的知识源:将相关文档(pdf等)放入chat/data/目录,然后运行数据准备脚本(cd chat/后执行以下命令)
      CUDA_VISIBLE_DEVICES=0 python prepare.py --input data/ --output knowledge/ --config configs/default_release.json
      
    • 支持的文档格式有pdf、txt、doc、docx、ppt、pptx、html、md、csv,可通过编辑配置文件轻松扩展。如果出现NLTK相关错误,请参考此问题的提示。
    • 最新:现在可以通过GUI工具的"知识"选项卡创建知识库。用户现在可以即时添加知识。在运行工具之前不需要执行上述prepare.py脚本。

🏃 如何运行此工具?

设置好上述先决条件后,将当前路径设置为chat目录(cd chat/),执行以下命令。然后"去喝杯咖啡吧!"因为它只需要几分钟就能加载完成。

CUDA_VISIBLE_DEVICES=0 python chat.py --config configs/default_release.json

然后,通过在你喜欢的浏览器中导航到http://<本地服务器IP>:7860来访问基于Web的GUI。将<本地服务器IP>替换为你的GPU服务器的IP地址。就是这样,你已经准备就绪了!

  • 关于GUI操作手册,请参考docs/目录中的GUI自述文件
  • 关于API访问手册,请参考examples/目录中的API自述文件和示例脚本。

以下是GUI的示例聊天截图。它提供了一个熟悉的流式聊天机器人界面,带有全面的RCG调优面板。

平台GUI示例

目前没有本地GPU服务器来运行这个工具?没问题。访问这个仓库。它展示了在AWS EC2云平台上尝试这个工具的说明。

🤝 贡献

欢迎给我们任何反馈和评论。我们非常欢迎关于这个工具的任何讨论和贡献,包括新功能、改进和更好的文档。随时开启问题或讨论。我们目前还没有问题或讨论的模板,所以现在任何形式都可以。

🛣️ 路线图

未来发展

  • 支持vLLM PagedAttention高吞吐量推理
  • 添加检索中心记忆(聊天历史)组件
  • 创建全面的文档

⚠️ 局限性

需要注意的是,即使在以检索为中心的方法中,这个工具也不能为确保生成式AI模型完全安全和负责任的响应提供万无一失的解决方案。开发更安全、可解释和负责任的AI系统仍然是一个活跃的研究领域和持续的努力。

由于当前一代LLM的下一个token预测行为,即使只是稍微修改提示或查询,该工具生成的文本也可能会出现变化。这意味着用户可能需要仔细微调提示和查询,以获得最佳响应。

📝 引用

如果你觉得我们的工作有用,请按以下方式引用我们:

@article{ng2023simplyretrieve,
    title={SimplyRetrieve: A Private and Lightweight Retrieval-Centric Generative AI Tool}, 
    author={Youyang Ng and Daisuke Miyashita and Yasuto Hoshi and Yasuhiro Morioka and Osamu Torii and Tomoya Kodama and Jun Deguchi},
    year={2023},
    eprint={2308.03983},
    archivePrefix={arXiv},
    primaryClass={cs.CL},
    journal={arXiv preprint arXiv:2308.03983}
}

🏛️ 机构:日本铠侠株式会社记忆技术研发所

编辑推荐精选

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

TRELLIS

TRELLIS

用于可扩展和多功能 3D 生成的结构化 3D 潜在表示

TRELLIS 是一个专注于 3D 生成的项目,它利用结构化 3D 潜在表示技术,实现了可扩展且多功能的 3D 生成。项目提供了多种 3D 生成的方法和工具,包括文本到 3D、图像到 3D 等,并且支持多种输出格式,如 3D 高斯、辐射场和网格等。通过 TRELLIS,用户可以根据文本描述或图像输入快速生成高质量的 3D 资产,适用于游戏开发、动画制作、虚拟现实等多个领域。

ai-agents-for-beginners

ai-agents-for-beginners

10 节课教你开启构建 AI 代理所需的一切知识

AI Agents for Beginners 是一个专为初学者打造的课程项目,提供 10 节课程,涵盖构建 AI 代理的必备知识,支持多种语言,包含规划设计、工具使用、多代理等丰富内容,助您快速入门 AI 代理领域。

AEE

AEE

AI Excel全自动制表工具

AEE 在线 AI 全自动 Excel 编辑器,提供智能录入、自动公式、数据整理、图表生成等功能,高效处理 Excel 任务,提升办公效率。支持自动高亮数据、批量计算、不规则数据录入,适用于企业、教育、金融等多场景。

UI-TARS-desktop

UI-TARS-desktop

基于 UI-TARS 视觉语言模型的桌面应用,可通过自然语言控制计算机进行多模态操作。

UI-TARS-desktop 是一款功能强大的桌面应用,基于 UI-TARS(视觉语言模型)构建。它具备自然语言控制、截图与视觉识别、精确的鼠标键盘控制等功能,支持跨平台使用(Windows/MacOS),能提供实时反馈和状态显示,且数据完全本地处理,保障隐私安全。该应用集成了多种大语言模型和搜索方式,还可进行文件系统操作。适用于需要智能交互和自动化任务的场景,如信息检索、文件管理等。其提供了详细的文档,包括快速启动、部署、贡献指南和 SDK 使用说明等,方便开发者使用和扩展。

Wan2.1

Wan2.1

开源且先进的大规模视频生成模型项目

Wan2.1 是一个开源且先进的大规模视频生成模型项目,支持文本到图像、文本到视频、图像到视频等多种生成任务。它具备丰富的配置选项,可调整分辨率、扩散步数等参数,还能对提示词进行增强。使用了多种先进技术和工具,在视频和图像生成领域具有广泛应用前景,适合研究人员和开发者使用。

爱图表

爱图表

全流程 AI 驱动的数据可视化工具,助力用户轻松创作高颜值图表

爱图表(aitubiao.com)就是AI图表,是由镝数科技推出的一款创新型智能数据可视化平台,专注于为用户提供便捷的图表生成、数据分析和报告撰写服务。爱图表是中国首个在图表场景接入DeepSeek的产品。通过接入前沿的DeepSeek系列AI模型,爱图表结合强大的数据处理能力与智能化功能,致力于帮助职场人士高效处理和表达数据,提升工作效率和报告质量。

Qwen2.5-VL

Qwen2.5-VL

一款强大的视觉语言模型,支持图像和视频输入

Qwen2.5-VL 是一款强大的视觉语言模型,支持图像和视频输入,可用于多种场景,如商品特点总结、图像文字识别等。项目提供了 OpenAI API 服务、Web UI 示例等部署方式,还包含了视觉处理工具,有助于开发者快速集成和使用,提升工作效率。

下拉加载更多