A reverse‐engineering approach to subsystem structure identification

Hausi A. Müller*, Mehmet A. Orgun, Scott R. Tilley, James S. Uhl

*Corresponding author for this work

Research output: Contribution to journalArticlepeer-review

214 Citations (Scopus)

Abstract

Reverse‐engineering is the process of extracting system abstractions and design information out of existing software systems. This process involves the identification of software artefacts in a particular subject system, the exploration of how these artefacts interact with one another, and their aggregation to form more abstract system representations that facilitate program understanding. This paper describes our approach to creating higher‐level abstract representations of a subject system, which involves the identification of related components and dependencies, the construction of layered subsystem structures, and the computation of exact interfaces among subsystems. We show how top‐down decompositions of a subject system can be (re)constructed via bottom‐up subsystem composition. This process involves identifying groups of building blocks (e.g., variables, procedures, modules, and subsystems) using composition operations based on software engineering principles such as low coupling and high cohesion. The result is an architecture of layered subsystem structures. The structures are manipulated and recorded using the Rigi system, which consists of a distributed graph editor and a parsing system with a central repository. The editor provides graph filters and clustering operations to build and explore subsystem hierarchies interactively. The paper concludes with a detailed, step‐by‐step analysis of a 30‐module software system using Rigi.

Original languageEnglish
Pages (from-to)181-204
Number of pages24
JournalJournal of Software Maintenance: Research and Practice
Volume5
Issue number4
DOIs
Publication statusPublished - 1993

Keywords

  • Change analysis
  • Exact interfaces
  • Program understanding
  • Resource‐flow graphs
  • Reverse‐engineering
  • Re‐engineering
  • Software engineering principles
  • Software maintenance
  • Subsystem composition
  • Subsystem hierarchies

Fingerprint

Dive into the research topics of 'A reverse‐engineering approach to subsystem structure identification'. Together they form a unique fingerprint.

Cite this