CIAO - Code In Architecture Out - Automated Software Architecture Documentation with Large Language Models
This addresses the challenge of incomplete software architecture documentation for developers, offering an automated solution that is incremental by applying existing LLM techniques in a structured workflow.
The paper tackles the problem of generating system-level software architecture documentation from code using Large Language Models, presenting CIAO, a structured process that produces documentation following established standards. Evaluation with 22 developers showed the documentation is perceived as valuable and accurate, with generation taking only minutes and being cost-effective.
Software architecture documentation is essential for system comprehension, yet it is often unavailable or incomplete. While recent LLM-based techniques can generate documentation from code, they typically address local artifacts rather than producing coherent, system-level architectural descriptions. This paper presents a structured process for automatically generating system-level architectural documentation directly from GitHub repositories using Large Language Models. The process, called CIAO (Code In Architecture Out), defines an LLM-based workflow that takes a repository as input and produces system-level architectural documentation following a template derived from ISO/IEC/IEEE 42010, SEI Views \& Beyond, and the C4 model. The resulting documentation can be directly added to the target repository. We evaluated the process through a study with 22 developers, each reviewing the documentation generated for a repository they had contributed to. The evaluation shows that developers generally perceive the produced documentation as valuable, comprehensible, and broadly accurate with respect to the source code, while also highlighting limitations in diagram quality, high-level context modeling, and deployment views. We also assessed the operational cost of the process, finding that generating a complete architectural document requires only a few minutes and is inexpensive to run. Overall, the results indicate that a structured, standards-oriented approach can effectively guide LLMs in producing system-level architectural documentation that is both usable and cost-effective.