SWE-fficiency: Can Language Models Optimize Real-World Repositories on Real Workloads?
Jeffrey Jian Ma, Milad Hashemi, Amir Yazdanbakhsh, Kevin Swersky, Ofir Press, Enhui Li, Vijay Janapa Reddi, Parthasarathy Ranganathan
TL;DR
SWE-fficiency addresses the gap in evaluating repo-level performance optimization by requiring language-model agents to investigate real codebases, localize runtime bottlenecks, and produce correctness-preserving patches that speed up real workloads. The benchmark assembles 498 tasks across 9 popular Python repositories using a principled data collection pipeline and a speedup-ratio evaluation against expert gold patches, with a strict separation of correctness and performance tests. Empirical results show substantial gaps between current LM agents and expert performance, including widespread mislocalization of bottlenecks and frequent correctness regressions, even as easier tasks yield modest gains. By releasing a scalable dataset, reproducible evaluation harness, and analysis of failure modes, SWE-fficiency aims to catalyze advances in long-horizon software reasoning and automated performance engineering.
Abstract
Optimizing the performance of large-scale software repositories demands expertise in code reasoning and software engineering (SWE) to reduce runtime while preserving program correctness. However, most benchmarks emphasize what to fix rather than how to fix code. We introduce SWE-fficiency, a benchmark for evaluating repository-level performance optimization on real workloads. Our suite contains 498 tasks across nine widely used data-science, machine-learning, and HPC repositories (e.g., numpy, pandas, scipy): given a complete codebase and a slow workload, an agent must investigate code semantics, localize bottlenecks and relevant tests, and produce a patch that matches or exceeds expert speedup while passing the same unit tests. To enable this how-to-fix evaluation, our automated pipeline scrapes GitHub pull requests for performance-improving edits, combining keyword filtering, static analysis, coverage tooling, and execution validation to both confirm expert speedup baselines and identify relevant repository unit tests. Empirical evaluation of state-of-the-art agents reveals significant underperformance. On average, agents achieve less than 0.15x the expert speedup: agents struggle in localizing optimization opportunities, reasoning about execution across functions, and maintaining correctness in proposed edits. We release the benchmark and accompanying data pipeline to facilitate research on automated performance engineering and long-horizon software reasoning.
