LSTM-Based with Deterministic Negative Sampling for API Suggestion.

Jinpei Yan,Yong Qi,Qifan Rao,Hui He,Saiyu Qi
DOI: https://doi.org/10.1142/s0218194019500347
IF: 1.007
2019-01-01
International Journal of Software Engineering and Knowledge Engineering
Abstract:Modern programming relies on a large number of fundamental APIs, but programmers often take great effort to remember names and the usage of APIs when coding, and repeatedly search the related API documents or Q&A websites (e.g. Stack Overflow). To improve the programming efficiency, we present a Java API suggestion model called APIHelper which learns API sequence pattern via the Long Short-Term Memory (LSTM) network, then provides API suggestion based on the program context. Comparing with statistical methods (e.g. Hidden Markov Model (HMM), N-gram), which require establishing one specific model for each class, we propose Deterministic Negative Sampling (DNS) to make API suggestion for a large number of Java classes by one single end-to-end LSTM. To verify this approach, we make API suggestion for 50,000 Java classes and evaluate it with accuracy and top-K accuracy. The results show that APIHelper outperforms other research works both on accuracy and computation efficiency.
What problem does this paper attempt to address?