Unifying the Perspectives of NLP and Software Engineering: A Survey on Language Models for Code

Abstract

In this work we systematically review the recent advancements in software engineering with language models, covering 70+ models, 40+ evaluation tasks, 180+ datasets, and 900 related works. Unlike previous works, we integrate software engineering (SE) with natural language processing (NLP) by discussing the perspectives of both sides: SE applies language models for development automation, while NLP adopts SE tasks for language model evaluation. We break down code processing models into general language models represented by the GPT family and specialized models that are specifically pretrained on code, often with tailored objectives. We discuss the relations and differences between these models, and highlight the historical transition of code modeling from statistical models and RNNs to pretrained Transformers and LLMs, which is exactly the same course that had been taken by NLP. We also go beyond programming and review LLMs' application in other software engineering activities including requirement engineering, testing, deployment, and operations in an endeavor to provide a global view of NLP in SE, and identify key challenges and potential future directions in this domain.

Cite

Text

Zhang et al. "Unifying the Perspectives of NLP and Software Engineering: A Survey on Language Models for Code." Transactions on Machine Learning Research, 2024.

Markdown

[Zhang et al. "Unifying the Perspectives of NLP and Software Engineering: A Survey on Language Models for Code." Transactions on Machine Learning Research, 2024.](https://mlanthology.org/tmlr/2024/zhang2024tmlr-unifying/)

BibTeX

@article{zhang2024tmlr-unifying,
  title     = {{Unifying the Perspectives of NLP and Software Engineering: A Survey on Language Models for Code}},
  author    = {Zhang, Ziyin and Chen, Chaoyu and Liu, Bingchang and Liao, Cong and Gong, Zi and Yu, Hang and Li, Jianguo and Wang, Rui},
  journal   = {Transactions on Machine Learning Research},
  year      = {2024},
  url       = {https://mlanthology.org/tmlr/2024/zhang2024tmlr-unifying/}
}