Score: 2

Bringing Structure to Naturalness: On the Naturalness of ASTs

Published: April 11, 2025 | arXiv ID: 2504.08234v1

By: Profir-Petru Pârţachi, Mahito Sugiyama

Potential Business Impact:

Finds bugs in computer code automatically.

Business Areas:
Natural Language Processing Artificial Intelligence, Data and Analytics, Software

Source code comes in different shapes and forms. Previous research has already shown code to be more predictable than natural language as well as highlighted its statistical predictability at the token level: source code can be natural. More recently, the structure of code -- control flow, syntax graphs, abstract syntax trees etc. -- has been successfully used to improve the state-of-the-art on numerous tasks: code suggestion, code summarisation, method naming etc. This body of work implicitly assumes that structured representations of code are similarly statistically predictable, i.e. that a structured view of code is also natural. We consider that this view should be made explicit and propose directly studying the Structured Naturalness Hypothesis. Beyond just naming existing research that assumes this hypothesis and formulating it, we also provide evidence in the case of trees: TreeLSTM models over ASTs for some languages, such as Ruby, are competitive with $n$-gram models while handling the syntax token issue highlighted by previous research 'for free'. For other languages, such as Java or Python, we find tree models to perform worse, suggesting that downstream task improvement is uncorrelated to the language modelling task. Further, we show how such naturalness signals can be employed for near state-of-the-art results on just-in-time defect prediction while forgoing manual feature engineering work.

Repos / Data Links

Page Count
18 pages

Category
Computer Science:
Software Engineering