TransCoder: Towards Unified Transferable Code Representation Learning Inspired by Human Skills
Qiushi Sun, Nuo Chen, Jianing Wang, Xiang Li, Ming Gao
TL;DR
TransCoder introduces a unified transferable framework for code representation learning that captures cross-task and cross-language knowledge through a tunable universal knowledge prefix. The method operates in two stages: source task training to absorb universal knowledge via continual learning, and target task specification to apply the learned prefix to new CodePTMs. Empirical results on CodeXGLUE show consistent improvements across code generation and understanding tasks, with pronounced gains in low-resource languages and data-scarce tasks, and ablation analyses confirm the effectiveness of the universal knowledge prefix. This approach reduces data imbalance effects and enables mutual reinforcement among tasks and languages, offering practical benefits for real-world code intelligence under limited data scenarios.
Abstract
Code pre-trained models (CodePTMs) have recently demonstrated a solid capacity to process various software intelligence tasks, e.g., code clone detection, code translation, and code summarization. The current mainstream method that deploys these models to downstream tasks is to fine-tune them on individual tasks, which is generally costly and needs sufficient data for large models. To tackle the issue, in this paper, we present TransCoder, a unified Transferable fine-tuning strategy for Code representation learning. Inspired by human inherent skills of knowledge generalization, TransCoder drives the model to learn better code-related meta-knowledge like human programmers. Specifically, we employ a tunable prefix encoder as the meta-learner to capture cross-task and cross-language transferable knowledge, respectively. Besides, tasks with minor training sample sizes and languages with small corpus can be remarkably benefited from our approach. Extensive experiments conducted on benchmark datasets clearly demonstrate that our method can lead to superior performance on various code-related tasks and encourage mutual reinforcement. We also show that TransCoder is applicable in low-resource scenarios. Our codes are available at https://github.com/QiushiSun/TransCoder.
