diff --git a/README.md b/README.md index 4574715..fcd1d2c 100644 --- a/README.md +++ b/README.md @@ -1,9 +1,11 @@ # InfCode -[![Python 3.12+](https://img.shields.io/badge/python-3.12+-blue.svg)](https://www.python.org/downloads/) [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) +[![Python 3.12+](https://img.shields.io/badge/python-3.12+-blue.svg)](https://www.python.org/downloads/) [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) [![arXiv:2511.16004](https://img.shields.io/badge/TechReport-arXiv%3A2511.16004-b31a1b)](https://arxiv.org/abs/2511.16004) -**InfCode** is an intelligent Code Agent System developed by [Tokfinity](https://www.tokfinity.com)'s Code Research team, which uses LLMs to automatically analyze and fix Code Repo issues. +InfCode is an adversarial multi-agent Code Agent System developed by [Tokfinity](https://www.tokfinity.com)'s Code Research team & Beihang University, which uses LLMs to automatically analyze and fix Code Repo issues. + +InfCode introduces a dual-agent adversarial refinement framework that iteratively improves both test patches and code patches, producing highly reliable fixes verified under strengthened test suites. **Project Status:** InfCode has achieved **79.4%** solution rate on the SWE-Bench Verified split, demonstrating the **latest SOTA** performance. @@ -15,9 +17,13 @@ ### Core Modules -The InfCode adopts a generate-select architectural pattern. Its core modules include the **Patch Generator** and the **Patch Selector**, which are responsible for generating candidate patches and selecting the optimal patch, respectively. +The InfCode adopts a generate-select architectural pattern. Its core modules include the **Patch Generation** and the **Patch Selection**, which are responsible for generating candidate patches and selecting the optimal patch, respectively. - **Patch Generator**: Register multiple groups of generators, where each generator is configured with a separate container to generate and repair multiple candidate patches in parallel. Can interact with `File Editor`, `File Search`, `Bash Executor`, `Result Submitter` tools. The Patch Generator runs up to $5$ attempts and gathers all produced patches. + + - The Generator internally contains two agents: a **Test Patch Generator** and a **Code Patch Generator**, that iteratively improve tests and code in an adversarial loop. The Test Generator strengthens tests to better expose faults, and the Code Generator refines patches to satisfy the newly enhanced tests. + + - **Patch Selector**: Select the best patch from all the candidate patches. Can interact with `File Editor`, `File Search`, `Bash Executor` tools. diff --git a/figures/framework.svg b/figures/framework.svg index f99e123..feae206 100644 --- a/figures/framework.svg +++ b/figures/framework.svg @@ -4,9 +4,9 @@ @@ -16,8 +16,7 @@ clipPathUnits="userSpaceOnUse" id="clipPath2"> @@ -25,8 +24,7 @@ clipPathUnits="userSpaceOnUse" id="clipPath4"> @@ -34,176 +32,176 @@ clipPathUnits="userSpaceOnUse" id="clipPath6"> + id="clipPath8"> + id="path8" /> + id="clipPath10"> + id="path10" /> - - - + + + - - - - - - - - - + id="mask15"> + xlink:href="" + id="image15" /> + + + + + + + + + + id="clipPath23"> + id="path23" /> + id="clipPath26"> + id="path26" /> + + + + id="clipPath31"> + id="path31" /> @@ -211,8 +209,7 @@ clipPathUnits="userSpaceOnUse" id="clipPath34"> @@ -220,167 +217,188 @@ clipPathUnits="userSpaceOnUse" id="clipPath35"> - - - + id="clipPath37"> + id="path37" /> - - - - - - - - - + + + + id="clipPath44"> + id="path44" /> + + + + id="clipPath46"> + id="path46" /> + + + + id="clipPath48"> + id="path48" /> + + + + + + + + + @@ -388,107 +406,152 @@ clipPathUnits="userSpaceOnUse" id="clipPath56"> + id="clipPath58"> + id="path58" /> + id="clipPath60"> - - - + id="path60" /> + + + + + + + + + + + + + + + + id="clipPath71"> + id="path71" /> + id="clipPath73"> + id="path73" /> + + + @@ -496,8 +559,8 @@ clipPathUnits="userSpaceOnUse" id="clipPath77"> @@ -505,56 +568,50 @@ clipPathUnits="userSpaceOnUse" id="clipPath78"> - - - + + + + id="mask80"> @@ -570,48 +627,57 @@ height="1" style="image-rendering:optimizeSpeed" preserveAspectRatio="none" - xlink:href="" + xlink:href="" id="image82" /> + + + + + + + id="mask85"> + xlink:href="" + id="image85" /> - - - @@ -619,32 +685,17 @@ clipPathUnits="userSpaceOnUse" id="clipPath87"> - - - @@ -652,8 +703,7 @@ clipPathUnits="userSpaceOnUse" id="clipPath90"> @@ -661,8 +711,7 @@ clipPathUnits="userSpaceOnUse" id="clipPath92"> @@ -670,62 +719,99 @@ clipPathUnits="userSpaceOnUse" id="clipPath93"> + + + + + + + id="clipPath97"> - - - + id="path97" /> + + + + + + @@ -733,41 +819,24 @@ clipPathUnits="userSpaceOnUse" id="clipPath104"> - - - + id="clipPath106"> + id="path106" /> @@ -775,8 +844,8 @@ clipPathUnits="userSpaceOnUse" id="clipPath108"> @@ -784,95 +853,101 @@ clipPathUnits="userSpaceOnUse" id="clipPath109"> - - - - - - - - - - - - - - - - - - - - - + id="mask109"> + xlink:href="" + id="image109" /> + + + + + + + + + + + + + + + + + + + + + + + + @@ -888,60 +963,81 @@ height="1" style="image-rendering:optimizeSpeed" preserveAspectRatio="none" - xlink:href="" - id="image122" /> + xlink:href="" + id="image121" /> + id="clipPath122"> + id="path122" /> + + + + + + + id="clipPath127"> - - - + id="path127" /> + + + @@ -949,44 +1045,73 @@ clipPathUnits="userSpaceOnUse" id="clipPath132"> + + + + id="clipPath133"> + id="path133" /> + + + + id="clipPath136"> + id="path136" /> @@ -1002,843 +1127,530 @@ height="1" style="image-rendering:optimizeSpeed" preserveAspectRatio="none" - xlink:href="" + xlink:href="" id="image138" /> - - - - - - - - - + + + - - - + + + - - - + + + + + + + + + + + + + + + + id="mask153"> + xlink:href="" + id="image153" /> + id="clipPath154"> + id="path154" /> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + Image Builder - + transform="matrix(1.3333333,0,0,1.3333333,-182.34269,-240.36082)" + clip-path="url(#clipPath13)" /> Patch Generator + dx="0 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999" + y="0">Stage 1: Patch Generation Patch Selector - - - Issue - Information + dx="0 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999 0.061999999" + y="0">Stage 2: Patch Selection + + - - Code Patch - - + dx="0 0.037450001 0.037450001 0.037450001 0.037450001 0.037450001 0.037450001 0.037450001" + y="0">Tool Box Test Patch + dx="0 0.0089999996 0.0089999996 0.0089999996 0.0089999996 0.0089999996 0.0089999996 0.0089999996 0.0089999996 0.0089999996 0.0089999996 0.0089999996 0.0089999996" + y="0">Function Call + Function Call + id="path24" + d="M 168.84,361.32 H 165 v 11.04 h -7.56 v -11.04 h -3.84 l 7.56,-7.56 7.68,7.56" + style="fill:#91ace0;fill-opacity:1;fill-rule:evenodd;stroke:none" + transform="matrix(1.3333333,0,0,1.3333333,-182.34269,-240.36082)" + clip-path="url(#clipPath25)" /> + Config Env + + Container + + Bash Tool Validation - - - - - Parallel Generation - - - - Patches - - - - Patches - - - Tests - - - - - - - - Chosen - Patch - - - - - LLM - LLM - - - - Tool Box - - Function Calling - - Function Calling - - Config Env - - - - diff --git a/astropy/.../core.py - b/astropy/.../core.py - ...... - - Selection - - - - Container - - - - Bash Tool - - Editor + transform="matrix(1.3333333,0,0,1.3333333,-182.34269,-240.36082)" + clip-path="url(#clipPath37)" /> Searcher + transform="matrix(1.3333333,0,0,1.3333333,-182.34269,-240.36082)" + clip-path="url(#clipPath40)" /> Submit - ter + + Executor + mask="url(#mask45)" + id="image46" + transform="matrix(31.333333,0,0,31.333333,347.33864,271.85385)" + clip-path="url(#clipPath46)" /> + + + + + + + + Code Repository + dx="0 0.037450001 0.037450001 0.037450001 0.037450001 0.037450001 0.037450001 0.037450001 0.037450001" + y="0">Code Repo + /testbed/ + astropy/ + __init__.py + tests/ + examples/ + setup.py + ... + + + Issue + <Problem Statement> + Modeling's + `separability_matrix` + does not compute ... + + + Test + Generator + + Code + Generator + + + Test Patch + git diff ... + + + + Code Patch + git diff ... + + + + Code Patch + es + git diff ... + + Write/Improve + Test Patch + + Write/Improve + Code Patch + + Adversarial Iterative Process + + + + + + + Test Patch + es + git diff ... + + + Selector + + + - - - - diff --git + a/astropy/modeling/separable.py + b/astropy/modeling/separable.py + old mode 100644 + new mode 100755 + ... + + + Chosen Code + Patch + + + + + + + + Run in + the + Container + Evaluation + and + Selection + +