# When Deep Learning Met Code Search

**Authors:** Jose Cambronero, Hongyu Li, Seohyun Kim, Koushik Sen, Satish, Chandra

arXiv: 1905.03813 · 2019-10-16

## TL;DR

This paper systematically evaluates different deep learning approaches for code search using natural language, comparing supervised and unsupervised methods, and introduces a minimal supervision technique that enhances performance.

## Contribution

It is the first study to systematically compare supervision choices and network complexities in deep learning-based code search, providing insights into effective design strategies.

## Key findings

- Supervision can improve code search performance but with diminishing returns.
- Simple network architectures can outperform more complex sequence-based models.
- Supervision using query-appropriate corpora is more effective than using docstrings.

## Abstract

There have been multiple recent proposals on using deep neural networks for code search using natural language. Common across these proposals is the idea of $\mathit{embedding}$ code and natural language queries, into real vectors and then using vector distance to approximate semantic correlation between code and the query. Multiple approaches exist for learning these embeddings, including $\mathit{unsupervised}$ techniques, which rely only on a corpus of code examples, and $\mathit{supervised}$ techniques, which use an $\mathit{aligned}$ corpus of paired code and natural language descriptions. The goal of this supervision is to produce embeddings that are more similar for a query and the corresponding desired code snippet. Clearly, there are choices in whether to use supervised techniques at all, and if one does, what sort of network and training to use for supervision. This paper is the first to evaluate these choices systematically. To this end, we assembled implementations of state-of-the-art techniques to run on a common platform, training and evaluation corpora. To explore the design space in network complexity, we also introduced a new design point that is a $\mathit{minimal}$ supervision extension to an existing unsupervised technique. Our evaluation shows that: 1. adding supervision to an existing unsupervised technique can improve performance, though not necessarily by much; 2. simple networks for supervision can be more effective that more sophisticated sequence-based networks for code search; 3. while it is common to use docstrings to carry out supervision, there is a sizeable gap between the effectiveness of docstrings and a more query-appropriate supervision corpus.   The evaluation dataset is now available at arXiv:1908.09804

## Full text

_Full body text omitted from this summary view._ Fetch the complete paper as Markdown: https://tomesphere.com/paper/1905.03813/full.md

## Figures

14 figures with captions in the complete paper: https://tomesphere.com/paper/1905.03813/full.md

## References

38 references — full list in the complete paper: https://tomesphere.com/paper/1905.03813/full.md

---
Source: https://tomesphere.com/paper/1905.03813