pith. sign in

arxiv: 1810.08305 · v2 · pith:L4TYTKIXnew · submitted 2018-10-18 · 💻 cs.LG · stat.ML

Open Vocabulary Learning on Source Code with a Graph-Structured Cache

classification 💻 cs.LG stat.ML
keywords codecachegraph-structuredlearningmodelsvocabularyopensource
0
0 comments X
read the original abstract

Machine learning models that take computer program source code as input typically use Natural Language Processing (NLP) techniques. However, a major challenge is that code is written using an open, rapidly changing vocabulary due to, e.g., the coinage of new variable and method names. Reasoning over such a vocabulary is not something for which most NLP methods are designed. We introduce a Graph-Structured Cache to address this problem; this cache contains a node for each new word the model encounters with edges connecting each word to its occurrences in the code. We find that combining this graph-structured cache strategy with recent Graph-Neural-Network-based models for supervised learning on code improves the models' performance on a code completion task and a variable naming task --- with over $100\%$ relative improvement on the latter --- at the cost of a moderate increase in computation time.

This paper has not been read by Pith yet.

discussion (0)

Sign in with ORCID, Apple, or X to comment. Anyone can read and Pith papers without signing in.