# Chapter 2 Formal Reliability Analysis of Embedded Computing Systems

#### Osman Hasan

National University of Sciences and Technology, Pakistan

#### Sofiène Tahar

Concordia University, Canada

#### **ABSTRACT**

The accurate reliability assessment of embedded systems has become a concern of overwhelming importance with their increasingly ubiquitous usage in safety-critical domains like transportation, medicine, and nuclear power plants. Traditional reliability analysis approaches of testing and simulation cannot guarantee accurate result and thus there is a growing trend towards developing precise mathematical models of embedded systems and to use formal verification methods to assess their reliability. This chapter is mainly focused towards this emerging trend as it presents a formal approach for the reliability assessment of embedded computing systems using a higher-order-logic theorem prover (HOL). Besides providing the formal probability theory based fundamentals of this recently proposed technique, the chapter outlines a generic reliability analysis methodology for embedded systems as well. For illustration purposes, two case studies have been considered, i.e., analyzing the reparability conditions for a reconfigurable memory array in the presence of stuck-at and coupling faults and assessing the reliability of combinational logic based digital circuits.

#### INTRODUCTION

Reliability analysis involves the usage of probabilistic techniques for the prediction of reliability related parameters, such as a system's resistance to failure and its ability to perform a required function under some given conditions. This information is

in turn utilized to design more reliable and secure systems. The reliability analysis of embedded computing systems has been conducted since their early introduction. However, the ability to efficiently analyze the reliability of embedded systems has become very challenging nowadays because of their growing sizes and the complex nature of hardware software interaction.

DOI: 10.4018/978-1-4666-3922-5.ch002

Traditionally, simulation has been the most commonly used computer based reliability analysis technique for embedded systems. Most simulation based reliability analysis software provide a programming environment for defining functions that approximate random variables for probability distributions. The environmental behavior and the input patterns of embedded systems are random quantities and are thus modeled by these functions and the system is analyzed using computer simulation techniques, such as the Monte Carlo Method, where the main idea is to approximately answer a query on a probability distribution by analyzing a large number of samples. Statistical quantities, such as expectation and variance, may then be calculated, based on the data collected during the sampling process, using their mathematical relations in a computer. Due to the inherent nature of simulation coupled with the usage of computer arithmetic, the reliability analysis results attained by the simulation approach can never be termed as 100% accurate.

The accuracy of reliability analysis results has become imperative these days because of the extensive usage of embedded systems in safety critical areas. Some examples of safety-critical embedded systems include aircraft flight control systems, surgical robotics and patient monitoring system used in hospitals and instrumentation and control systems found in nuclear power plants. Erroneous reliability analysis in these kinds of areas could have serious consequences, such as loss of human lives.

Formal methods are capable of conducting precise system analysis and thus overcome the above mentioned limitations of simulation (Hall, 2007). The main principle behind formal analysis of a system is to construct a computer based mathematical model of the given system and formally verify, within a computer, that this model meets rigorous specifications of intended behavior. Two of the most commonly used formal verification methods are model checking (Baier, 2008) and higher-order-logic theorem proving (Harrison,

2009). Model checking is an automatic verification approach for systems that can be expressed as a finite-state machine. Higher-order-logic theorem proving, on the other hand, is an interactive verification approach that allows us to mathematically reason about system properties by representing the behavior of a system in higher-order logic.

A number of elegant approaches for the formal analysis of embedded systems can be found in the literature (Balarin, 1996, Ulrich 2006). However, most of this existing formal verification literature is focused towards analyzing the functional verification aspects instead of reliability properties. Recently, both model checking and theorem proving has been extended with probabilistic reasoning support (Baier, 2003, Hurd, 2002) and thus a few formal reliability analysis approaches for embedded systems have been reported (e.g. Hasan, 2009, Hasan, 2011). Probabilistic model checking is automatic but is limited to systems that can only be expressed as probabilistic finite state machines or Markov chains. Another major limitation of using probabilistic model checking to analyze reliability of embedded systems is state space explosion (Baier, 2008) due to the large size of system models and complex hardware software interactions in embedded systems. Similarly, to the best of our knowledge, it has not been possible to use probabilistic model checking to precisely reason about most of the statistical quantities, such as expectation and variance, which are an integral component of every reliability analysis. On the other hand, the higher-order-logic theorem proving based technique tends to overcome the above mentioned limitations of probabilistic model checking. Due to the formal nature of the higher-order-logic models and properties and the inherent soundness of the theorem proving approach, reliability analysis carried out in this way is free from any approximation and precision issues. Similarly, the high expressiveness of higher-order logic allows us to analyze both hardware and software components of an embedded system along with their uncertainties without any

## 13 more pages are available in the full version of this document, which may be purchased using the "Add to Cart" button on the publisher's webpage:

www.igi-global.com/chapter/formal-reliability-analysis-embeddedcomputing/76949

#### Related Content

#### Designing Secure and Privacy-Aware Information Systems

Christos Kalloniatis, Argyri Pattakou, Evangelia Kavakliand Stefanos Gritzalis (2017). *International Journal of Secure Software Engineering (pp. 1-25).* 

www.irma-international.org/article/designing-secure-and-privacy-aware-information-systems/190419

### A Methodology for UICC-Based Security Services in Pervasive Fixed Mobile Convergence Systems

Jaemin Park (2012). Advanced Design Approaches to Emerging Software Systems: Principles, Methodologies and Tools (pp. 173-194).

www.irma-international.org/chapter/methodology-uicc-based-security-services/55440

#### Sampled-Data Control of Large-Scale Fuzzy Interconnected Systems

(2017). Large-Scale Fuzzy Interconnected Control Systems Design and Analysis (pp. 84-126). www.irma-international.org/chapter/sampled-data-control-of-large-scale-fuzzy-interconnected-systems/181989

#### A Comparison and Scenario Analysis of Leading Data Mining Software

John Wang, Xiaohua Hu, Kimberly Hollisterand Dan Zhu (2009). Software Applications: Concepts, Methodologies, Tools, and Applications (pp. 467-485).

www.irma-international.org/chapter/comparison-scenario-analysis-leading-data/29404

#### Exploiting Codified User Task Knowledge to Discover Services at Design-Time

Konstantinos Zachos, Angela Kounkouand Neil A. M. Maiden (2012). *International Journal of Systems and Service-Oriented Engineering (pp. 30-66).* 

 $\underline{www.irma-international.org/article/exploiting-codified-user-task-knowledge-to-discover-services-at-design-time/78917}$