Engineering Trustworthy Self-Adaptive Software with Dynamic Assurance Cases
Radu Calinescu,Danny Weyns,Simos Gerasimou,Muhammad Usman Iftikhar,Ibrahim Habli,Tim Kelly
DOI: https://doi.org/10.1109/tse.2017.2738640
IF: 7.4
2018-11-01
IEEE Transactions on Software Engineering
Abstract:Building on concepts drawn from control theory, self-adaptive software handles environmental and internal uncertainties by dynamically adjusting its architecture and parameters in response to events such as workload changes and component failures. Self-adaptive software is increasingly expected to meet strict functional and non-functional requirements in applications from areas as diverse as manufacturing, healthcare and finance. To address this need, we introduce a methodology for the systematic ENgineering of TRUstworthy Self-adaptive sofTware (ENTRUST). ENTRUST uses a combination of (1)design-time and runtime modelling and verification, and (2)industry-adopted assurance processes to develop trustworthy self-adaptive software and assurance cases arguing the suitability of the software for its intended application. To evaluate the effectiveness of our methodology, we present a tool-supported instance of ENTRUST and its use to develop proof-of-concept self-adaptive software for embedded and service-based systems from the oceanic monitoring and e-finance domains, respectively. The experimental results show that ENTRUST can be used to engineer self-adaptive software systems in different application domains and to generate dynamic assurance cases for these systems.
engineering, electrical & electronic,computer science, software engineering