code2vec: Learning Distributed Representations of Code

Uri Alon,Meital Zilberstein,Omer Levy,Eran Yahav
DOI: https://doi.org/10.48550/arXiv.1803.09473
2018-10-30
Abstract:We present a neural model for representing snippets of code as continuous distributed vectors ("code embeddings"). The main idea is to represent a code snippet as a single fixed-length $\textit{code vector}$, which can be used to predict semantic properties of the snippet. This is performed by decomposing code to a collection of paths in its abstract syntax tree, and learning the atomic representation of each path $\textit{simultaneously}$ with learning how to aggregate a set of them. We demonstrate the effectiveness of our approach by using it to predict a method's name from the vector representation of its body. We evaluate our approach by training a model on a dataset of 14M methods. We show that code vectors trained on this dataset can predict method names from files that were completely unobserved during training. Furthermore, we show that our model learns useful method name vectors that capture semantic similarities, combinations, and analogies. Comparing previous techniques over the same data set, our approach obtains a relative improvement of over 75%, being the first to successfully predict method names based on a large, cross-project, corpus. Our trained model, visualizations and vector similarities are available as an interactive online demo at <a class="link-external link-http" href="http://code2vec.org" rel="external noopener nofollow">this http URL</a>. The code, data, and trained models are available at <a class="link-external link-https" href="https://github.com/tech-srl/code2vec" rel="external noopener nofollow">this https URL</a>.
Machine Learning,Artificial Intelligence,Programming Languages
What problem does this paper attempt to address?