Agentless项目在SWE-bench lite测试中的性能复现问题分析
2025-07-10 23:58:08作者:庞眉杨Will
背景介绍
Agentless是一个开源代码修复工具,最新发布的1.5版本在SWE-bench lite测试集上声称达到了32%的修复通过率。然而,有用户在尝试复现这一结果时遇到了困难,仅能获得26%-29.67%的通过率,这表明在复现过程中可能存在一些关键步骤的误解。
问题核心
用户在复现Agentless 1.5版本的SWE-bench lite测试结果时,采用了合并40个样本输出文件的方法,这实际上是不正确的处理方式。正确的做法应该是保持样本文件的独立性,并通过rerank.py脚本的特定参数配置来处理多个样本文件夹。
正确使用方法
根据项目维护者的说明,正确的执行流程应该是:
- 保持四个修复样本文件夹(repair_sample_1到repair_sample_4)的独立性
- 使用rerank.py脚本时,通过逗号分隔的方式指定所有样本文件夹路径
- 设置num_samples参数为40(总样本数)
- 启用deduplicate(去重)、regression(回归)和reproduction(复现)标志
具体命令格式如下:
python agentless/repair/rerank.py \
--patch_folder results/swe-bench-lite/repair_sample_1/,results/swe-bench-lite/repair_sample_2/,results/swe-bench-lite/repair_sample_3/,results/swe-bench-lite/repair_sample_4 \
--num_samples 40 \
--deduplicate \
--regression \
--reproduction
技术要点解析
-
样本独立性:每个样本文件夹中的输出文件应保持独立,不应手动合并。rerank.py脚本内部会处理多个样本的集成。
-
参数含义:
- deduplicate:去除重复的修复方案
- regression:考虑回归测试结果
- reproduction:确保修复方案的可复现性
-
性能差异原因:手动合并样本文件可能导致信息丢失或处理逻辑错误,从而影响最终的修复质量评估结果。
最佳实践建议
- 严格按照项目文档中的说明进行操作
- 保持原始样本文件夹结构不变
- 使用完整的参数配置调用rerank.py脚本
- 对于大型测试集,可以考虑使用分布式处理来提升效率
总结
正确使用Agentless工具链对于获得预期的性能结果至关重要。通过理解工具的设计原理和遵循正确的操作流程,开发者可以准确复现项目声称的性能指标,并在此基础上进行进一步的优化和定制开发。
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
jiuwenclawJiuwenClaw 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。Python0204- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01
awesome-zig一个关于 Zig 优秀库及资源的协作列表。Makefile00
热门内容推荐
最新内容推荐
项目优选
收起
deepin linux kernel
C
27
12
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
609
4.05 K
Ascend Extension for PyTorch
Python
447
534
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
924
774
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.47 K
829
暂无简介
Dart
851
205
React Native鸿蒙化仓库
JavaScript
322
377
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
372
251
昇腾LLM分布式训练框架
Python
131
157