NS3: Neuro-symbolic Semantic Code Search

Dec 1, 2022·
Shushan Arakelyan
Anna Hakhverdyan
Anna Hakhverdyan
,
Miltiadis Allamanis
,
Luis Garcia
,
Christophe Hauser
,
Xiang Ren
· 0 min read
Abstract
Semantic code search is the task of retrieving a code snippet given a textual description of its functionality. Recent work has been focused on using similarity metrics between neural embeddings of text and code. However, current language models are known to struggle with longer, compositional sentences, and multi-step reasoning. To overcome this limitation, we propose supplementing the query sentence with a layout of its semantic structure. The semantic layout is used to break down the final reasoning decision into a series of lower-level decisions. We use a Neural Module Network architecture to implement this idea. We compare our model - NS3 (Neuro-Symbolic Semantic Search)-to a number of baselines, including state-of-the-art semantic code retrieval methods, such as CodeBERT, CuBERT and GraphCodeBERT, and evaluate on two datasets-Code Search Net (CSN) and Code Search and Question Answering (CoSQA). On these datasets, we demonstrate that our approach results in higher performance. We also perform additional studies to show the effectiveness of our modular design when handling compositional queries.
Type
Publication
In Advances in Neural Information Processing Systems 35
Anna Hakhverdyan
Authors
MSc in Computing Science
I am interested in developing agents that learn continually in complex environments - like the world we live in.