Software Architecture Evolution through Evolvability Analysis
Publication Type:
Journal article
Venue:
The Journal of Systems & Software
Publisher:
Elsevier, http://dx.doi.org/10.1016/j.jss.2012.05.085
DOI:
http://dx.doi.org/10.1016/j.jss.2012.05.085
Abstract
Software evolvability is a multifaceted quality attribute that describes a software system’s ability to easily accommodate future changes. It is a fundamental characteristic for the efficient implementation of strategic decisions, and the increasing economic value of software. For long life systems, there is a need to address evolvability explicitly during the entire software lifecycle in order to prolong the productive lifetime of software systems. However, designing and evolving software architectures is a challenging task. To improve the ability to understand and systematically analyze the evolution of software system architectures, in this paper, we describe software architecture evolution characterization, and propose an architecture evolvability analysis process that provides replicable techniques for performing activities to aim at understanding and supporting software architecture evolution. The activities are embedded in: (i) the application of a software evolvability model; (ii) a structured qualitative method for analyzing evolvability at the architectural level; and (iii) a quantitative evolvability analysis method with explicit and quantitative treatment of stakeholders’ evolvability concerns and the impact of potential architectural solutions on evolvability. The qualitative and quantitative assessments manifested in the evolvability analysis process have been applied in two large-scale industrial software systems at ABB and Ericsson, with experiences and reflections described.
Bibtex
@article{Pei-Breivold2584,
author = {Hongyu Pei-Breivold and Ivica Crnkovic and Magnus Larsson},
title = {Software Architecture Evolution through Evolvability Analysis},
volume = {85},
pages = {2574--2592},
month = {July},
year = {2012},
journal = {The Journal of Systems {\&} Software},
publisher = {Elsevier, http://dx.doi.org/10.1016/j.jss.2012.05.085},
url = {http://www.es.mdu.se/publications/2584-}
}