LARCH: Large Language Model-based Automatic Readme Creation with Heuristics

Yuta Koreeda,Terufumi Morishita,Osamu Imaichi,Yasuhiro Sogawa
DOI: https://doi.org/10.1145/3583780.3614744
2023-08-22
Abstract:Writing a readme is a crucial aspect of software development as it plays a vital role in managing and reusing program code. Though it is a pain point for many developers, automatically creating one remains a challenge even with the recent advancements in large language models (LLMs), because it requires generating an abstract description from thousands of lines of code. In this demo paper, we show that LLMs are capable of generating a coherent and factually correct readmes if we can identify a code fragment that is representative of the repository. Building upon this finding, we developed LARCH (LLM-based Automatic Readme Creation with Heuristics) which leverages representative code identification with heuristics and weak supervision. Through human and automated evaluations, we illustrate that LARCH can generate coherent and factually correct readmes in the majority of cases, outperforming a baseline that does not rely on representative code identification. We have made LARCH open-source and provided a cross-platform Visual Studio Code interface and command-line interface, accessible at <a class="link-external link-https" href="https://github.com/hitachi-nlp/larch" rel="external noopener nofollow">this https URL</a>. A demo video showcasing LARCH's capabilities is available at <a class="link-external link-https" href="https://youtu.be/ZUKkh5ED-O4" rel="external noopener nofollow">this https URL</a>.
Computation and Language,Software Engineering
What problem does this paper attempt to address?