Title :
Software reflexion models: bridging the gap between design and implementation
Author :
Murphy, Gail C. ; Notkin, David ; Sullivan, Kevin J.
Author_Institution :
Dept. of Comput. Sci., British Columbia Univ., Vancouver, BC, Canada
fDate :
4/1/2001 12:00:00 AM
Abstract :
The artifacts constituting a software system often drift apart over time. We have developed the software reflexion model technique to help engineers perform various software engineering tasks by exploiting, rather than removing, the drift between design and implementation. More specifically, the technique helps an engineer compare artifacts by summarizing where one artifact (such as a design) is consistent with and inconsistent with another artifact (such as source). The technique can be applied to help a software engineer evolve a structural mental model of a system to the point that it is “good enough” to be used for reasoning about a task at hand. The software reflexion model technique has been applied to support a variety of tasks, including design conformance, change assessment, and an experimental reengineering of the million-lines-of-code Microsoft Excel product. We provide a formal characterization of the reflexion model technique, discuss practical aspects of the approach, relate experiences of applying the approach and tools, and place the technique into the context of related work
Keywords :
formal specification; reverse engineering; software maintenance; systems re-engineering; Microsoft Excel product; change assessment; design conformance; experimental reengineering; formal characterization; model differencing; program representation; program understanding; reverse engineering; software engineering tasks; software reflexion models; software structure; software system; structural mental model; Cognitive science; Computer Society; Context modeling; Design engineering; Maintenance engineering; Reverse engineering; Software engineering; Software performance; Software systems; Spreadsheet programs;
Journal_Title :
Software Engineering, IEEE Transactions on