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}
}

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

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

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

下拉加载更多