Functional paleontology: system evolution as the user sees it

  • Authors:
  • Annie I. Antón;Colin Potts

  • Affiliations:
  • College of Engineering, North Carolina State University, 1010 Main Campus Drive, Raleigh, NC;College of Computing, Georgia Institute of Technology, 801 Atlantic Drive, Atlanta, GA

  • Venue:
  • ICSE '01 Proceedings of the 23rd International Conference on Software Engineering
  • Year:
  • 2001

Quantified Score

Hi-index 0.00

Visualization

Abstract

It has long been accepted that requirements analysis should precede architectural design and implementation, but in software evolution and reverse engineering this concern with black-box analysis of function has necessarily been de-emphasized in favor of code-based analysis and designer-oriented interpretation. In this paper, we redress this balance by describing “functional paleontology”, an approach to analyzing the evolution of user-visible features or services independent of architecture and design intent. We classify the benefits and burdens of interpersonal communication services into core and peripheral categories and investigate the telephony services available to domestic subscribers over a fifty-year period. We report that services were introduced in discrete bursts, each of which emphasized different benefits and burdens. We discuss the general patterns of functional evolution that this “fossil record” illustrates and conclude by discussing their implications for forward engineering of software products.