Project Icon

bm25s

为文本检索提供极速Python BM25实现

BM25S为基于Python的文本检索排名函数,使用Scipy稀疏矩阵实现快速响应。其性能显著优于传统库,支持多种BM25变体,提供灵活API及Hugging Face集成,适合大规模数据的内存效率处理。

BM25S 项目介绍

什么是 BM25S?

BM25S 是一个用纯 Python 实现的超快速的 BM25 算法库,依托于 Scipy 稀疏矩阵技术来提升性能。BM25 是文本检索任务中使用广泛的排序函数,也是像 Elasticsearch 这样的搜索服务的核心组件。

BM25S 的特点

BM25S 以以下两大特点闻名:

  • 快速:借助于 Scipy 稀疏矩阵,BM25S 可以在查询时极快地评分,为所有文档中的词语预先计算得分,从而大幅提高性能。
  • 简单:安装 BM25S 非常简单,可以通过 pip 快速安装并使用。它没有对 Java 或 Pytorch 的依赖,只需要 Scipy 和 Numpy,以及可选的轻量级词干化依赖。

安装与快速开始

安装 BM25S

用户可以通过下面的命令来安装 BM25S:

pip install bm25s

对于更好的检索结果,用户还可以安装词干化工具:

pip install bm25s[full]
pip install PyStemmer
pip install jax[cpu]

快速开始

下面是一个简短的例子,展示如何使用 BM25S 来检索文本:

import bm25s
import Stemmer

corpus = [
    "a cat is a feline and likes to purr",
    "a dog is the human's best friend and loves to play",
    "a bird is a beautiful animal that can fly",
    "a fish is a creature that lives in water and swims",
]

stemmer = Stemmer.Stemmer("english")
corpus_tokens = bm25s.tokenize(corpus, stopwords="en", stemmer=stemmer)

retriever = bm25s.BM25()
retriever.index(corpus_tokens)

query = "does the fish purr like a cat?"
query_tokens = bm25s.tokenize(query, stemmer=stemmer)

results, scores = retriever.retrieve(query_tokens, corpus=corpus, k=2)

for i in range(results.shape[1]):
    doc, score = results[0, i], scores[0, i]
    print(f"Rank {i+1} (score: {score:.2f}): {doc}")

灵活性

BM25S 提供了高度灵活的 API,用户可以根据需要自定义 BM25 模型和标记化过程。例如,可以使用自定义的停用词列表或词干化功能来优化检索结果。

内存高效检索

BM25S 具有内存高效的设计,支持使用内存映射文件来保存 BM25 索引,从而在不加载完整索引的情况下检索文档。这在需要处理非常大的索引时特别有用。

不同的 BM25 变种

BM25S 支持多种 BM25 的变种,包括原始实现、ATIRE、BM25L、BM25+ 和 Lucene 版本。用户可以根据具体需求选择合适的实现方法。

Hugging Face 集成

BM25S 可以与 Hugging Face 公共模型仓库完美集成,让用户可以方便地共享 BM25 索引并使用社区提供的模型。

性能对比

在性能测试中,BM25S 显示出显著的速度优势,在各种数据集上的每秒查询数 (QPS) 高于其他流行 BM25 实现。

项目核心理念与贡献

BM25S 的中心思想和许多功能从一开始便受到了其他相关项目的启发,包括 bm25_pt 和 rank-bm25,包含多语言停用词列表的灵感来自 NLTK,及 numba 的实现受到 kiwa 和 retriv 大力支持。

欢迎对 BM25S 感兴趣的用户下载、使用,并将其应用于自己的工作,大大提升文档检索效率。请在您的工作中引用 BM25S。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号