MTEB项目中的可选依赖优化方案
2025-07-01 11:26:55作者:柏廷章Berta
背景介绍
MTEB(Massive Text Embedding Benchmark)是一个用于评估文本嵌入模型性能的基准测试框架。随着项目的发展,特别是将MIEB(多模态嵌入基准)合并到主分支后,项目的依赖项数量显著增加。这给用户带来了不必要的安装负担,特别是对于那些不需要使用全部功能的用户。
依赖项分析
当前MTEB项目的主要依赖项包括:
-
核心必需依赖:
- datasets(>=2.19.0,<3.0.0)
- numpy(>=1.0.0,<3.0.0)
- scikit-learn(>=1.0.2)
- scipy(用于STS和摘要任务中的pearsonr、spearmanr计算)
- torch(>1.0.0)
- tqdm(>1.0.0)
- pytrec-eval-terrier(>=0.5.6)
- pydantic(>=2.0.0)
- typing_extensions(用于Pydantic的TypedDict验证)
-
潜在可选依赖:
- torchvision(MIEB所需)
- sentence_transformers(>=3.0.0)
- requests(>=2.26.0)
- rich(可通过#1046移除)
-
其他依赖:
- polars(>=0.20.22)
- eval_type_backport(具体用途待确认)
优化方案
针对上述依赖分析,项目团队提出了以下优化方案:
-
MIEB相关依赖作为可选安装:
- 创建
mteb[mieb]可选安装组,包含torchvision和其他MIEB模型相关依赖 - torchvision版本与torch对齐,建议设置为">0.2.1"
- 创建
-
其他可选依赖处理:
- 保留sentence_transformers为必需依赖,因其改动涉及大量代码重构
- requests可考虑设为可选,因其主要用于模型部分
- rich依赖可通过#1046完全移除
-
未来优化方向:
- 持续评估各依赖项的必要性
- 考虑为不同功能模块创建更多可选安装组
- 监控依赖版本兼容性问题
技术实现细节
在技术实现上,Python项目可以通过setup.py或pyproject.toml中的extras_require来定义可选依赖组。例如:
extras_require = {
'mieb': ["torchvision>0.2.1", ...],
# 可添加更多可选组
}
用户可以通过以下方式安装带有可选功能的包:
pip install mteb[mieb]
总结
通过将非核心功能相关的依赖项设为可选,MTEB项目能够:
- 减少基础安装的依赖项数量
- 降低用户安装负担
- 提高项目的灵活性
- 保持核心功能的稳定性
这种优化方式在大型Python项目中是常见的最佳实践,特别是当项目功能模块不断增加时。它不仅改善了用户体验,也使得项目维护更加清晰和模块化。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0153- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112
项目优选
收起
暂无描述
Dockerfile
733
4.75 K
deepin linux kernel
C
31
16
Ascend Extension for PyTorch
Python
652
797
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.25 K
153
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.1 K
611
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.01 K
1.01 K
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
147
237
昇腾LLM分布式训练框架
Python
168
200
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
434
395
暂无简介
Dart
986
253