Contrastive Code Representation Learning
Paras Jain, Ajay Jain, Tianjun Zhang, Pieter Abbeel, Joseph E. Gonzalez, Ion Stoica
TL;DR
This work tackles the fragility of reconstruction-based code representations by introducing ContraCode, a contrastive pretraining framework that uses compiler-based, semantics-preserving transformations to learn functional code representations. By forming positive pairs from variants of the same program and negatives from others, ContraCode learns invariances to surface-level code edits and enhances robustness across clone detection, type inference, and extreme code summarization. The approach yields significant improvements over MLM baselines and demonstrates robustness to adversarial edits, including a new zero-shot JavaScript clone-detection dataset. The results underscore the value of function-focused, data-augmentation-driven self-supervision for scalable, language-agnostic code understanding.
Abstract
Recent work learns contextual representations of source code by reconstructing tokens from their context. For downstream semantic understanding tasks like summarizing code in English, these representations should ideally capture program functionality. However, we show that the popular reconstruction-based BERT model is sensitive to source code edits, even when the edits preserve semantics. We propose ContraCode: a contrastive pre-training task that learns code functionality, not form. ContraCode pre-trains a neural network to identify functionally similar variants of a program among many non-equivalent distractors. We scalably generate these variants using an automated source-to-source compiler as a form of data augmentation. Contrastive pre-training improves JavaScript summarization and TypeScript type inference accuracy by 2% to 13%. We also propose a new zero-shot JavaScript code clone detection dataset, showing that ContraCode is both more robust and semantically meaningful. On it, we outperform RoBERTa by 39% AUROC in an adversarial setting and up to 5% on natural code.
