CoTran: An LLM-based Code Translator using Reinforcement Learning with Feedback from Compiler and Symbolic Execution
Prithwish Jana, Piyush Jha, Haoyang Ju, Gautham Kishore, Aryan Mahajan, Vijay Ganesh
TL;DR
CoTran presents an LLM-based method for whole-program translation between Java and Python, addressing limitations of function-level approaches by integrating fine-grained compiler feedback and symbolic-execution-based functional testing into a reinforcement learning loop. The system trains two back-to-back LLMs (S→T and T→S) with RL+SFT, using a novel kw-Tok tokenizer and LoRA for efficiency, and is evaluated on AVATAR-TC, a large Java–Python dataset with human-written test cases. The results show substantial gains in compilation and functional-equivalence accuracy over 14 competitive tools, with particularly strong improvements when CF and SF are combined, and demonstrate easier debugging via improved first-error positions. The work provides a scalable framework for robust code translation and suggests future extensions to more language pairs and legacy-modernization tasks.
Abstract
In this paper, we present an LLM-based code translation method and an associated tool called CoTran, that translates whole-programs from one high-level programming language to another. Existing LLM-based code translation methods lack training to ensure that the translated code reliably compiles or bears substantial functional equivalence to the input code. In our work, we fine-tune an LLM using reinforcement learning, incorporating compiler feedback, and symbolic execution (symexec)-based testing feedback to assess functional equivalence between the input and output programs. The idea is to guide an LLM during fine-tuning, via compiler and symexec-based testing feedback, by letting it know how far it is from producing perfect translations. We conduct extensive experiments comparing CoTran with 14 other code translation tools, including human-written transpilers, LLM-based translation tools, and ChatGPT. Using a benchmark of over \num{57000} code pairs in Java and Python, we demonstrate that CoTran outperforms the other tools on relevant metrics such as compilation accuracy (CompAcc) and functional equivalence accuracy (FEqAcc). For example, in Python-to-Java translation, CoTran achieves 48.68% FEqAcc and 76.98% CompAcc, whereas the nearest competing tool (PLBART-base) gets 38.26% and 75.77% respectively. Additionally, CoTran, built on top of CodeT5, improves FEqAcc by +14.89% and CompAcc by +8.14% for Python-to-Java (resp., +12.94% and +4.30% for Java-to-Python).
