Thinking Before Running! Efficient Code Generation with Thorough Exploration and Optimal Refinement
Xiaoqing Zhang, Yuhan Liu, Flood Sung, Xiuying Chen, Shuo Shang, Rui Yan
TL;DR
ThinkCoder tackles the latency of test-time code generation by pairing a thorough exploration phase with an optimal refinement phase, guided by a non-LLM CodeVerifier and a dynamic Testing Pool. The framework is augmented with Reinforced Self-Training (ReST), which learns from successful exploration trajectories to fine-tune the LLM offline, reducing online compute. Empirical results show ThinkCoder achieving state-of-the-art or competitive Pass@1 on MBPP and HumanEval with substantially lower computational overhead, and ReST enabling efficient performance for smaller LLMs like LLaMA2-7B. The approach offers a scalable path toward high-quality, cost-efficient code generation, with demonstrated gains across diverse benchmarks and model scales, and points to future work on on-policy training to sustain exploration diversity.
Abstract
Code generation is crucial in software engineering for automating the coding process efficiently. While test-time computation methods show promise, they suffer from high latency due to multiple computation rounds. To overcome this, we introduce \textbf{ThinkCoder}, a framework that combines thorough exploration with optimal refinement. The exploration phase diversifies the solution space by searching for potential solutions, followed by a refinement phase that enhances precision. This approach allows us to select the best solution through careful consideration before taking action, avoiding excessive trial and error. To further minimize test-time computation overhead, we introduce preference-driven optimization with Reinforced Self-Training (ReST), which uses exploration trajectories from ThinkCoder to guide LLM's evolution. This approach enhances LLM's exploration efficiency via preference learning, cutting costs while maintaining accuracy. ThinkCoder boosts the performance with a single LLM, excelling on benchmarks like HumanEval and MBPP. Compared to SOTA models, it improves Pass@1 by 3.0\% over MapCoder with just 6.4\% of the computation cost. Against AgentCoder, ThinkCoder achieves a 0.5\% higher Pass@1 after 2 rounds, outperforming AgentCoder's 5 rounds. Additionally, ReST with success trajectories enhances efficiency, allowing models like LLaMA2-7B to achieve competitive results using only 20\% of the computational resources. These results highlight the framework's effectiveness and scalability.
