Issue No. 10 - October (2003 vol. 29)
Katerina Goseva-Popstojanova , IEEE
Ahmed Hassan , IEEE
Walid Abdelmoez , IEEE
Diaa Eldin M. Nassar , IEEE
Hany Ammar , IEEE
Ali Mili , IEEE
<p><b>Abstract</b>—Risk assessment is an essential part in managing software development. Performing risk assessment during the early development phases enhances resource allocation decisions. In order to improve the software development process and the quality of software products, we need to be able to build risk analysis models based on data that can be collected early in the development process. These models will help identify the high-risk components and connectors of the product architecture, so that remedial actions may be taken in order to control and optimize the development process and improve the quality of the product. In this paper, we present a risk assessment methodology which can be used in the early phases of the software life cycle. We use the Unified Modeling Language (UML) and commercial modeling environment Rational Rose Real Time (RoseRT) to obtain UML model statistics. First, for each component and connector in software architecture, a dynamic heuristic risk factor is obtained and severity is assessed based on hazard analysis. Then, a Markov model is constructed to obtain scenarios risk factors. The risk factors of use cases and the overall system risk factor are estimated using the scenarios risk factors. Within our methodology, we also identify critical components and connectors that would require careful analysis, design, implementation, and more testing effort. The risk assessment methodology is applied on a pacemaker case study.</p>
Risk assessment, UML specification, software architecture, dynamic complexity, dynamic coupling, severity of failure, Markov model.
A. Hassan et al., "Architectural-Level Risk Analysis Using UML," in IEEE Transactions on Software Engineering, vol. 29, no. , pp. 946-960, 2003.