# RELIABILITY-ENERGY-PERFORMANCE OPTIMISATION IN COMBINATIONAL CIRCUITS IN PRESENCE OF SOFT ERRORS 

Mohamed Abulgasem Abufalgha

A Thesis Submitted for the Degree of
Doctor of Philosophy at Newcastle University

School of Engineering
Faculty of Science, Agriculture and Engineering
March 2019

Mohamed Abulgasem Abufalgha: Reliability-Energy-Performance Optimisation in Combinational Circuits in Presence of Soft Errors ©2019

## DECLARATION

I hereby declare that this thesis is my own work and effort and that it has not been submitted anywhere for any award. Where other sources of information have been used, they have been acknowledged.

Newcastle upon Tyne, March 2019

Mohamed Abulgasem
Abufalgha

## CERTIFICATE OF APPROVAL

I confirm that, to the best of my knowledge, this thesis is from the student's own work and effort, and all other sources of information used have been acknowledged. This thesis has been submitted with my approval.

Dr. Alex Bystrov
Prof. Alex Yakovlev

To my wonderful mother whose affection and love make me to get such success

To the soul of my father who was and will always be my role model

To my beloved wife who supported me to reach this stage
To my lovely kids Abulgasem, Salma, Zakaria, Sadeem and Yahia

- Mohamed

I would like to express my deep gratitude to my supervisors Dr. Alex Bystrov and Prof. Alex Yakovlev for their support and guidance through my PhD journey. They have always been a source of motivation and my inspirational model as a researcher.

I am grateful to the Ministry of Education and Scientific Research in Libya for funding my PhD study and Engineering faculty in Misurata university for offering this place to finish my study abroad.

I would like also to express my gratefulness and appreciation to my colleagues and friends in school of Engineering, especially in MicroSystems Research Group. We have discussed many topics over the years, and they were very helpful and best supporters. Special Thanks to my colleague Konstantinos Goutsos and my friend Dr. Fathi Abugchem for heir help and support. I hope they continue to be successful with their research and future careers. Also, I would like to offer my special regards to all the staff of the school of Engineering in Newcastle university.

Finally, I would like to acknowledge with gratitude, the support and love of my mother, my lovely family and my brothers and sisters.

The reliability metric has a direct relationship to the amount of value produced by a circuit, similar to the performance metric. With advances in CMOS technology, digital circuits become increasingly more susceptible to soft errors. Therefore, it is imperative to be able to assess and improve the level of reliability of these circuits. A framework for evaluating and improving the reliability of combinational circuits is proposed, and an interplay between the metrics of reliability, energy and performance is explored.

Reliability evaluation is divided into two levels of characterisation: stochastic fault model (SFM) of the component library and a design-specific critical vector model (CVM). The SFM captures the properties of components with regard to the interference which causes error. The CVM is derived from a limited number of simulation runs on the specific design at the design time and producing the reliability metric. The idea is to move the high-complexity problem of the stochastic characterisation of components to the generic part of the design process, and to do it just once for a large number of specific designs. The method is demonstrated on a range of circuits with various structures.

A three-way trade-off between reliability, energy, and performance has been discovered; this trade-off facilitates optimisations of circuits and their operating conditions.

A technique for improving the reliability of a circuit is proposed, based on adding a slow stage at the primary output. Slow stages have the ability to absorb narrow glitches from prior stages, thus reducing the error probability. Such stages, or filters, suppress most of the glitches generated in prior stages and prevent them from arriving at the primary output of the circuit. Two filter solutions have been developed and analysed. The results show a dramatic improvement in reliability at the expense of minor performance and energy penalties.

To alleviate the problem of the time-consuming analogue simulations involved in the proposed method, a simplification technique is proposed. This technique exploits the equivalence between the properties of the gates within a path and the equivalence between paths. On the basis of these equivalences, it is possible to reduce the number of simulation runs. The effectiveness of the proposed technique is evaluated by applying it to different circuits with
a representative variety of path topologies. The results show a significant decrease in the time taken to estimate reliability at the expense of a minor decrease in the accuracy of estimation. The simplification technique enables the use of the proposed method in applications with complex circuits.

## Journal and magazines publications:

1. Mohamed A. Abufalgha; Alex Bystrovv, Reliability-energy-performance interplay in combinational circuits, (to be submitted), IEEE Transactions on Device and Materials Reliability.

This journal paper extends the material published in the conference paper Design-time reliability evaluation for digital circuits. This extension includes applying the proposed method to evaluate the reliability of large circuits which have been chosen from ISCAS-85 benchmarks. Also, two filter solutions to improve the reliability of combinational circuits have been analysed, and a solution for the problem of time-consuming analogue simulations is introduced and evaluated. This journal paper is written in such a way as to summarise the material that is introduced in this thesis.

## Conference publications:

1. Mohamed A. Abufalgha; Alex Bystrov, Derivation of the reliability metric for digital circuits, 2017 22nd IEEE European Test Symposium (ETS), PP 1-2, May 2017.

The studies underpinning this paper can be found in Chapters 3, 5. In it a new method for evaluating the reliability of a combinational circuit is introduced briefly but without a comprehensive presentation due to the limited space allowed. In this paper, the reliability of a circuit is evaluated and introduced in terms of a trade-off relationship with the energy consumption and performance of the circuit. Also, a method for improving the reliability of the circuit is introduced.
2. Mohamed A. Abufalgha; Alex Bystrov, Design-time reliability evaluation for digital circuits, 2017 IEEE 23rd International Symposium on On-Line Testing and Robust System Design (IOLTS), pp 39-44, July 2017.

The studies underpinning this paper can be found in Chapters 3, 5, as with the previous paper. However, in this paper the proposed methods for evaluating and improving the reliability of combinational circuits are introduced in more detail. Also, the proposed method is applied to a multipath circuit to evaluate its reliability.

## CONTENTS

I Thesis Chapters ..... 1
1 INTRODUCTION ..... 3
1.1 Motivation ..... 3
1.1.1 Reliability of Combinational Circuits ..... 4
1.1.2 Switching from Power-Performance Optimisation to Reliability- Energy-Performance Optimisation. ..... 5
1.2 Thesis Scope and Contributions ..... 6
1.3 Thesis Organization and Key Findings ..... 9
2 BACKGROUND AND PREVIOUS WORKS ..... 11
2.1 Introduction ..... 11
2.2 Background on Radiation Environments ..... 12
2.3 Interaction of Neutrons with Matter ..... 15
2.3.1 Scattering Interaction ..... 15
2.3.2 Absorption Interaction ..... 16
2.4 Ionization ..... 17
2.5 Linear Energy Transfer ..... 18
2.6 Critical Charge ..... 20
2.7 Single Event Effect: Mechanisms and Classifications ..... 21
2.8 Single Event Transient Propagation ..... 23
2.9 Related Work ..... 26
2.9.1 Reliability Evaluation Techniques ..... 27
2.9.2 Soft Error Estimation ..... 28
2.9.3 Reliability Improvement in Combinational Circuits ..... 32
2.10Conclusions ..... 33
3 DERIVATION OF RELIABILITY ..... 35
3.1 Modelling the transient current pulse ..... 35
3.1.1 Bias-dependent Current Model ..... 36
3.2 The Proposed Approach ..... 38
3.3 Uniform Single-Path Circuit ..... 40
3.3.1 Evaluating the Reliability of Chain of inverters Circuit ..... 42
3.3.2 Results ..... 44
3.4 Non-Uniform Path ..... 46
3.4.1 Results ..... 49
3.5 Multipath Circuits ..... 52
3.5.1 Deriving the reliability of the circuit ..... 54
3.5.2 Results ..... 56
3.6 Conclusion ..... 57
4 AUTOMATING THE PROPOSED APPROACH ..... 59
4.1 Simulation Phase ..... 59
4.2 Error Probability Calculation ..... 61
4.3 Benchmark Reliability Estimation ..... 61
4.4 Stopping Criterion ..... 67
4.5 Conclusion ..... 69
5 IMPROVING THE RELIABILITY OF COMBINATIONAL CIRCUITS ..... 71
5.1 Introduction ..... 71
5.2 Circuit Reliability with Active Filter Stage ..... 72
$5 \cdot 3$ Active Filter Stage Evaluation ..... 75
5.3.1 The Performance Change ..... 75
5.3.2 Change in Energy Consumption ..... 76
5.3.3 Area Overhead ..... 76
5.4 Circuit Reliability with Passive Filter Stage ..... 78
5.4.1 Improving the Reliability of c432 Circuit ..... 80
5.4.2 Improving the Reliability of the c1908 Circuit ..... 83
5.5 Conclusions ..... 87
6 SIMPLIFICATION APPROACH USING EQUIVALENT GATES FOR THE EVAL- UATION OF THE RELIABILITY OF LARGE CIRCUITS ..... 89
6.1 Introduction ..... 89
6.2 Approximate Reliability of Different Path topologies ..... 90
6.2.1 At Around Nominal Voltage ..... 90
6.2.2 Including Very Low Voltages ..... 97
6.3 Estimating the Approximate Reliability of Complete Circuits ..... 101
6.3.1 Around Nominal Voltage ..... 103
6.3.2 Including Very-Low Voltage ..... 106
6.4 Evaluation of the Simplification Approach ..... 110
6.5 Conclusions ..... 111
7 CONCLUSIONS AND FUTURE WORK ..... 113
7.1 Summary and Conclusion ..... 113
7.2 Critical Review and Future Work ..... 116
II Thesis Appendices ..... 119
A RELIABILITY AND PROBABILITY OF ERRORS DATA ..... 121
b Deriving the reliability codes ..... 129
B. 1 Finding CVM values of a circuit, Ocean script. ..... 129
B. 2 Calculating the error probability of a circuit, C-language code. ..... 140
C ENERGY CONSUMPTION AND PERFORMANCE ..... 147
C. 1 Energy consumption and performance of chain of inverters circuit14c. 2 Energy consumption and performance of c432 circuit.148
c. 3 Energy consumption and performance of c1908 circuit ..... 149
III Thesis Bibliography ..... 151
BIBLIOGRAPHY ..... 153
Figure 1.1 The taxonomy of dependability. ..... 4
Figure 1.2 The effect of complementary metal oxide semiconduc- tor (CMOS) technology scaling on the susceptibility of elec- tronic circuits to soft errors. ..... 5
Figure 1.3 The V-Cycle of System Design Architecture [43]. ..... 7
Figure 2.1 Secondary particles produced in the interaction of cosmic rays with the nuclei of atmospheric gases [28]. ..... 13
Figure 2.2 The energy distribution of neutron particle flux, and the corresponding cumulated integral flux measured at the roof of the IBM research centre; data is taken from [5] ..... 14
Figure 2.3 Elastic scattering interaction, the total kinetic energy is the same before and after the collision. [6]. ..... 16
Figure 2.4 Inelastic scattering interaction, the total kinetic energy after the collision is less than the original. [6]. ..... 16
Figure 2.5 A negative ion passes near an atom and causes loosing one of its electrons which causes the ionization of that atom [6]. ..... 17
Figure 2.6 Penetration of neutron particles through a semiconductor device, a neutron interacts with a silicon nucleus and a neutron penetrate without any interaction [23, 55]. ..... 18
Figure 2.7 The effect of supply voltage (Vdd) and technology node on the critical charge $\mathrm{Q}_{\text {crit }}$ of a node [54]. ..... 21
Figure 2.8 Charge deposition and collection caused by the interaction between a charged particle and a reverse-bias junction on a device: (a) an ionizing ion passes through a sensitive junction and pairs of electron-hole are generated; (b) is the drift stage where the electrons and holes are collected because of the effect of the local electrical field at the junction; (c) in this stage the potential of the junction collapses, and all excess carriers combine or diffuse away from the depletion layer [11]. ..... 22
Figure 2.9 Transient current pulse that generated on a sensetive node due to a strike by a charged particle[11]. ..... 23
Figure 2.10 The red gates are sensitive, so any glitch arrives to one of their inputs it will propagate. The blue gates are non- sensitive gates, so they have the ability to block the prop- agated glitches. ..... 24
Figure 2.11 Electrical masking that occurs on some gates and atten- uates the narrow pulses. ..... 25
Figure 2.12 Latching window masking that occurs at the sequential part of the system, when the glitch misses the setup and hold times of the flip-flop. ..... 26
Figure 2.13 Probabilistic transfer matrices of logical gates: (a) AND gate, (b) NOT gate, and (c) OR gate. The symbol $p$ repre- sents an incorrect output of a gate [105]. ..... 27
Figure 3.1 The response of a faulty node to a transient current pulse generated by double exponential current model [80] ..... 37
Figure 3.2 Response of a faulty node to a transient current pulse generated by mixed-mode device physics simulation [80]. ..... 38
Figure 3.3 Transient current pulses generated using bias-dependent current model. ..... 39
Figure 3.4 Chain of inverters circuit. ..... 40
Figure 3.5 A family of single event transient (SET) pulses registered at the output of the circuit for different linear energy transfer (LET) values. (a) at Vdd $=0.4 \mathrm{~V}$, (b) at $\mathrm{Vdd}=1 \mathrm{~V}$ ..... 41
Figure 3.6 Different glitches arrived on different times. ..... 42
Figure 3.7 Critical values of the interference vector. ..... 43
Figure 3.8 Error probability of different single stages vs Vdd. ..... 45
Figure 3.9 Overall error probability of the circuit vs Vdd. ..... 46
Figure 3.10 Reliability trajectory of the uniform path changes with changing the energy consumption and the performance, the data of this figure can be found in Table A.1. ..... 47
Figure 3.11 Non-uniform single-path circuit extracted from c6288 benchmark (the carry path). ..... 47
Figure 3.12 Transient pulses registered at the output of faulty gates. ..... 48
Figure 3.13 Transient pulses registered at the output of the circuit. ..... 48
Figure 3.14 Error probability of intermediate gates vs Vdd. ..... 49
Figure 3.15 The error probability of the last stage vs Vdd. ..... 50
Figure 3.16 Overall error probability of the non-uniform circuit vs Vdd 51
Figure 3.17 Reliability, energy and performance trade-off relationship for the non-uniform path circuit, the data of this figure can be found in Table A.2. ..... 52
Figure 3.18 3-bit full adder circuit. ..... 53
Figure 3.19 Sensitive paths for the gate I1 for the input combination X1. 54
Figure 3.20 The critical values of the SETs that are generated at the gate I1 and propagated to S0 under input X1. ..... 55
Figure 3.21 The critical values of the SETs that generated at the gate Il and propagated to S1 under input X1. ..... 55
Figure 3.22 Critical values of the SETs generated in the gate Il and propagated to the two primary outputs S0 and S1. ..... 55
Figure 3.23 Reliability, energy consumption and performance trade-off in the 3-bit full adder circuit, the data of this figure can be found in Table A.3. ..... 57
Figure 4.1 Process flow of finding CVM values ..... 60
Figure 4.2 Process flow of calculating the error probability phase. ..... 61
Figure 4.3 Reliability, performance and energy trade-off of circuit c432, the data of this figure can be found in Table A. 4 ..... 64
Figure 4.4 Reliability, performance and energy trade-off of circuit c499, the data of this figure can be found in Table A.5. . ..... 65
Figure 4.5 Reliability, performance and energy trade-off of circuit c1908, the data of this figure can be found in Table A.6. ..... 66
Figure 4.6 Reliability, performance and energy trade-off relation of circuit c6288, the data of this figure can be found in Table A. 7. ..... 66
Figure 4.7 Standard error calculated for the error probabilities of different input combinations of circuit c432. There is a convergence in the results after 10 input combinations. ..... 68
Figure 4.8 Standard error calculated for the error probabilities of dif- ferent input combinations of circuit c499. The convergence occurred after 15 or 16 input combinations. ..... 69Figure 4.9 Standard error calculated for the error probabilities ofdifferent input combinations of circuit c 1908, showing aconvergence in the results after 9 or 10 input combinations. 69
Figure 4.10 Standard error calculated for the error probabilities of dif- ferent input combinations of circuit c6288, good conver- gence in the results occurring after 11 input combinations. 70
Figure 5.1 Schematic views for the circuit with the filter stage ..... 72
Figure 5.2 Overall error probability of the circuit with and without a filter stage ..... 73
Figure 5.3 Energy-Reliability-Performance trade-off before and after adding the filter stage, the data of this figure can be found in Table A. 8 ..... 74
Figure 5.4 Error suppression percentage vs Vdd. ..... 74
Figure 5.5 Effect of the filter stage on the performance of the circuit. ..... 75
Figure 5.6 Effect of the filter stage on the energy consumption of the circuit. ..... 76
Figure 5.7 Effect of the filter stage on the circuit area ..... 77
Figure 5.8 Flowchart of the systematic method of selecting filters type and strength. ..... 79
Figure 5.9 RC filters connected to circuit outputs ..... 80
Figure 5.10 The reliability improvement of the circuit c432 that oc- curred due to adding the passive filter stage, the data of this figure can be found in Table A. 9 ..... 81
Figure 5.11 Error suppression percentage of c432 circuit vs Vdd. ..... 82
Figure 5.12 Effect of the filter stage on the performance of c432 circuit ..... 83
Figure 5.13 Effect of the filter stage on the energy consumption of c432 circuit ..... 83
Figure 5.14 Reliability improvement of c 1908 circuit that occurred due to adding the passive filter stage, the data of this figure can be found in Table A. 10. ..... 84
Figure 5.15 Error suppression percentage of c1908 circuit vs Vdd. ..... 85
Figure 5.16 The effect of the filter stage on the performance of c1908 circuit ..... 86
Figure 5.17 The effect of the filter stage on the energy consumption of c1908 circuit ..... 86
Figure 6.1 Average error probability of different gates selected from different locations within a single path circuit. ..... 90
Figure 6.2 Block diagram of a single path-circuit containing $n$ gates. ..... 91
Figure 6.3 Overall error probability of the path calculated by using both exact and approximate approaches. ..... 92
Figure 6.4 Approximate and exact reliability for the single path with the Vdd range $0.6 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$. ..... 93
Figure 6.5 Block diagram of a circuit with forked path topology. ..... 93
Figure 6.6 Error zones of different gates chosen from different sub- paths. ..... 94
Figure 6.7 Error probability caused by different gates located in dif- ferent sub-paths ..... 95
Figure 6.8 Approximate and exact reliability of the divergent path for the Vdd range: $0.6 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$. ..... 95
Figure 6.9 Block diagram of a reconvergent topology path circuit. ..... 96
Figure 6.10 The possible recombination cases of tow glitches propa- gated through two different sub-paths. ..... 97
Figure 6.11 Approximate and exact reliability of the reconvergent path for the Vdd range: $0.6 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$. ..... 98
Figure 6.12 Approximate and exact reliability of the single path at the $\mathrm{V} d \mathrm{~d}$ range from 0.2 V to 2 V . ..... 99
Figure 6.13 Approximate and exact reliability of the divergent path in the Vdd range $0.2 \mathrm{~V} \geqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$. ..... 100
Figure 6.14 Approximate and exact reliability of the reconvergent path in the Vdd range: $0.2 \mathrm{~V} \geqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$. ..... 101
Figure 6.15 Sensitive paths extracted from a path topology to explain the method used to categorise the equivalent gates ..... 103
Figure 6.16 The flowchart of the process that is followed to calculate the approximate reliability of a combinational circuit. ..... 104
Figure 6.17 The approximate reliability and the exact reliability of the circuit c432 in the range $0.6 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$, it shows a minor contrast between two trajectory ..... 106
Figure 6.18 Approximate and exact reliability of circuit c1908 in the range: $0.6 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$, showing a minor contrast between the two trajectories. ..... 107
Figure 6.19 Approximate and exact reliability of circuit c432 in the range: $0.2 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$, showing a minor contrast between the two trajectories. ..... 108
Figure 6.20 Standard error calculated for the error probabilities of different input combinations of circuit c432, showing a convergence in the results after 12 input combinations. . 108
Figure 6.21 Approximate and exact reliability of circuit c1908 in the range: $0.2 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$, it shows a minor contrast between two trajectory. ..... 109Figure 6.22 Standard error calculated for the error probabilities ofdifferent input combinations of circuit c 1908, showing aconvergence in the results after 10 input combinations. . 109
Figure C. 1 The effect of the filter stage on the performance of the chain of inverters circuit. ..... 147
Figure C. 2 The effect of the filter stage on the energy consumption of the chain of inverters circuit. ..... 148
Figure C. 3 The effect of the filter stage on the performance of c432 circuit ..... 148
Figure C. 4 The effect of the filter stage on the energy consumption of c432 circuit ..... 149
Figure C. 5 The effect of the filter stage on the performance of c1908 circuit ..... 149
Figure C. 6 The effect of the filter stage on the energy consumption of c 1908 circuit ..... 150
Table 3.1 Error probabilities of individual gates corresponding to Vdd values. ..... 50
Table 4.1 Specifications of the benchmark circuits chosen to evalu- ate the reliability metric. [51]. ..... 62
Table 4.2 Number of vulnerable gates and the total simulation time of each circuit. ..... 67
Table 5.1 Effect of using $0.5 x+32 x$ filter stage on c432 and c1908 circuits (\%). ..... 78
Table 5.2 Comparison between the proposed technique and other techniques. ..... 87
Table 6.1 Approximation error caused by calculating the overall error probability using the error probability of different gates in the path (\%). ..... 92
Table 6.2 Reduction in simulation time and approximation error obtained from applying the approximation approach at the range ( $0.6 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$ ). ..... 110
Table 6.3 Percentage error and time saved obtained from applying the approximation approach at the Vdd range ( $0.2 \mathrm{~V} \leqslant \mathrm{Vdd}$ $\leqslant 2 \mathrm{~V}$ ). ..... 111
Table A. 1 Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of the chain of inverters circuit. ..... 121
Table A. 2 Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of the non-uniform path circuit. ..... 122
Table A. 3 Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of the 3-bit adder circuit. ..... 122
Table A. 4 Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of c432 circuit. ..... 123
Table A. 5 Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of c499 circuit.123
Table A. 6 Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of c1908 circuit.124
Table A. 7 Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of c6288 circuit.124
Table A. 8 Data of Figure 5.3, shows the relation between reliability, energy consumption and performance for the circuit chain of inverters in the cases: without filter, with 16x, 32x, $32 x+0.5 x$ filters.125
Table A. 9 Data of Figure 5.10, shows the relation between reliability, energy consumption and performance for the circuit c432 in the cases: without filter, with $\mathrm{R}=10 \mathrm{k} \Omega$ and $\mathrm{C}=30 \mathrm{fF}$, $\mathrm{R}=10 \mathrm{k} \Omega$ and $\mathrm{C}=40 \mathrm{fF}, \mathrm{R}=10 \mathrm{k} \Omega$ and $\mathrm{C}=50 \mathrm{fF}$ filters. . . . 126
Table A. 10 Data of Figure 5.14, shows the relation between reliability, energy consumption and performance for the circuit c1908 in the cases: without filter, with $\mathrm{R}=10 \mathrm{k} \Omega$ and $\mathrm{C}=30 \mathrm{fF}$, $\mathrm{R}=10 \mathrm{k} \Omega$ and $\mathrm{C}=40 \mathrm{fF}, \mathrm{R}=10 \mathrm{k} \Omega$ and $\mathrm{C}=50 \mathrm{fF}$ filters. . . . 127

## LIST OF ALGORITHMS

4.1 Pseudocode of the script used to find the critical values vectors
of the vulnerable gates in a circuit ..... 60
4.2 Pseudocode of the script used to calculate the error probability of a circuit. ..... 63
6.1 Finding the sensitive paths and vulnerable gates of large circuits to apply the simplification approach. ..... 105

## ACRONYMS

SET single event transient
SEE single event effect
LET linear energy transfer
PV parameter vector
PDF probability density function
UMC united microelectronics corporation
PIPB propagation-induced pulse broadening
SEU single event upset
SFM stochastic fault model
CVM critical vector model
$r_{\text {SET }}$ the rate of neutron particle
ISCAS international symposium on circuits and systems
Vdd supply voltage
IC integrated circuit
ICs integrated circuits
CUT circuit under test
CMOS complementary metal oxide semiconductor
SPICE simulation program with integrated circuit emphasis
SER soft error rate
ISCAS international symposium on circuits and systems
FIT failure in time
CRs cosmic rays

MC monte carlo

SEMT single event multiple transient

DVFS dynamic voltage frequency scaling

## Part 1

## Thesis Chapters

INTRODUCTION

### 1.1 MOTIVATION

A reliability metric can be defined as the ability of a system to continue to deliver its specified function without failure for a given period of time [27]. Reliability is one of the aspects of the value produced by a system or a circuit within a system. This value has several components For example, the reliability which can be defined as the percentage of the valid results. The energy which represents the cost of the valid results. The performance which is the number of valid results per unit of time. The unit cost which reflects the cost of the device including non-recurring engineering costs. Some of these components positively contribute to the value of the circuit, such as reliability and performance. However, some of them are negative contributors which decrease the value of the circuit, such as energy and unit cost. This study addresses all of these issues in application to design of combinational circuits rather than entire systems. In particular, this fits in the overall concept of dependability, which is the ability of a system to deliver a service that can justifiably be trusted [9, 97]. The taxonomy of dependability from [9] can be expanded as shown in Fig. 1.1. The blocks framed by black lines are relevant to the work described in this thesis. The blocks with a white background are those which are introduced in this study to the existent taxonomy. The reason for this is that dependability makes no sense if it is applied to a system which has no worthwhile level of performance. Moreover, one cannot say that the dependability of a system is high if it is achieved at the expense of very high energy or cost. The present work investigates a three-way trade-off involving reliability, energy and performance (REP) metrics, so that one can optimise these metrics to the technical requirements of a design. The unit cost is also addressed in looking for a method to increase the reliability metric by adding modifications which are inexpensive in terms of area, energy and performance using the filters which are introduced in Chapter 5.

Dependability threats are events affecting one or more of the dependability attributes of a system. These threats can be categorised as faults, errors and


Figure 1.1: The taxonomy of dependability.
failures [9, 27]. In this work, the focus is on faults and errors, as they affect the circuit-level design. Faults, in our case, are transient faults caused by neutron particles hitting the silicon in a combinational circuit. Errors are the manifestations of faults at the primary output of the circuit.

To attain dependability of a system, various approaches are proposed each of which is used in such a way to achieve one or more attributes of dependability. These approaches can be classified into four categories: fault prevention, fault tolerance, fault removal and fault forecasting [8, 61]. This work contributes to fault prevention in Fig 1.1 by adding a filtering technique. It also contributes to fault forecasting by performing the reliability estimation of combinational circuits. This is conducted off-line at design time. Both filters and reliability estimation techniques are evaluated with regard to the negative contributors to the value (energy and cost), and their effect on the positive contributors (reliability and performance).

### 1.1.1 Reliability of Combinational Circuits

Scaling of complementary metal oxide semiconductor (CMOS) technology during the last four decades has been achieved by reducing voltage levels and the feature size of transistors. This has led to doubling the density of the
embedded transistors in the same size of chip every 1-2 years [29, 42]. So, the susceptibility of digital circuits to radiation-induced soft errors has increased, and the reliability of these circuits becomes a major concern for the designers of integrated circuits (ICs) [109]. This is can be seen clearly in Fig. 1.2, showing that in 1990 the minimum linear energy transfer (LET) that was needed to cause a glitch at a circuit node which would subsequently propagates to cause an error was $15 \mathrm{MeV} . \mathrm{cm}^{2} / \mathrm{mg}$. However, in 2004 , an LET equal to $2 \mathrm{MeV} . \mathrm{cm}^{2} / \mathrm{mg}$ was sufficient to cause a glitch at the output terminal with a duration of a few nanoseconds [38, 59, 100]. Therefore, we need to know the extent to which the reliability of a combinational circuit may be affected by these errors and how is it possible to exploit available operation points such as values of supply voltage (Vdd) or minor changes in the circuit's structure in order to achieve reliable performance.


Figure 1.2: The effect of cmos technology scaling on the susceptibility of electronic circuits to soft errors.

### 1.1.2 Switching from Power-Performance Optimisation to Reliability-EnergyPerformance Optimisation.

For many years, the predominant target for ICs designers was to increase the performance of new designs regardless of their power consumption. With technology scaling, however, a higher number of devices are included in the same chip area, and power dissipation has become a crucial issue that
should be taken into account during design time [2, 101]. Power management techniques have been suggested to tackle problems associated with power dissipation in some applications, such as battery-mobile and wearable systems [88], where ultra-low power consumption and energy supply are considered to be crucial constraints among the design requirements [10, 92].

The most commonly used technique in power management is dynamic voltage frequency scaling (DVFS), which relies on lowering the voltages and/or frequency of a circuit in order to reduce the consumed power or energy. The relationship between the dynamic power and the voltage and frequency of a circuit can be described by the equation $p \propto F V^{2}$, where $F$ is the operating frequency and V is the voltage that is needed for the circuit to operate in a stable manner [66, 88]. However, the use of the DVFS technique affects the reliability of that circuit. This is because decreasing the supply voltage of the circuit leads to a decrease in the critical charge of the nodes of the circuit, which means that low energy particles become a major cause of soft errors [39, 135, 141].

Thus, a reliability metric should be included in the classical power-performance trade-off to become a reliability-energy-performance trade-off.

### 1.2 THESIS SCOPE AND CONTRIBUTIONS

The thesis addresses the problem of evaluating the reliability of combinational circuits in terms of changes in performance and energy. Performance and energy consumption are calculated according to the value of Vdd applied to the circuit. This work considers transient faults caused by neutron particles which may affect digital circuits during its normal operation. The research work in this thesis focuses on studying the generation and propagation of transient pulses at various voltages. This enables us to evaluate precisely the reliability metric and to study the effect of circuit parameters on transient pulse propagation. This research is conducted at the circuit level of abstraction.

The major contributions of this thesis can be summarised as follows:

- Reliability, energy consumption and performance metrics are combined in one trade-off interplay. This relationship allows us to explore the change in reliability due to changing one or both the other metrics of performance and energy consumption. So, performance and/or energy consumption can be tuned depending on their criticality for the application so as to
control the reliability. This is accomplished by a new proposed method for the evaluation of reliability at low levels of implementation in the bottom-up design flow. This design flow can be seen in Fig. 1.3, which shows two main aspects of system design architecture which are the implementation and verification paths. So, using this approach, we are able to address reliability issues at the stage of designing a circuit as a group of logic gates and flip-flops. If issues with circuit reliability are detected, it is possible to rectify them in the early stages of implementation.


Figure 1.3: The V-Cycle of System Design Architecture [43].

The core idea of the proposed method is based on splitting the reliability evaluation process into two levels of characterisations: a platform-level stochastic interference model and a circuit-level model:

- The platform-level interference model is fixed and applicable to any design or system under test. For example, it may include a probability density function (PDF) of neutron energy and a model of the current pulse in the transistor as a function of the neutron energy, transistor size and type, source-drain voltage, temperature, etc. Its purpose is to characterise the interference, possibly expressed in non-electrical terms (for example particle energy distribution), as electrical effects, (for example pulses of current having their magnitude, duration and arrival time described stochastically). This is done just once at design time and not specific to a particular design but is universal for every component in the circuit.
- The circuit-level model is the core idea of the proposed method. This model converts the stochastic description of the electrical interference (the current pulse caused by neutron strike) into the probability of error at the circuit output. This is achieved by finding the critical values for the interference parameter beyond which it causes an error; for example an incorrect output value written into a flip-flop. The critical values are found by a series of analogue simulation runs on the circuit. Then, given knowledge of the critical values of the interference parameter, it becomes possible to analytically recalculate the stochastic model of the interference into the probability of an output error or correct operation (reliability).
- In this work, neutron particle strikes are chosen to be the cause of the faults in a digital circuit. So, in order to apply the proposed method for the estimation of the reliability of combinational circuits, we need to model the transient current pulse that is generated because of the particle strike. This model needs to be chosen carefully, as it has a significant impact on the accuracy of the estimated reliability. A model introduced in [80] is used. In this model, the effect of a neutron strike is represented as a dependent current source added to a BSIM4 Spice model of a MOSFET transistor. Moreover, the energy of the particles is expressed as a metric of LET, because it is the effect of their interaction with the transistor that matters here and not their kinetic energy. This model is attached using the Cadence tool in circuit-level simulation to inject an single event transient (SET) into the faulty node.
- The effect of logical masking and electrical masking on the generated SET is taken into account by using analogue simulation to find the critical values of the SETS at the output of the circuit under test (CUT). In some soft error rate (SER) techniques, such as FASER [137], a predefined trapezoidal shape has been used to represent the generated transient pulse rather than using a fault model to generate it. Models are also used to implicitly include the effect of logical masking and electrical masking, which caused ignoring the effect of propagation-induced pulse broadening (PIPB). Using these models accelerates the estimation process, but also decreases the precision of the obtained results.
- A technique to improve the reliability of combinational circuits is proposed. In this technique, a filter stage is added at the primary outputs of the

CuT. This filter stage suppresses most of the glitches generated in the prior stages. Two filter solutions have been developed and analysed. The first increases the size of the output gate, and the other is implemented by adding an RC circuit at the primary outputs of the circuit. Different types of filters contribute to improving the reliability of the circuit to different extents. Also, the effect of these filter stages on the circuit metrics of energy consumption and performance are studied in detail.

- To tackle the time consumption problem encountered when using analogue simulations, a simplification technique is proposed. This technique relies on finding the equivalence between the gates within a path and the equivalence between paths. This equivalence can be determined according to the contribution of these gates to the overall probability of error in the circuit. The results obtained using this technique are compared with the exact results. The comparison shows a minor reduction in the accuracy of the approximate results in favour of a dramatic reduction in computation time.


### 1.3 THESIS ORGANIZATION AND KEY FINDINGS

This thesis is organized into eight chapters, as follows:
Chapter 1 introduces the concept of the dependability of a system and its attributes, threats and means. This is followed by introducing the main motivations behind this research which are related to the reliability of combinational circuits. Then, a list of the main contributions of this thesis, and lastly the structure of this thesis.

Chapter 2 provides a brief background of areas relevant to the research topic, such as the generation of neutron particles and classifications of the interaction between these particles and any material. It also reviews the ionization process which occurs due to the interaction between neutrons and silicon. In addition, it gives details of the generation and propagation of SETs. Finally, in this chapter we highlight the previous techniques that have been proposed for the estimation of reliability and SER of combinational circuits and their drawbacks.

Chapter 3 introduces a new method for the evaluation of the reliability of combinational circuits. Several examples have been given to show how the proposed method can be applied to a combinational circuit. Also, a brief introduction on the fault model that used in our reliability analysis is given.

Chapter 4 introduces an automation scheme for the proposed method which makes it applicable for estimating the reliability of large circuits. Then, the reliability of different circuits is estimated and introduced. These circuits are chosen from the international symposium on circuits and systems (ISCAS)-85 benchmark circuits depending on their structure and the type of gates that are used to implement those circuits.

Chapter 5 presents a new technique to improve the reliability of combinational circuits. This technique relies on enhancing the inertial delay of the last stages to filter out narrow glitches. Two different solutions have been developed and analysed. The first using active elements where the size of the final stage is modified, and the second using passive cells where a low-pass filter is added at the end of the paths in the combinational circuit. Each of these is valid for work with certain structures of circuits.

Chapter 6 proposes a simplification technique that can be used when estimating the reliability of large circuits in order to reduce the time taken to complete the estimation. The simplicity and acceptable precision of this technique make it usable in circumstances where the time of estimation matters more than the accuracy of the estimated reliability.

Chapter 7 summarises the contributions of this thesis and indicates possible directions for future research.

## BACKGROUND AND PREVIOUS WORKS

In this chapter, background information on neutron particles and their classifications is given, and the types of neutron-matter interaction are introduced in some detail. The influence of neutron particles in ionizing a silicon nucleus is described. The concepts of linear energy transfer (LET) and critical charge are also explained in this chapter. Then, the generation and propagation processes of an single event transient (SET) in a digital circuit are reported to provide on account of the physics of these events. An overview is given of relevant work that has been done so far on estimating and mitigating soft errors.

### 2.1 INTRODUCTION

In this section, a historical background is given of the effect of soft errors on the reliability digital circuits. Soft errors were first observed between 1954 and 1957 when they appeared as random failures in monitoring equipment during tests of nuclear bombs [73]. In 1962, the authors of [125] predicted that with the increasing component density of integrated circuits (ICs), the influence of cosmic rays and heavy ionized particles in affecting the operation of microelectronic circuits would become a major concern. During the 1970 and 1980, researchers began to pay attention to the soft errors induced by radiation and how it affects the reliability of semiconductor devices. However, most of this research was conducted in studies of soft errors in space equipment caused by radiation, since the effects of radiation were a major cause.

It was reported in several studies that radiation-induced soft errors can occur at sea-levels due to alpha particles [82, 83]. Alpha particles are emitted from decaying radioactive material that exists in the packaging of semiconductor devices. These particles penetrate near a storage node in a dynamic RAM, which leads to the creation of electron-hole pairs causing a random singlebit error in that node. In studies published in 1979 and 1980 respectively [47, 142] it was found that soft errors can be generated by the interaction
between neutron particles and the nuclei of silicon, which is the most commonly used material in the manufacture of semiconductor devices. This has been proven in physical experiments carried out on dynamic RAMs. In these experiments, arrays of DRAMs have been irradiated by a flux of neutron particles with different energies. The obtained results showed that one upset occurs for approximately $10^{8}$ particles $/ \mathrm{cm}^{2}$. So, by using materials emitting fewer alpha particles, neutron particles have replaced alpha particles as the dominant cause of soft errors in RAMs since 1990 [55].

Up to that time, soft errors were considered to be a reliability issue for memory circuits. However, this belief changed in 1990, when researchers started to explore the effects of radiation on ICs. A study conducted by the authors of [98] investigated the generation of a transient pulse at the output of an inverter and for the first time the acronym SET was used by these authors. Many subsequent studies have examined the effect of radiation on logic circuits. The authors of [12] introduced different propagation scenarios for an SET generated in a combinational circuit. These scenarios mostly depend on the characterization of the generated SET. So, for a SET to be able to propagate to the output flip-flop and cause a soft error, it should be wider than the transition time of the gate that propagates in. In this case, the SET propagates without any attenuation. If the duration of the SET is lower than half of the transition time of the gate, it will be attenuated. However, a SET that has a duration in the range between these two values propagates with minor attenuation leading to its duration being reduced, and eventually it may be attenuated if it is generated in a long path. Accordingly, SETs generated in combinational circuits became a huge concern related to the reliability of microelectronic circuits. These assumptions have been confirmed by subsequent studies [26, 30, 35, 81] in which it has been proven that the effect of SETs becomes more significant with technology scaling, and various techniques were proposed to mitigate these transient pulses before reaching the output of the circuit.

### 2.2 BACKGROUND ON RADIATION ENVIRONMENTS

To understand the physics of soft errors, we need to know the causes of these errors and how they originate. For many years, the two dominant causes of soft errors at sea-level were alpha and neutron particles. The emission of alpha particles can be prevented by choosing good packaging material or
coating very vulnerable semiconductor components with a thick layer of a polyamide material [7, 67].


Figure 2.1: Secondary particles produced in the interaction of cosmic rays with the nuclei of atmospheric gases [28].

The other dominant cause is neutron particles. These are generated in the interaction between cosmic rays (CRs) and the nuclei of atmospheric gases. This interaction causes a cascade of nuclear reactions producing secondary particles such as protons, neutrons, muons, and other types of particle as shown in Fig. 2.1. The intensity of these secondaries is significant at an altitude of about 55 Km , but the maximum levels can be reached at an altitude of 20 km . The concentrations of these particles decrease as they travel to the earth's surface due to their energy being lost and short lifetimes, so that most of them have decayed and are absorbed. Electrons and protons are attenuated by interaction with the atmosphere before reaching the earth's surface. At sea level, only a very small percentage of these secondaries arrive. Due to their nature and longevity, around $1 \%$ of neutron particles arrive at sea level. This feature makes this type of particle the most dominant cause of single event effect (SEE) in semiconductor devices [6, 28, 40, 55, 62, 63, 99].

Despite the small percentages of neutron particles which arrive at the earth's surface, they consist of a variety of levels of energy from a few eV to TeV . The distribution of the energies of neutron particles as measured by Goldhagen and Gordon et al. (2004) is shown in Fig. 2.2 [5]. It can be seen from this figure that the flux has three peaks. The first is for high energy
neutrons and is centred around 100 MeV . The second peak is centred at about 1 MeV and represents thermal neutrons. The third peak is for the neutrons with very low energies that have already scattered with materials, and so they are slower and become in thermal equilibrium. In the same figure, the integral flux per square centimetre per hour can be seen, where the flux is divided into three parts according to the density of the particles.

Neutrons can be classified according to their kinetic energy into six different categories as follows [5]:

- Cold neutrons: with kinetic energy $\mathrm{E}<1 \mathrm{meV}$.
- Thermal neutrons: with kinetic energy $\mathrm{E}<0.5 \mathrm{eV}$.
- Epithermal neutrons: with kinetic energy $50 \mathrm{eV}<\mathrm{E}<50 \mathrm{keV}$.
- Fast neutrons: with kinetic energy $50 \mathrm{keV}<\mathrm{E}<1 \mathrm{MeV}$.
- Medium energy neutrons: with kinetic energy $1 \mathrm{MeV}<\mathrm{E}<10 \mathrm{MeV}$.
- High energy neutrons: with kinetic energy $\mathrm{E}>10 \mathrm{MeV}$.


Figure 2.2: The energy distribution of neutron particle flux, and the corresponding cumulated integral flux measured at the roof of the IBM research centre; data is taken from [5].

### 2.3 INTERACTION OF NEUTRONS WITH MATTER

Neutron particles have the ability to penetrate deep into material. When such penetration occurs, there are three different scenarios. The first is that the penetrating particle has low energy, and so it collides with the material's nucleus. This collision causes the nucleus to be knocked out of the lattice then displacing other nuclei in the lattice. This affects the minority carrier lifetime and mobility, which causes a modification of the electrical characteristics of the component. In the second scenario, a particle with high kinetic energy collides with a nucleus of the material. This collision produces small charged fragments which have the ability to ionize the material directly. In the third scenario, the particle penetrates the material without any interaction with any nucleus. This kind of penetration does not cause any fault in the material [5, 6, 76, 99].

Neutron particles interact with material according to their kinetic energy and the interaction can be classified in two subcategories; scattering and absorption.

### 2.3.1 Scattering Interaction

Scattering interaction can be divided into two further subcategories: elastic and inelastic scattering. In elastic scattering interaction, the total energy of the particle and the nucleus is not modified, and the numbers of protons and neutrons in the nucleus remain the same as before the interaction as shown in Fig 2.3. However, the particle may lose some of its kinetic energy. The magnitude of the lost energy depends on the atomic weight of the nucleus. The lost energy can be calculated using the expression $2 E A /(A+1)^{2}$, where $A$ is the atomic weight of the nucleus, and $E$ is the kinetic energy of the neutron [112].

In inelastic scattering interaction, the energy and direction of the penetrating particle change due to this interaction. Also, some of the particle's energy is transferred to the nucleus, which might leads to a modification of the state of that nucleus so that it has an excited state. Then, the total energy of the neutron and the nucleus after the interaction is less than the original kinetic energy of the penetrating particle, because part of the particle's energy is used to displace the nucleus to the new state. This loss in the kinetic energy of the particle leads to it slowing down and being transformed into another


Figure 2.3: Elastic scattering interaction, the total kinetic energy is the same before and after the collision. [6].
type of particle depending on the new energy range, this is shown in Fig 2.4 [6, 99, 112].


Figure 2.4: Inelastic scattering interaction, the total kinetic energy after the collision is less than the original. [6].

### 2.3.2 Absorption Interaction

Absorption interaction differs from scattering interaction. In this type of interaction, a neutron is absorbed or captured by a nucleus of the penetrated material. So, a large amount of radiation can be emitted and atomic recoil may be produced. The atom eventually breaks into small fragments, each of which can generate a charged particle $[6,54,76,112]$.

Here we are interested on the interaction between neutrons and silicon because silicon is the predominant material used in the semiconductor industry. In the rest of this chapter, the focus is on silicon as an irradiated material.

### 2.4 IONIZATION

A strike of a neutron particle has been chosen to be a cause of soft errors in the approach followed in the present study. Neutrons are neutral particles and so they do not ionize penetrated material directly. However, when a neutron particle penetrates silicon, this particle may collide with a silicon nucleus, and if the particle's energy is high enough, secondary ions may be produced. These ions travel through the material causing an excitation of electrons, and these electrons then ionise other atoms. This cascading ionization process causes an inducing channel along the path of the ion. The atoms that have lost one of their electrons rearrange themselves to form holes. A high density of electron-hole pairs is then formed in a narrow zone around the ion's track [6]. This ionization process of an atom of silicon can be seen in Fig. 2.5.


Figure 2.5: A negative ion passes near an atom and causes loosing one of its electrons which causes the ionization of that atom [6].

The normal operation of semiconductor devices boosts the ionization process. For example, when a secondary ion penetrates a region in the targeted node, this region is usually a reverse-biased p-n junction in a transistor. Due to the state of this junction and the potential across its terminals, it becomes sensitive to radiation effects. So a track surrounded by pairs of electrons and holes is generated as a result of the ionization process. This track is called a funnel, and it reshapes the depletion area of that junction as shown in

Fig. $2.6[4,6,14,91,122,131]$. The recombination of these electrons and holes is caused by the potential across the terminals of the struck junction. This recombination causes the generation of a transient current pulse which may propagate through the circuit and cause a bit flip in the output flip-flop [56, 64, 128, 129, 139]. The generation and propagation of the transient voltage pulse is covered in detail in Sections 2.7 and 2.8.

Fig. 2.6 shows two neutron particles penetrating a transistor, both of which are high energy particles. One of them collides with a silicon nucleus in the transistor and secondary charged ions are generated. The other particle penetrates the transistor without any interaction and does not cause any fault in the circuit.


Figure 2.6: Penetration of neutron particles through a semiconductor device, a neutron interacts with a silicon nucleus and a neutron penetrate without any interaction [23, 55].

### 2.5 LINEAR ENERGY TRANSFER

When a particle travels through a semiconductor device, it loses some of its energy per unit length and this is called stopping power. It can be divided into two components:

1. Electronic stopping power is generated from the interaction or collision between an ionizing particle and an electron of an atom of the targeted material.
2. Nuclear stopping power is generated from the interaction between an ionizing particle and a nucleus of an atom of the targeted material.

Here, we are interested in electronic stopping power because it is the main reason for creation of electron-hole pairs, which is considered to be the first step in the generation of an SEE in a circuit. Electronic stopping power, which is called the LET can be explained as the energy deposited by an ionizing particle per unit of distance along its track. The value of LET depends on the type of ion that is created when the interaction happens. For example, a Magnesium ion has a LET higher than those of Helium or Lithium ions. An ion with higher LET ion causes a stronger effect in the semiconductor device [60].

LET can be expressed by the following equation, which represents the loss of a particle energy E per a unit of distance $x$ [6].

$$
\begin{equation*}
\mathrm{LET}=-\frac{\Delta \mathrm{E}}{\Delta \chi} . \tag{2.1}
\end{equation*}
$$

The LET in (2.1) is expressed in megaelectronvolts per micrometre. A weighted LET is used to evaluate the ratio of the LET to the density of the targeted material, which is in our case silicon [6].

$$
\begin{equation*}
\mathrm{LET}=-\frac{1}{\rho} \frac{\Delta \mathrm{E}}{\Delta x^{\prime}} \tag{2.2}
\end{equation*}
$$

where $\rho$ is the density of the targeted material. The unit of the weighted LET in (2.2) is expressed in megaelectronvolts square centimetre per milligram. To convert from LET to weighted LET the targeted material should be known. In our case, it is silicon which has a density of $2.32 \mathrm{~g} / \mathrm{cm}^{3}$. So, the LET that is expressed in $\mathrm{MeV} \mu \mathrm{m}^{-1}$ can be replaced by its equivalent weighted LET expressed in $\mathrm{MeVcm}^{2} \mathrm{mg}^{-1}$ (deposited in silicon) using the following steps [6]:

As mentioned earlier, LET describes the average energy that is lost during the passage of an ion across one unit of distance. To express the LET in more convenient units for electronics designers, it is better to express it using the unit of electrical charge, the coulomb. This makes it more comparable with the critical charge of a node and the physical dimensions of that node. The average energy that is needed to create an electron-hole is equal to 3.6 eV ,
and if we know that the electron charge is equal to $1.610^{-7} \mathrm{pC}$, using all these parameters the LET can be expressed as follows [6]:

$$
\begin{equation*}
1 \mathrm{MeV} \mu \mathrm{~m}^{-1} \Leftrightarrow \frac{1.6 \times 10^{-7} \mathrm{pC} \times 10^{6} \mathrm{eV}}{3.6 \mathrm{eV} \times 1 \mu \mathrm{~m}}=0.0446 \mathrm{pC} \mu \mathrm{~m}^{-1} \tag{2.4}
\end{equation*}
$$

Using the two equations (2.3) and (2.4), the charge collected in a semiconductor device due to interaction with a neutron particle can be expressed by the following relationship [65]:

$$
\begin{equation*}
\mathrm{Q}\left(\frac{\mathrm{pC}}{\mu \mathrm{~m}}\right)=1.035 \times 10^{-2} \mathrm{LET}\left(\mathrm{MeVcm}^{2} \mathrm{mg}^{-1}\right), \tag{2.5}
\end{equation*}
$$

where $Q$ is the charge collected in the struck node. From (2.5) the charge that is deposited by a neutron can be obtained if the LET is known [6].

The Let deposited in a material depends on the kinetic energy of the ion and the distance it has travelled in that material. This applies until it reaches the maximum at Bragg peak. After this, the LET starts to decrease as the energy of the particle increases beyond the Bragg peak [22, 99].

### 2.6 CRITICAL CHARGE

The critical charge of a digital circuit node can be defined as the minimum charge that needs to be deposited by an ionizing particle or which can be collected by that node in order to change the state of that node. The critical charge of a node can be given by the following relation [95]:

$$
\begin{equation*}
\mathrm{Q}_{\text {crit }}=\mathrm{C}_{\mathrm{N}} \cdot \mathrm{Vdd}+\mathrm{I}_{\mathrm{DP}} \cdot \mathrm{~T}_{\mathrm{F}}, \tag{2.6}
\end{equation*}
$$

where $Q_{c r i t}$ is the critical charge of a node, $C_{N}$ is the capacitance of the struck node, $V$ dd is the supply voltage, $I_{D P}$ is the maximum drain conduction current of the PMOS transistor, and $T_{F}$ is the flipping time of the node. The term $I_{D P} . T_{F}$ can be ignored in case of characterise $\mathrm{Q}_{\text {crit }}$ by using SPICE simulations [95].

From the above equation, it can be noticed that the $\mathrm{Q}_{\text {crit }}$ of a node mainly depends on the capacitance of the node and the supply voltage that is applied to it. So, with decreasing values of supply voltage (Vdd) and node capacitance due to technology scaling, the value of $Q_{\text {crit }}$ of a node is reduced as well.

This leads to increasing the susceptibility of new design technologies to the radiation-induced soft errors [54, 113].


Figure 2.7: The effect of Vdd and technology node on the critical charge $\mathrm{Q}_{\text {crit }}$ of a node [54].

The effect of supply voltage on the critical charge of a node is illustrated in Fig. 2.7 (a). It is clear from the figure that the critical charge increases with supply voltage. The influence of design technology on the critical charge of a node is shown in Fig. 2.7 (b), and it is clear that the critical charge decreases with technology scaling due to the shrinking of node capacitance.

### 2.7 SINGLE EVENT EFFECT: MECHANISMS AND CLASSIFICATIONS

To study the reliability of digital circuits and how they are affected by soft errors, we need to understand the mechanism through which such errors are generated. In general the generation of SEEs because of either a direct or an indirect ionization process can be classified into two main categories:

1. A SET is a transient voltage pulse which appears at the output of a gate in a combinational circuit. This transient pulse is generated as a result of the passage of a charged ion across a sensitive junction in that gate. The generation mechanism of this pulse can be divided into three phases, as shown in Fig. 2.8. The first phase is shown in Fig. 2.8 (a), where an ionizing ion passes through a sensitive junction. This passage of the ion leads to generating pairs of electron-hole, and the density of these pairs depends on the charge deposited by the ion. In other words, it depends on the kinetic energy of the ion and the length of the tunnel it has travelled along. Each 3.6 eV of deposited energy generates an electron-hole pair. A cylindrical track
of electron-hole pairs is thus formed along the path of the ion in the silicon. The second phase of an SET-generating mechanism is shown in Fig. 2.8 (b). In this stage, the carriers (the electrons and holes) drift and are collected by the local electric field of the junction. The electrons and holes are attracted to the N -substrate and P -substrate respectively. The electron's movement generates a current pulse, and the depletion region is distorted into a funnel shape due to the lack of equilibrium in the charge distribution. The distortion improves and increases the efficiency of the charge collection. These events end after tens of picoseconds, this prompt charge collection has occurred as a result of the existence of a local electric field across the struck junction. The final phase of this mechanism can be seen in Fig. 2.8 (c). In this phase, the funnel collapses and the electrons take a longer time to diffuse into the depletion junction due to the collapse of the junction potential. This stage takes hundreds of picoseconds, and it continues until all excess carriers have combined or diffused away from the depletion layer [6, 11, 122, 131].


Figure 2.8: Charge deposition and collection caused by the interaction between a charged particle and a reverse-bias junction on a device: (a) an ionizing ion passes through a sensitive junction and pairs of electron-hole are generated; (b) is the drift stage where the electrons and holes are collected because of the effect of the local electrical field at the junction; (c) in this stage the potential of the junction collapses, and all excess carriers combine or diffuse away from the depletion layer [11].

A transient current pulse, as shown in Fig. 2.9, is generated as a result of the charge deposited by the ionizing ion. It can be seen from the figure that the transient current pulse can be divided into two main stages. In the first stage, where the pulse is produced from the prompt collection phase, this part of the pulse has a narrower duration and higher magnitude. The second
part of the pulse is a plateau produced by the diffusion occurring during charge collection, and it has a longer duration and lower magnitude than the first part of the pulse [14, 91].

If the deposited charge in a node is higher than the critical charge of that node, then the generated transient current pulse causes a glitch in the output of the struck node. This glitch is called an SET and it is transient because it is a temporary event caused by a transient effect [6].


Figure 2.9: Transient current pulse that generated on a sensetive node due to a strike by a charged particle[11].
2. A single event upset (SEU) is a transient event which can be generated directly if the ionization ion hits a sensitive junction in a memory cell or a flip-flop, or it may occur as a result of the propagation of an SET [6]. If an SET generated in a combinational block has sufficient magnitude, it may propagate through a logic path and it might be latched by the next flip-flop or the memory cell and cause a bit flip. This flip is called an SEU [4], which eventually causes a soft error.

### 2.8 SINGLE EVENT TRANSIENT PROPAGATION

As mentioned in the last section, the interaction between a neutron particle and a semiconductor device in a combinational circuit may generate an SET. This SET may propagate through the combinational block to be latched and cause an SEU or it may be suppressed. There are three masking effects
which may prevent the generated SET from causing a soft error. Logical and electrical masking effects are related to the circuit topology and latching window masking which depends on the latching time of the output flip-flop.

1. The logical masking effect is considered to be one reason to prevent the propagation of glitches through combinational circuits [40]. This type of masking depends on the type of gates that construct the propagation path. This effect may occur on some gates, such as NAND, NOR, AND and OR, depending on their sensitivity to the faulty input line. However, this masking effect cannot happen in other gates, such as NOT, XOR and XNOR, because these gates are always sensitive to any change which occurs in their input lines. A gate is sensitive if any change in the input affects the output of the gate (the output of the gate is dependent on that input) [91]. For example, in a NAND gate has both inputs at logic-1, in this case the gate is sensitive to both inputs, and so if a glitch reaches this gate through any one of these inputs it will propagate and appears in the output of the gate. On the other hand, if both inputs of this gate are at logic-0, in this case the gate is not sensitive and any glitch arrives at one of the gate's inputs will be masked and will not appear in the output of the gate.


Figure 2.10: The red gates are sensitive, so any glitch arrives to one of their inputs it will propagate. The blue gates are non-sensitive gates, so they have the ability to block the propagated glitches.

Different SETs are shown in Fig. 2.10, some of which are masked and some are propagated depending on the type of propagation gate and its input values.
2. An SET might be attenuated before reaching the output of the combinational block. This effect is called electrical masking [21, 93]. This kind of masking occurs during the propagation of a generated glitch through the gates of a combinational circuit. It occurs as a result of the inertial delay of the gates (the transition time). So, if the propagated glitch does not have sufficient


Figure 2.11: Electrical masking that occurs on some gates and attenuates the narrow pulses.
amplitude and duration, it will be attenuated; and sufficient duration here means that the duration of the propagated glitch should be longer than the inertial delay of the gate, otherwise the glitch will be attenuated [13, 37, 120]. This effect increases in slow stages or at sub-threshold voltages where the circuit works at a slow pace.

As reported in [86, 127], when a glitch with duration $t_{d u r}$ is propagated through a path and reaches an input of a gate $G$ whose delay time is $t_{d e l}$, the propagation scenarios are governed by the relationship between the duration of the propagated glitch and the time delay of the gate as follows:

1. If $t_{d u r} \leqslant t_{\text {del }}$ the glitch will definitely be masked and will not propagate through the gate.
2. If $t_{d e l}<t_{d u r} \leqslant 2 t_{\text {del }}$ the glitch propagates through the gate, but the duration and the amplitude of the glitch at the output of the gate are less than its original duration and amplitude. So, in this case, the propagated glitch is attenuated, and it will be masked after propagating through several stages.
3. If $t_{\text {dur }}>2 t_{\text {del }}$ the glitch will be propagated through the gate without any attenuation.

In general, of all logic gates, the XOR and XNOR gates have the strongest electrical masking effect due to their size [96]. The electrical masking effect caused by some slow gates which affects narrow pulses generated in prior stages is illustrated in Fig. 2.11.
3. The third masking effect is the latching window masking effect. This type of masking related to the sequential part of the system where the generated SET can be registered as an SEU. This masking effect occurs when the propagated glitch does not match the timing of the latching window of the output flip-flop, so that it reaches it before or after the latching window [70, 77]. It is known
that the latching widow consists of the setup time and the hold time. Thus, the duration of the propagated glitch should be wider than or equal to the summation of those times. Narrow glitches may arrive at the right time for the latching window, but may not be latched up due to their short duration [25].


Figure 2.12: Latching window masking that occurs at the sequential part of the system, when the glitch misses the setup and hold times of the flip-flop.

Latching window masking is illustrated in Fig. 2.12, and it can be seen that the SET propagated from the combinational block arrives at the input of the output flip-flop at a certain time. Depending on this arrival time, the glitch may or may not cause an SEU.

### 2.9 RELATED WORK

Since 1990, soft errors in combinational circuits have been considered to be a significant concern for the reliability of commercial electronics, and so research has been carried out to investigate the effect of radiation on ICs [38]. The scope of this work is to predict the reliability of combinational circuits using analytical techniques. We have targeted the useful period of the circuit's life cycle, as in this period the faults occur as random events because of the randomness of their cause. So, we can eliminate the reliability concerns that result from manufacturing issues. This section describes the techniques that are used to estimate the reliability of combinational circuits and other techniques in the area of the analysis of soft error rate (SER). In this work, we evaluate the reliability of combinational circuits and exploring changes in terms of the voltage that is applied to the circuit. In other words, this study explores the trajectory of reliability when different parameters change
in order to determine how these changes affect the reliability of a circuit under test (CUT).

### 2.9.1 Reliability Evaluation Techniques

Analysing the reliability of digital circuits computationally could be an expensive approach. Therefore, most of the researchers suggest dealing with this problem using analytical or numerical techniques [49, 134].

The probabilistic transfer matrix (PTM) method [105] is used to evaluate the probability of errors at the gate level of abstraction in the presence of transient errors such as soft errors that caused by alpha particles. The main idea of this method is to use a matrix to represent the behaviour of the circuit, and the input values of the circuit are represented by column indices and the output is represented by the row indices. In order to do this, each gate in the circuit needs to be represented by a PTM matrix. An incorrect output is represented by $p$ in the matrix and a correct one is represented by $1-p$. The PTM matrices of some logic gates are shown in Fig. 2.13.

(a)

NOT gate

(b)


Input

(c)

Figure 2.13: Probabilistic transfer matrices of logical gates: (a) AND gate, (b) NOT gate, and (c) OR gate. The symbol $p$ represents an incorrect output of a gate [105].

After finding all PTM matrices of all gates, the PTM of the whole circuit can be found by taking into account the topology of the circuit, so that the inner product is used with serial composition and the tensor product is used with parallel composition. Based on this concept, a computational frame using algebraic decision diagram (ADD) has been developed in [69] to remove the redundant rows or columns in the PTM matrices. This reduces the complexity of the method in order to be applied to the evaluation of the reliability of large circuits. Also, the PTM method has been used as a basic approach in
[15, 102, 119, 133, 136]; however, each adds a specific technique to be used in a certain way. The PTM method is considered a simple approach for use in evaluating the reliability of a circuit; however, it has some drawbacks. For example, the masking effects are not considered, so the reliability of each gate is evaluated regardless of logical and electrical masking effects. Ignoring such effects may cause an overestimation of the circuit's reliability by a factor of 25 X in the case of a circuit tree with a logic depth of 7 [137]. Also, when evaluating a circuit's reliability in the presence of soft errors caused by neutron particles, the rates of those particles should be taken into consideration.

The signal probability reliability (SPR) method [45] has been used to evaluate the reliability of combinational circuits in [16, 50]. Analysing logic circuits using input signal probabilities is an old technique mentioned in [104]. This method is a simplified version of the PTM method which avoids the use of intermediate PTM matrices. The basis of the SPR method is to use signal probabilities and the propagation of these probabilities along the cells of the circuit under test. The idea of this method is that each gate output can be described in terms of a four-state signal probabilities matrix, and signal reliability is embedded explicitly in this matrix. For example, consider the following matrix which represents the probabilities of four states of a gate output signal:

$$
\mathrm{P}_{2 \times 2}(\text { signals })=\left[\begin{array}{cc}
\mathrm{P}(\mathrm{~s}=\text { correct } 0) & \mathrm{P}(\mathrm{~s}=\text { incorrect } 1) \\
\mathrm{P}(\mathrm{~s}=\text { incorrect } 0) & \mathrm{P}(\mathrm{~s}=\text { correct } 1)
\end{array}\right]
$$

This matrix can be obtained by multiplying jointly the inputs probabilities signals and the transfer function of the gate. The reliability of a circuit can be found by multiplying the reliability of individual output signals. The drawbacks of this method relate to dealing with reconvergent signals and scalability [41], and so the problem of the complexity of the circuit is not solved by the reference approaches.

### 2.9.2 Soft Error Estimation

SER techniques are used to estimate the susceptibility of circuits to soft errors caused by radiation effects. failure in time (FIT) is used as a measure to quantify the estimated number of failures, and one unit is equivalent to one error per billion hours of circuit operation. Proposed approaches can be classified as Analytical approaches and statistical fault injection approaches.

Analytical approaches are developed to tackle the scalability problem at the circuit level of abstraction. However, using models to represent the transient pulses which are generated and propagated in a circuit affects the accuracy of the evaluated SER [20].

Various symbolic methods based on binary decision diagram (BDD) and algebraic decision diagram (ADD) have been proposed by the authors of [ $3,18,53,85,86,87,106,107,108,137,139]$. In these approaches, descriptive models are used to represent the generated transient pulse, and in most of them it is described as a trapezoidal shape with different rise and fall times. To model the propagation process, mathematical models are used to implicitly include the effects of logical masking and electrical masking effects. Using such approaches the time taken for the estimation of the SER is reduced dramatically, especially for large circuits. However, the estimated results are inaccurate due to the use of modelling approaches. It is difficult to characterise a generated SET using a model because it depends on the characterisation of the struck node. So, modelling this pulse using a trapezoidal shape either underestimates or overestimates it. Also, when this SET propagates through a circuit, its shape changes depending on the circuit topology and the type of cells through which the pulse is propagated. So, in some topologies, the propagated pulse suffers from attenuation and when it reaches the output of the circuit it is narrower than the original pulse. However, in some topologies, the propagated pulse suffers from broadness in duration and reaches the output of the circuit wider than it was originally. This is known as propagation-induced pulse broadening (PIPB) [130]. This effect depends on the polarity of the generated pulse. Moreover, some of the proposed techniques use circuit partitioning to parallelize the estimation process in order to decrease processing time, but this technique is not applicable for all digital circuits and it is not possible at all in cases of correlated signals. So, with all the time that is saved in the estimation process, these approaches still suffer from a lack of accuracy.

Other authors [57, 77, 110] have used different current source models to inject the transient current pulse using a single-exponential model or double-exponential model. Regardless of their accuracy using these models leads to an increase in SER accuracy compared to the approaches mentioned in the previous section. Here, the SER of a circuit is calculated by finding the summation of the SERs of all sensitive nodes in the circuit. For each sensitive node, the SER is calculated by finding the probability of the logical, electrical, and latching-window masking effects that affect any generated
pulse at this node. Although the time taken to estimate the SER is reduced using these approaches, they still lack of accuracy because of the employment of mathematical models to simulate the three masking effects. Adifferent a SER analysis method has been designed which uses a parametric waveform model based on the Weibull function to describe a particle strike in [110]. In a further method for analysing and measuring SER in combinational circuits [31], a framework was proposed to estimate soft errors at three levels. At the device-level, the generation of the fault was modelled using TCAD simulation, and then at the gate level, a propagation model simulated the masking effects. An emulation-based platform was subsequently used at the application level to find the contribution of each part of the system under test to the overall SER.

Meanwile a contrasting proposal for an SER estimation technique comprises of two phases of characterisation and propagation introduecd in [77]. In the characterisation phase, a transient pulse is generated using a doubleexponential current source model injected into a node and simulated using the HSPICE simulation tool. The characterisation of the SET is stored in lookup tables, and this phase is performed only once for each technology node. The second phase is the propagation phase, in which the propagation of the SETs from the faulty node towards the output flip-flop is described using a propagation algorithm. In this algorithm, the three masking effects are included using a lookup table function so that each node has own generation LUT and propagation LUT. The SER is estimated depending on the results obtained from the propagation phase. An approach was proposed in [52] to estimate neutron-induced SER by incorporating a machine learning technique with monte carlo (MC) radiation simulation. The authors used MC simulation to obtain information about secondary ions and their deposited charge. The machine learning discriminator is used to distinguish whether or not an ion with a certain amount of energy can upset a cell, and it is fed with data collected using a TCAD simulation. This data is obtained by injecting different ions with different amounts of energy into a cell to identify the energy required to upset that cell.

Statistical fault injection approaches have been proposed to estimate the SER of combinational circuits, some of these approaches are proposed in [32, 58, 74, 94, 99, 103, 138]. In [32, 58, 138] the authors proposed a MC simulation-based technique to calculate the SER of a circuit by combining the MC simulation code proposed in [68] with a 3-D TCAD simulator to build models of particles transfer and collision. The particle energies used
in the proposed technique are sampled from the range 1 MeV to 1 GeV , obtained according to Joint Electron Tube Engineering Council (JEDEC) standard. Alternatively, a MC simulation was used to build models representing the generation and propagation of a transient pulse in [74]. Quasirandom sequences proposed in [90] were used for sampling points rather than using the $\operatorname{rand}()$ function. The advantage of using this type of sequence is that evenly scattered sampling points throughout the selected space can be obtained. Eventually, these samples are used to build a lookup table containing all SET details. Then, the error rate is calculated using an analytical technique by finding the summation of the computed SERs of all nodes in the CUT.

In another study [94] the MC simulation technique was used to verify the experimental results obtained from physical experiments conducted using accelerated high-energy neutron tests at the Weapon Neutron Research test facility, Los Alamos Neutron Science Center, USA. The authors of [99] used an approach to estimate SER exploits a nuclear database of neutron-silicon interactions that is built using MC simulation. Also, a MC code is used to identify the sensitive zones in a circuit and to generate a list of transient current pulses.

Other researchers have proposed an SER analysis framework to estimate the SER in the presence of single event multiple transient (SEMT) and SET in combinational circuits [103]. The SEMT occurs when a particle strike causes more than one transient pulse due to technology downscaling. For each node, the effects of the three masking mechanisms are modelled and incorporated into the calculation process. The problem of circuit complexity is tackled by dividing the circuit into sub-circuits of different grids, where each grid contains a group of gates and flip-flops. Then the proposed tool is applied to each grid to estimate its SER. Eventually, the overall SER is calculated by summing the SERs obtained for all grids. In this approach, the authors claimed that acceptable accuracy in the results was obtained after 10,000 simulation runs.

Statistical approaches using MC simulation are preferred by some researchers, even though they are time-consuming approaches to achieve reasonable accuracy. However, in some cases, especially if the circuit under test is used in critical applications, the extra time that is taken to estimate reliability is justified.

The use of digital simulations in evaluating the reliability of a circuit does not consume much time and the results can be obtained in a matter of seconds. However, because of the use of models to describe some effects, the
results may suffer from inaccuracies. On the other hand, although using MC simulations is a time-consuming process, the results obtained are accurate. In this work, we propose a method for evaluating the reliability of combinational circuits using analogue simulations. This method is slower than methods that use digital simulations. However, the accuracy is higher, and the results can be obtained quicker than the approaches that use MC.

### 2.9.3 Reliability Improvement in Combinational Circuits

The effect of soft errors on combinational circuits has been eliminated at several levels of abstraction using different traditional methods. In general, these methods focus on enhancing masking mechanisms in order to prevent the propagation of such errors.

At the architectural level, soft errors are detected using software redundancy. Redundant multi-threading (RMT) is a proven method which is built by running multiple threads for the same program, and the results of those threads are compared. If an error is detected, the program is rolled back to a checkpoint to rerun the instructions from that point [71].

At the logic level, hardware redundancy is used to mitigate errors. The most well-known technique is N -modular redundancy (NMR), where N -copies of a circuit connected in parallel perform the same function and the outputs of those copies are connected to a majority voter circuit which chooses the correct output. Usually $\mathrm{N}=2$ or 3 modular, forming dual-modular redundancy (DMR) or triple-modular redundancy (TMR). The cascaded triple modular redundancy (CTMR) method was proposed by John von Neumann in [124]. In this method, unreliable components can be triplicated and connected in parallel to a majority voter, where each component contains triplicate circuits and a voter. The drawback of the hardware redundancy technique is the area overhead because of the duplication or triplication of the circuit, and the area of this type of circuit increases two or three times. As result, the energy consumption of the circuit increases too.

At the circuit level, the gate sizing technique has been suggested to mitigate soft errors, where increasing the size of the transistors in a gate increases the conductance of that gate and as a result the restoration current increases. Also, increasing the transitors' size increases the gate's capacitance, which leads to the increase of its $Q_{\text {crit }}$. To decrease the area overhead, the designers of some techniques suggest choosing the most susceptible gates in the circuit
and to modify their sizes in order to harden them and make them more reliable [75, 106, 140]. These techniques have some drawbacks, such as the area overhead in the circuit and extra energy consumption.

Razor technique has been introduced in [33] to eliminate soft errors by using a delayed clock to detect timing errors that are generated because of the voltage scaling, and it can be used to detect soft errors too. However, this technique has a limited ability to detect such errors due to the duration of some SET pulses. Narrow SETs cannot be detected because their duration is less than the difference between the two clocks that used by Razor. Also from a power consumption perspective, short paths need in some cases to be delayed to prevent the reading of the short paths' next signal as a present signal, and so buffers have to be used to make sure that those signals arrive at the right time. These buffers consume extra power, which may lead to the use of Razor technique to be impractical in some circuits because of the trade-off between low power consumption due to supply voltage scaling, and the extra power consumption caused by the extra buffers. Also, in the case of detecting SETs or SEUs, if these events occur in the shadow latch, the correct data will be replaced by erroneous values [101].

Different on previous work, we propose a filtering technique based on creating a long transition region at the end of a circuit's paths to attenuate short glitches. This technique is implemented by two different structures. The first structure is changing the size of last stage in the path. The second structure is adding an RC filtering circuit at the end of the path. More details on these structure and their effect on the circuit parameters are introduced in Chapter 5

### 2.10 CONCLUSIONS

In this chapter, a concise background of the radiation environment has been given, explaining how neutron particles are involved in generating soft errors in combinational circuits. The mechanisms of the generation and propagation of an SET are covered in two separate sections due to the importance of this topic in providing a rationale for studying this kind of errors. Relevant work is reported in the last section of the chapter to give a brief background concerning research carried out so far. However, the focus here was on approaches that are concerned with soft errors generated in combinational circuits; that is SETs. Thus, this chapter has provided the background necessary to understand
the nature of soft errors and the effect of neutron particles in digital circuits, paving the way for the following chapters.

DERIVATION OF RELIABILITY

This chapter presents the core idea of the proposed method and how the approach can be applied to a combinational circuit in order to estimate its reliability. For the sake of simplicity, the approach is manually applied to small circuits to explain the main steps in estimating the reliability metric of a circuit. These circuits are two single-path circuits and one simple multipath circuit. The first single-path circuit mimics any individual path that can be taken from a large circuit. The second is a carry path extracted from the international symposium on circuits and systems (ISCAS) c6288 benchmark ( $16 \times 16$ multiplier), which is constructed from different logic gates to see the effect of the diversity of cells on a circuit's reliability. The third circuit represents multipath circuits, and is a 3-bit adder which has 7 -inputs and 3 -outputs and is constructed using 125 gates.

### 3.1 MODELLING THE TRANSIENT CURRENT PULSE

In order to estimate correctly the error probability in combinational circuits in terms of soft errors caused by neutron particles, we need to choose an accurate model of such an effect. Various models have been introduced for this purpose. For example, Messanger in [84] developed an approximate analytical solution. Wirth in [132] also introduced a mathematical model to predict and explain the relationship between a transient current pulse generated in a device and the radiation dose deposited into that device. However, the doubleexponential model is the model most commonly used by soft error researchers in simulation-based experiments due to its simplicity of incorporation in a simulation session. Various authors have used this model in experiments to approximate the transient current pulse generated in digital ICs [56, 79, $110,126,128,129,139]$. In such experiments, a transient current pulse is injected into a CUT to observe the rate of soft errors at the output of the circuit [72].

The double-exponential function used in the double-exponential current source is presented as follows [14]:

$$
I(t)= \begin{cases}0 ; & t<t d 1  \tag{3.1}\\ I_{\text {peak }}\left(1-e^{\frac{-(\mathrm{t}-\mathrm{td} 1)}{\tau 1}}\right) ; & \mathrm{td} 1<\mathrm{t}<\mathrm{td} 2 \\ \mathrm{I}_{\text {peak }}\left(e^{\frac{-(\mathrm{t}-\mathrm{td} 2)}{\tau 2}}-e^{\frac{-(\mathrm{t}-\mathrm{td} 1)}{\tau 1}}\right) ; & \mathrm{t}>\mathrm{td} 2\end{cases}
$$

In (3.1) the current waveform can be divided into two parts. The first part starts at td 1 , which is the rising part of the waveform, and it continues until $t=t d 2$. The second part starts at $t>t d 2$, which is the falling part of the waveform. The rising time is defined by $\tau 1$, and the falling time is defined by $\tau 2$. $\mathrm{I}_{\text {peak }}$ is the maximum value of the current pulse.

The main disadvantage of using the double exponential current source is its inaccuracy in representing the physical response of a device. So, if a transient current pulse generated using this model is injected into a digital circuit, it causes a drop in the output voltage of the faulty node. However, this drop may exceed Vss=0 V to the negative side, as shown in Fig. 3.1, which leads to an accelerating discharging of the charge deposited in the faulty node at a higher rate compared to the physical response of the struck node. This behaviour is not an accurate simulation of the physical response of the circuit because, in real cases when a particle hits a sensitive junction (usually a reversebias junction) in a transistor in a digital circuit, the electrical field across the struck junction collapses due to the decrease in voltage and the glitch generated at the output stops at $\mathrm{V} s \mathrm{~s}=0 \mathrm{~V}$ [14]. As a result, the prompt charge collection process is terminated and the deposited charge takes longer time to be completely discharged from the circuit. This slow discharging process leads to the generation of a longer SET [65]. Overdrive behaviour occures in models that implemented independently on the voltage of the struck node [14, 44]. However, this model can be considered a valid approximation in the cases of low values of LET [14, 24, 35, 65, 111, 123].

### 3.1.1 Bias-dependent Current Model

In this work, a model introduced in [80] and developed in [64] is used. This model is built by performing a 3-D device physics simulation simultaneously with simulation program with integrated circuit emphasis (SPICE) analysis as


Figure 3.1: The response of a faulty node to a transient current pulse generated by double exponential current model [80]
a fully coupled mixed mode. The behaviour of the simulated current pulse is implemented in such a way as to be very realistic and to follow the physical response of the struck node. This response is illustrated in Fig. 3.2. As can be seen in the figure, the node voltage decreases immediately after the charge collection has begun. So, the response of the faulty node stops at $\mathrm{V}_{\text {ss }}=0 \mathrm{~V}$, due to the collapsing of the electric field of the junction. By comparing the response of the faulty node in Fig. 3.2 with the response introduced in Fig. 3.1, it can be clearly noticed that the transient voltage pulse generated using the bias-dependent current model lasts for longer than the pulse generated using the double-exponential current model. This is due to the differences in discharging rates in the two cases.

The implementation process of this model can be divided into two phases. The first phase is used to model the prompt response of the ionization process. So, this part simulates the pulse caused due to the drift charge collection, and it is responsible for the spike in the current pulse. The second phase is used to model the recombination mechanism. So, this part simulates the pulse generated because of the diffusion charge collection, and it is responsible for the long-taieled pulse (the plateau part). The system of equations that describe this model can be found in [64] and [65].

Transient current pulses are generated at different values of LET and a fixed value of Vdd at 1 V using the bias-dependent current source model illustrated in Fig. 3.3(a). As can be seen in the figure, the current pulse is divided into two regions. In the first region, the instant response of the device is represented by a spike pulse which has different peak values depending on the LET value.


Figure 3.2: Response of a faulty node to a transient current pulse generated by mixed-mode device physics simulation [80].

So, a higher LET value generates a higher amplitude of spike pulse. This spike pulse is intended to simulate the effect of drift charge collection. The other region of the pulse is the plateau region, which is longer than the first one and has a constant magnitude for different values of LET. This is because, in this part of the pulse, the LET affects the duration of the pulse. So, it is obvious that a higher LET value generates a longer pulse duration. This part of the current pulse simulates the charge diffusion phase. The duration of the SET generated in a faulty node is proportional to the duration of this part of the transient current pulse [24].

Transient current pulses generated at different values of Vdd and a fixed value of $\mathrm{LET}=50 \mathrm{MeV} . \mathrm{cm}^{2} / \mathrm{mg}$ using the bias-dependent current source model are illustrated in Fig.3.3(b). As can be seen in the graph, the amplitude of the transient pulse changes according to the value of Vdd. This is expected, because the amount of the collected charge is proportional to the potential of the struck junction [46]. This is one of the advantages of this model, as the amplitude of the generated current pulses is correlated with the voltage applied to the struck node.

### 3.2 THE PROPOSED APPROACH

We propose a method for evaluating the reliability of combinational circuits without using the time consuming MC simulation tool or expensive physical experiments. This method uses two levels of characterisation: a stochastic


Figure 3.3: Transient current pulses generated using bias-dependent current model.
fault model (SFM) of the component library and a design-specific critical vector model (CVM). The idea is to move the high-complexity problem of the stochastic characterisation of parameters into the generic part of the design process, and do it just once for a great number of specific designs.

The SFM captures variations in the parameters of a library component with regard to the interference causing transient faults at the component output, and is meant to be obtained at the design time, similar to timing library files. It may include a probability density function (PDF) of the particle energy and a model of the generated transient current pulse as a function of the neutron energy. Its purpose is to represent the cause of faults, and so it is fixed and applicable to any design or system under test. The stochastic fault model (SFM) possibly expressed in non-electrical terms (for example, particle energy distribution), or as electrical effects (for example, a voltage pulse at a gate output with its magnitude, duration and arrival time described
stochastically). The parameters of the electrical effects form a parameter vector (PV) used further in the derivation of the critical vector model (CVM).

The CVM is derived from a limited number of simulation runs on the specific design, and it represents the boundary between the erroneous and error-free operation, w.r.t. the PV. In the above example, the PV includes the shape (a function of LET) and arrival time of a voltage pulse. A number of analogue simulations are performed to determine the LET-time pairs representing boundary conditions between error and no error at the primary output.

Finally, the probability of error-free operation is calculated by combining the SFM and CVM as a probability of the PV not reaching the critical values of CVM.

### 3.3 UNIFORM SINGLE-PATH CIRCUIT

A long chain of inverters intended to mimic a single path through an arbitrary logic circuit is used as a part of a digital circuit operating under voltage-frequency scaling. Frequency is chosen as a performance metric. It is determined for each value of Vdd applied to the circuit, by simulating the circuit and measuring the propagation delay, with no margins added. The circuit includes 205 identical inverters implemented with united microelectronics corporation (UMC) 90 nm foundry design kit. All transistors are 80 nm in length (which is standard for this library), the pull-down transistor is 400 nm , and the pull-up is 800 nm in width (these values are similar to those used in a commercial standard-cell library), with standard threshold voltage and standard Vdd=1 V. Between the inverters there are wires whose parasitic capacitance we simulate as 2 fF capacitors (which is typical capacitance of a short interconnect wire). The schematic view of this circuit is shown in Fig. 3.4.


Figure 3.4: Chain of inverters circuit.

In order to estimate the reliability of this circuit, a transient current pulse is generated using the bias-dependent current source model and injected into a single gate in each simulation run (e.g., the left inverter Il in Fig. 3.4). Examples of SET pulses in a single strength inverter under two different Vdd values of 0.4 V and 1 V and a range of LET values can be seen in Fig. 3.5. In this model, the particle energy is expressed as a metric of LET; this is because we are interested not in the energy of the particles, but rather the effect of their interaction with the transistor.


Figure 3.5: A family of SET pulses registered at the output of the circuit for different LET values. (a) at $\mathrm{Vdd}=0.4 \mathrm{~V}$, (b) at $\mathrm{Vdd}=1 \mathrm{~V}$

### 3.3.1 Evaluating the Reliability of Chain of inverters Circuit

In this section the main steps for deriving the reliability of the single-path circuit are described, where the SFM is converted into a value of reliability according to the properties of the circuit (expressed as CVM). The first objective of this stage is to determine whether or not an SET would cause an output error in the whole circuit comprising multiple gates (a long chain of inverters in our example) or not. The second objective is to calculate the probability of error-free operation, or reliability.

An output error is defined as an SEU, when an SET is latched by a flipflop connected to the output of a combinational circuit [14, 116, 120]. The difficulty here is that not all SETs result in SEUs. Some SETs disappear before the clock signal or appear too late w.r.t. it. Furthermore, the magnitude of the SET may be below the threshold of the flip-flop sampling, or its duration may be insufficient to be latched. Also, it may disappear while propagating through the path due to inertial delay behaviour exhibited in individual stages, leading to suppression of pulses of short duration. For an SET to be registered as a soft error, it should arrive at the same time as the rising edge of the clock with a magnitude in excess of Vdd/2. This is illustrated in Fig. 3.6. An early particle strike causes a glitch in a circuit, and this glitch propagates and arrives early before the rising edge of the clock. So, this glitch does not cause soft error. The same is the case if a particle hits the circuit and causes a glitch which arrives after the rising edge of the clock.


Figure 3.6: Different glitches arrived on different times.

The first objective is achieved by identifying the PV (in this experiment it is an SET characterised in terms of two parameters - the LET and arrival time)
and simulating the circuit in order to determine the critical values of this vector (PV values causing a transition at the end of the clock cycle).

The critical values of the interference vector in the case of an SET injected in stage number 101 at Vdd=1 V, are illustrated in Fig. 3.7. These critical values determine the boundary line that separates the error and no error zones. The clock period defined as a propagation delay without any margins is $\mathrm{T}=4.06$ ns. It is easy to adjust the results to any timing margins used in a particular design. For the other stages in the path, the diagrams are very similar but shifted left for low stage numbers and right for high numbers. For example, the error zones of stages 1 and 205 in Fig. 3.7 show the difference between the error zones of the three stages.


Figure 3.7: Critical values of the interference vector.
The second objective is achieved by using the graph in Fig. 3.7 to calculate the probability $\mathrm{P}_{\text {err }}$ of the circuit being in the error zone. For this, we use the PDF $f_{x}$ for the LET value $x$ and the PDF $f_{t}$ for the SET arrival time $t$. The former is known from the fault model and the latter has a uniform distribution due to the asynchronous nature of SET events. The value of $\mathrm{P}_{\text {err }}$ in (3.3) is calculated for a single clock cycle, where the clock period is adjusted to the propagation delay for each Vdd value. The PDF are for the clock cycle where an SET took place, but in real cases the SET does not occur in every clock cycle and so it needs to be multiplied by the rate of neutron particles in one clock cycle.

$$
\begin{equation*}
P_{\text {err }}=\frac{\iint_{\text {error zone }} f_{x}(x) \cdot f_{t}(t) d x \cdot d t}{\int_{t=0}^{T} \int_{x=0}^{\infty} f_{x}(x) \cdot f_{t}(t) d x \cdot d t} \cdot \text { T. } r_{\text {SET }} \text {. } \tag{3.2}
\end{equation*}
$$

Note that the PDF of the arrival time is a constant; that is, $f_{t}\left(t_{a}\right)=1 / T$ where $T$ is the clock period. The the rate of neutron particle ( $\mathrm{r}_{\text {SET }}$ ) is a constant
representing SET rate. Instead of the infinite integration limit for $x$, we choose a value of 100 , since the probability of exceeding this limit is negligible [19].

The denominator in (3.2) is equal to 1 because the integration is for the whole clock period and the whole energy range. So, (3.2) can be simplified to:

$$
\begin{equation*}
P_{e r r}=\int_{t=0}^{T} \int_{x=0}^{x=100} Z(x, t) \cdot f_{x}(x) \cdot f_{t}(t) d x \cdot d t \cdot r_{S E T}, \tag{3.3}
\end{equation*}
$$

where $Z(x, t)$ is the error zone function which can determined as:

$$
Z(x, t)=\left\{\begin{array}{ll}
0 & \text { outside the error zone }  \tag{3.4}\\
1 & \text { inside the error zone }
\end{array} .\right.
$$

The integrals in (3.3) are computed numerically because $Z(x, t)$ is determined through simulation. The PDF of LET in Fig. 3.7 is defined according to the Maxwell-Boltzmann formula:

$$
\begin{equation*}
f_{x}(x)=\sqrt{\frac{2}{\pi}} \cdot \frac{x^{2} e^{-x^{2} /\left(2 a^{2}\right)}}{a^{3}} \tag{3.5}
\end{equation*}
$$

where $a=\frac{\mu}{2} \sqrt{\frac{\pi}{2}} \approx 25.06$
This is for the probability of error when an SET is injected into any single stage in the path. The overall error probability of the path is calculated by summing the error probabilities of all individual gates. For low SET rates it is reasonable to assume that no more than a single SET can take place in the path in any particular clock cycle, which means that the (3.3) is applicable to the path error, and $r_{\text {SET }}$ becomes the SET rate in the path.

The reliability of the circuit is calculated as the probability of the absence of an error, i.e. $\mathrm{P}_{\text {reliability }}=1-\mathrm{P}_{\text {err }}$.

### 3.3.2 Results

The proposed method is applied to the CUT for a range of values of Vdd to explore how the trajectory of reliability changes with supply voltage. The error probabilities are calculated for individual gates as shown in Fig. 3.8 where the SET rate was chosen as $\mathrm{r}_{\mathrm{SET}}=20 \mathrm{n} . \mathrm{cm}^{-2} . \mathrm{h}^{-1}$ [6]. By comparing the error
probability of the first inverter with that of the 199th inverter, we can find that there is a slight difference between these probabilities. So it is sufficient to calculate the error probability of one gate and multiply it by the number of gates. However, in the case of gates located near the output, their error probabilities differ at very low voltages. So, they need to be calculated in order to obtain accurate results. It is interesting that the probability of error at the last stage is lower than those of the prior stages. This is because glitches generated in prior stages suffer from broadness, especially those generated with high LET values [34]. This broadness increases the probability of these glitches being latched by the output flip-flop. However, there is no path attached to the last stage, and hence any glitch generated in this stage would not be affected by this broadness, and a lower error probability results.


Figure 3.8: Error probability of different single stages vs Vdd.

Note that in these diagrams error probability is calculated per single clock cycle rather than per seconds of operation. This metric is relevant to the completion of fixed computational tasks. The overall error probability of the circuit is calculated by combining the error probabilities of all gates in the path as illustrated in Fig. 3.9.

A three-way trade-off between reliability, energy and performance (REP) is depicted in Fig. 3.10, which is one of the main contributions of this work. The circuit performance represents the frequency that is calculated at particular Vdd values. The energy that is consumed by the circuit is calculated by integrating the total power per one clock cycle. This figure can be divided into three regions. The first region is above the nominal voltage, where the circuit reliability and performance improve slightly versus an extreme increase in energy consumption. In the second region below the nominal voltage, where


Figure 3.9: Overall error probability of the circuit vs Vdd.
the circuit optimization based on power and performance trade-off works, the reliability of the circuit decreases dramatically to reach the lowest value at Vdd=0.35 V. This region is also known as the low-energy corner, where both reliability and performance drop rapidly, which results in a recommendation to avoid this region. In the third region, at very low voltages, the reliability of the circuit improves again to reach its highest value. This increase in the circuit reliability occurs due to the increase in the inertial delay of the gates at these values of Vdd. So, they act as filters for narrow SETs. This is a promising result for extremely low-power designs. This property is exploited by implementing a slow stage at the output terminals to work as a filter, and more details of this are given in Chapter 5.

### 3.4 NON-UNIFORM PATH

In this section, the reliability of a non-uniform path circuit is derived using the proposed method. This path is extracted from the c6288 benchmark circuit and it is constructed using 125 gates, including NOR, NAND, and NOT gates. The wires between the gates are modelled as 2 fF capacitors, and a schematic view of this path is shown in Fig. 3.11. The NOT gate is identical to the NOT gate used in the uniform-single path circuit. The width of the pull-up and pull-down transistors on the NAND and NOR gates is chosen so that it gives the same drive characteristics as the NOT gate. For the NAND gate the width of pull-up and pull-down transistors are 800 nm , and for the NOR gate the widths are 1600 nm and 400 nm for pull-up and pull-down


Figure 3.10: Reliability trajectory of the uniform path changes with changing the energy consumption and the performance, the data of this figure can be found in Table A.1.
transistors respectively. These values are calculated using the logical effort method by considering the inverter as a standard gate [121].


Figure 3.11: Non-uniform single-path circuit extracted from c6288 benchmark (the carry path).

This path is studied to see the impact of using various types of gates on the generation and propagation of SET pulses. To do so, three different SETs are generated in three different gates (NOT, AND and NOR). These gates are chosen from among the prior stages to allow the propagation effect to take place with the generated SETs. The duration of the generated SETs is
measured at the output of the faulty gates as shown in Fig.3.12. The durations were 395 ps, 407 ps and 398 ps for the SETs generated in NOT, NAND and NOR gates respectively. These pulses were generated at Vdd=1 V, and LET=50 $\mathrm{MeV} . \mathrm{cm}^{2} / \mathrm{mg}$. The durations of these pulses are measured again at the output of the path and found to be $532 \mathrm{ps}, 546 \mathrm{ps}$ and 538 ps respectively as shown in Fig.3.13. By comparing the durations of the SETs before and after propagation, it can be noticed that their duration is broadened. This occurs as a result of the accumulated effect of PIPB, which occurs due to the dissimilarities in cell sizes and also depends on the polarity of the generated SET [36, 48, 37]. As the broadness of a pulse increases, so does the probability of it being latched by the output flip-flop. So, the effect of pulse broadness can be reflected negatively in the error probability at the prior stages as can be seen in Fig. 3.14 where the error probabilities of the prior stages (gate No. 2 or gate No. 82) are higher than those error probabilities of the later gates (gate No. 114 or gate No. 122).


Figure 3.12: Transient pulses registered at the output of faulty gates.


Figure 3.13: Transient pulses registered at the output of the circuit.

### 3.4.1 Results

To evaluate the reliability of this path, the same procedure is used as in the earlier example with the inverters. Transient current pulses corresponding to a range of LET values $\left(1,2,5,25,50,75\right.$, and $\left.100 \mathrm{MeV} . \mathrm{cm}^{2} / \mathrm{mg}\right)$ are generated and injected into each gate in the path. One transient pulse is injected in each simulation run. The output of the path is observed to obtain the critical values of the SETs. Then the error probability of each individual gate is calculated. The error probabilities of some intermediate gates are shown in Fig. 3.14. In this figure, we can see the impact of the location of the faulty stage on the error probability of that stage. In general, the error probability curves can be divided into two regions: the first region is $2 \mathrm{~V} \geqslant \mathrm{Vdd} \geqslant 0.6 \mathrm{~V}$, where the error probability curves are very close to each other. This may be due to the equivalence of the attenuation effect in this voltage range. The second region of sub-threshold voltages is at Vdd<0.6 V, where the error probability of each stage differs from those of other stages, depending on the location of the stage. In this voltage range, the attenuation effect plays an important role in glitch propagation. So, most of the glitches that are generated in the prior stages are electrically masked.


Figure 3.14: Error probability of intermediate gates vs Vdd.

The error probability of the last stage in the path is shown in Fig. 3.15. The trend of error probability at this stage differs from the error probabilities of all prior stages, especially at very low voltages. This is because of its location at the end of the path, so there is no stages effect on the generated glitches.

The values of error probabilities of the chosen intermediate stages can be seen in Table 3.1. In this table, the differences between the error probabilities


Figure 3.15: The error probability of the last stage vs Vdd.

Table 3.1: Error probabilities of individual gates corresponding to Vdd values.

| Vdd <br> (V) | Gate No.2 | Gate No.82 | Gate <br> No. 114 | Gate <br> No. 122 | Gate <br> No. 124 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 2.00 | $2.01 \mathrm{E}-12$ | $1.74 \mathrm{E}-12$ | $1.63 \mathrm{E}-12$ | $1.57 \mathrm{E}-12$ | $1.51 \mathrm{E}-12$ |
| 1.8 | $2.12 \mathrm{E}-12$ | $1.79 \mathrm{E}-12$ | $1.68 \mathrm{E}-12$ | $1.67 \mathrm{E}-12$ | $1.57 \mathrm{E}-12$ |
| 1.6 | $2.23 \mathrm{E}-12$ | $1.90 \mathrm{E}-12$ | $1.79 \mathrm{E}-12$ | $1.76 \mathrm{E}-12$ | $1.68 \mathrm{E}-12$ |
| 1.4 | $2.40 \mathrm{E}-12$ | $2.04 \mathrm{E}-12$ | $1.90 \mathrm{E}-12$ | $1.89 \mathrm{E}-12$ | $1.78 \mathrm{E}-12$ |
| 1.2 | $2.57 \mathrm{E}-12$ | $2.18 \mathrm{E}-12$ | $2.01 \mathrm{E}-12$ | $2.01 \mathrm{E}-12$ | $1.90 \mathrm{E}-12$ |
| 1.00 | $2.85 \mathrm{E}-12$ | $2.40 \mathrm{E}-12$ | $2.23 \mathrm{E}-12$ | $2.18 \mathrm{E}-12$ | $2.12 \mathrm{E}-12$ |
| 0.8 | $3.29 \mathrm{E}-12$ | $2.74 \mathrm{E}-12$ | $2.51 \mathrm{E}-12$ | $2.46 \mathrm{E}-12$ | $2.40 \mathrm{E}-12$ |
| 0.6 | $3.96 \mathrm{E}-12$ | $3.35 \mathrm{E}-12$ | $3.12 \mathrm{E}-12$ | $3.01 \mathrm{E}-12$ | $2.96 \mathrm{E}-12$ |
| 0.4 | $1.00 \mathrm{E}-17$ | $4.89 \mathrm{E}-15$ | $4.69 \mathrm{E}-12$ | $5.17 \mathrm{E}-12$ | $4.73 \mathrm{E}-12$ |
| 0.35 | $1.00 \mathrm{E}-17$ | $1.00 \mathrm{E}-17$ | $1.32 \mathrm{E}-14$ | $7.18 \mathrm{E}-12$ | $6.29 \mathrm{E}-12$ |
| 0.3 | $1.00 \mathrm{E}-17$ | $1.00 \mathrm{E}-17$ | $1.00 \mathrm{E}-17$ | $9.78 \mathrm{E}-12$ | $9.95 \mathrm{E}-12$ |
| 0.2 | $1.00 \mathrm{E}-17$ | $1.00 \mathrm{E}-17$ | $1.00 \mathrm{E}-17$ | $1.00 \mathrm{E}-17$ | $5.19 \mathrm{E}-11$ |

of different stages can be clearly noticed. In general, around the nominal voltage, the last stage (gate No. 124) has the lowest error probability, and the second stage (gate No. 2) has the highest, because the effect of PIPB. This broadness affects negatively on the reliability of the circuit. However, this situation changes at very low voltages.

After obtaining the error probabilities of all gates in the path, the overall error probability of the path is calculated by combining these probabilities as seen in Fig. 3.16. The overall error probability of the circuit increases gradually with the scaling down of Vdd to reach a peak value at Vdd=0.4 V,
and then it decreases dramatically to reach the lowest values at Vdd=0.2 V and 0.3 V .

The reliability of the whole circuit is calculated and introduced in Fig. 3.17. The reliability trajectory in the figure is plotted using a solid line, and this changes with the energy consumption and the performance of the circuit. The dashed lines in the figure are trajectories which represent the reliability metric on the two-dimensional planes; the reliability-energy plane and performancereliability plane.

The reliability of the circuit is traded-off with energy consumption and performance of the circuit. It can be seen from the reliability figure that circuit reliability decreases with the scaling down of Vdd to reach the lowest reliable operating point at $\mathrm{Vdd}=0.4 \mathrm{~V}$, and this point represents the highest error probability of the circuit as shown in Fig. 3.16. Then the circuit becomes more reliable again with the scaling of vdd below 0.4 V , to reach the most reliable operating point at $\mathrm{Vdd}=0.3 \mathrm{~V}$. It is possible to exploit this point of operation where the circuit does not consume a large amount of energy in low-performance tolerance applications. There is another region at Vdd=0.2 V where the circuit reliability compared to at the previous Vdd value 0.3 V becomes less reliable.

The trend of the reliability curve is different from the results for the chain of inverters, and this can be attributed to the attenuation effect of NAND and NOR gates at low voltages. Because of this attenuation effect it is observed that no SET pulses generated in the first 80 gates at values of Vdd below 0.4 V arrived at the output of the circuit. This is because of the electrical masking effect


Figure 3.16: Overall error probability of the non-uniform circuit vs Vdd


Figure 3.17: Reliability, energy and performance trade-off relationship for the nonuniform path circuit, the data of this figure can be found in Table A.2.

## 3.5 mULTIPATH CIRCUITS

Multipath circuits contain a limited number of single paths depending on their complexity and topology. So, any generated SET may propagate through different gates and paths to arrive at one or more output terminals, or it may be attenuated because of electrical or logical masking effects. Electrical masking occurs when an SET attenuated during the propagation through a path due to the inertial delay of the stages in the path. Meanwhile, logical masking effect prohibits an SET from propagation to one of the primary outputs. Such an effect may occur as a result of the generated SET being propagated through a non-sensitive input of a gate, such as NOR or NAND gate in a combinational circuit. For example, if an SET propagates through the non-sensitive input of a NAND gate, it will be masked by the other sensitive input of the gate. In order to derive the reliability of multipath circuits, all of these effects should be taken into account to prevent under- or over-estimating the reliability of the CUT.

In multipath circuits, paths may have various topologies. For example, divergent paths where one path diverges into two or more paths (fan-out), or reconvergent paths where two or more paths meet at one node (fan-in). However, all these paths, whatever their internal topology, start with the location of a
fault and finish with one or more primary output. In the proposed method, we perform simulation to obtain the error zone of each output and combine them to find the union of all of these error zones. Then, the error probability of that fault location can be calculated with regards to the union of the error zones of all outputs. An example is given below to explain the idea of this paragraph.

For example, consider a 3-bit full adder benchmark circuit to estimate its reliability, the schematic view of this circuit is shown in Fig. 3.18. The cUT is constructed from various gates include; NAND, NOR, NOT, and XOR gates, with 7-primary inputs and 3-primary outputs. The same gate specifications as those used in the previous circuits have been used in this circuit too. The wires between the gates are modelled as 2 fF capacitors as in the single-paths examples.


Figure 3.18: 3-bit full adder circuit.
To show how our method can be applied to multipath circuits, a transient current pulse is injected into the inverter I1. As a result of this, an SET is generated at the targeted inverter and propagated through sensitive paths to reach the output of the circuit. The sensitive paths are those paths that are sensitized to the generated SET and lead it to arrive at the output terminals without any masking. The configuration of such paths depends on the input vector that is applied to the circuit. For example, we consider the vector $\mathrm{X} 1=\langle\mathrm{a} 0, \mathrm{a} 1, \mathrm{a} 2, \mathrm{~b} 0, \mathrm{~b} 1, \mathrm{~b} 2, \mathrm{ci}\rangle=\langle 0,0, x, 1,0, x, 0\rangle$, as an input combination for the circuit, and the sensitive paths under this vector are shown in Fig. 3.19. So, by applying this input combination, the generated SET propagates to reach the primary outputs S0 and S1.


Figure 3.19: Sensitive paths for the gate Il for the input combination X1.

### 3.5.1 Deriving the reliability of the circuit

The same steps have been followed in this case as in the single-path case. The difference here is that in multipath circuits, the generated SET might propagate to more than one primary output. In this case, all arriving SETs should be considered in finding the CVM.

We simulate the circuit number of times, and each time a fixed vdd value and a range of LET values are applied to the circuit as has been applied in the single-path circuits in the aforementioned sections. This time, however, the critical values of the PV are registered when at least one of the paths (where two of them exist in this example) produces a borderline error where the output voltage exceeds $50 \%$ of Vdd. The critical values of the PV of the SETs propagated through the first path to reach the primary output S0 are illustrated in Fig. 3.20. This figure shows the borderline between error and no error zones at output SO. Due to the shortened path structure of this circuit, the size of the error zone compared with the clock cycle is relatively large, unlike in the single-path case. The critical values of the PV of the other path that is connected to the primary output S 1 can be seen in Fig. 3.21.

The union of the two error zones of both outputs S0 and S1 forms the error zone of gate I1, as can be seen Fig. 3.22. As can be seen in the figure, the overall error zone is wider than the error zone of each path. Therefore, a greater number of paths through which a SET propagates lead to a wider error zone in the circuit.

The same procedure is applied to the other input vectors, $X 2=\langle 0,0, x, 1,0, x, 0\rangle$ and $\mathrm{X} 3=\langle 0,1, x, 1,0, x, 0\rangle$. In this case, it is assumed that the whole input set consists of only three vectors for simplicity. The critical values of the PV for these two input vectors are found, and the overall error and no error zones of the circuit are obtained. Then, the error probabilities of gate Il at those two input combinations are calculated.


Figure 3.20: The critical values of the SETs that are generated at the gate Il and propagated to S0 under input X1.


Figure 3.21: The critical values of the SETs that generated at the gate Il and propagated to S1 under input X1.


Figure 3.22: Critical values of the SETs generated in the gate I1 and propagated to the two primary outputs S0 and S1.

In order to calculate the error probability of I1 under the whole set of input combinations, one needs to know the probability of occurrence of each vector
in the input stream, which is part of the circuit specifications. We specify them, for example, as $\mathrm{F}_{\mathrm{X} 1}=30 \%, \mathrm{~F}_{\mathrm{X} 2}=20 \%$ and $\mathrm{F}_{\mathrm{X} 1}=50 \%$. Then, the weighted average of the error probabilities will be:

$$
\begin{equation*}
P_{e r r}^{I 1}=\sum_{i=1}^{n} F_{X i} \cdot P_{e r r i} \tag{3.6}
\end{equation*}
$$

where $P_{e r r}^{I 1}$ is the error probability of gate $I 1, n$ is the number of input vectors, and $P_{\text {err } i}$ is the error probability at a certain input vector.

The same procedure is repeated for each gate and the error probability of all gates in the circuit is calculated. The overall error probability of the circuit is calculated by finding the summation of all error probabilities of individual gates.

$$
\begin{equation*}
P_{e r r}=\sum_{j=1}^{m} P_{e r r}^{I j} \tag{3.7}
\end{equation*}
$$

where $m$ is the number of instances in which an SET is generated and arrives at the primary output under the specified input vectors.
(3.7) is used to calculate the overall error probability at different values of vdd.

### 3.5.2 Results

After finding the overall error probability of the circuit, reliability is calculated using the relationship $P_{\text {reliability }}=1-P_{\text {err }}$. The trajectory of reliability the circuit is shown in Fig. 3.23. The figure demonstrates the trade-off between reliability, energy consumption and performance of the circuit. The trajectory circuit's reliability at Vdd $>1 \mathrm{~V}$ does not show a significant improvement compared with the increase in the consumed energy, which is doubled around 4 times. So, we recommend avoiding this operating region. At the values of Vdd $\leqslant 1 \mathrm{~V}$, the reliability of the circuit decreases rapidly, which is associated with a slight decrease in the circuit's energy consumption and a sharp decrease in performance. For values of Vdd $<0.35 \mathrm{~V}$, reliability improves dramatically without a huge cost in terms of energy. This is a recommended operating point for very low-power applications.

In this circuit example, the logic depth was 9 stages, and so the electrical masking effect is not strong. By comparing the reliability trajectory of this circuit and that of the non-uniform single path shown in Fig. 3.17, we can see that the reliability of long paths is higher than that of short paths at the low-energy corner.


Figure 3.23: Reliability, energy consumption and performance trade-off in the 3-bit full adder circuit, the data of this figure can be found in Table A.3.

Up until this stage, small circuits have been used as examples to demonstrate how the proposed method can be applied to estimate the reliability of digital circuits. In order to apply this method to large benchmark circuits, the process needs to be automated. The automation scheme for this method is introduced in detail in the next chapter.

## 3.6 conclusion

In this chapter, the proposed approach is introduced in detail, and examples with different topologies are given to show how the proposed method works.

For simplicity, a single-path circuit built from a chain of identical inverters has been introduced to illustrate the main steps that have been followed to derive the reliability of a circuit. Also, another example of a single-path circuit that represents the carry path of the c6288 benchmark circuit has been given. In this example the path is constructed with different types of gates,
with different drive strengths. The trade-off between reliability, energy and performance has been explored for both circuits. In both cases the reliability of the circuits decreases sharply at Vdd $\leqslant 1.2 \mathrm{~V}$ where the circuit optimization based on power and performance trade-off works. However, unexpectedly, the reliability of the circuits improves again at very-low values of Vdd. This highlights a new operating region that can be exploited where the circuit can operate reliably with very low energy consumption. This is noticed as a common characteristic in all examples.

In multipath circuits, the same steps as in single-path circuits have been followed, but in this case, the union of all critical values should be determined at the output terminals. This is because the generated SET propagates through different paths to arrive different output terminals. The dissimilarity of path lengths widens the error zone of those paths. Also, the number of sensitive paths contributes proportionally to the widening of the error zone of the gate. As a result of these effects, the probability of error increases. This preliminary example of a multipath circuit has been given to explain how the reliability estimation method can be applied to this kind of circuits.

AUTOMATING THE PROPOSED APPROACH

This chapter presents details of the automation of the reliability estimation approach proposed in this work. This automation scheme enables us to derive the reliability of large circuits.

In the automation scheme, the reliability evaluation process is divided into two phases: the simulation phase and the computation phase. The simulation phase is performed to find the critical values of the PV of the circuit (CVM). The computation phase is then used to calculate the error probability of the circuit by jointly processing the data collected using the simulation phase with the SFM of the interference. These two phases are presented in detail in the next two sections. To validate the automation scheme, it is applied to different benchmark circuits chosen from the ISCAS-85 library.

The ISCAS- 85 benchmark circuits are used by researchers to evaluate the performance and quality of CAD tools. They have been widely used since being introduced in netlist form at the International Symposium of Circuits and Systems in 1985. However, their high-level designs have not been revealed. For research purposes, the functions and structures of these circuits are characterised by using well-defined components such as multiplexers, ALUs, and decoders [51].

### 4.1 SIMULATION PHASE

This phase is concerned with finding the critical values vector of the glitches (PV). This is done by writing a script by using OCEAN environment which is used with Cadence simulation tool. The block diagram of this process is shown in Fig. 4.1. This process starts by generating different transient current pulses corresponding to different LET values. The pulses vary in terms of magnitude and duration depending on the LET value that is used to generate each pulse. This ensures that the CUT is being tested under the whole range of effective neutron flux. In each simulation run, one current pulse is injected into a certain gate in the circuit. The output of the circuit is observed to register the critical values of the propagated glitches.


Figure 4.1: Process flow of finding CVM values

The pseudocode that describes the steps of this phase is shown in Algorithm 4.1. In this code, a circuit netlist is copied N times, where N is the number of gates in the circuit. Each copy of the circuit netlist contains one faulty gate. The simulation starts by applying the strongest SET can be generated in the circuit. This pulse is generated at Vdd $=2 \mathrm{~V}$ and LET $=100 \mathrm{MeV} . \mathrm{cm}^{2} / \mathrm{mg}$. Up until this step, we are testing weather or not the gate is vulnerable to the effect of the injected transient pulse, where the gate is vulnerable if it generates an SET. In a case where the gate is vulnerable and the generated SET arrives at the primary output of the circuit, the whole testing range of LET and Vdd is applied to the gate. Otherwise, the script skips this gate and tests the next one. After performing the simulation, the output of this process is the critical values vector of a faulty gate in the circuit. The simulation is run N times to examine all of the gates in the circuit netlist.

```
\(\overline{\text { Algorithm 4.1 Pseudocode of the script used to find the critical values vectors }}\)
of the vulnerable gates in a circuit
    for each gate \(i\) in the circuit do
        Inject the transient current pulse to the gate
    Make a copy of the netlist
    end for
    for each netlist \(i\) in the circuit netlists \(N\) do
    if a glitch with LET=100, Vdd=2 propagated to the circuit output
    then
        Apply a range of LETs and a range of Vdd values
        Find the critical values of all the glitches
        Save the results in a text file
    end if
    end for
```

The results obtained from this phase are the critical values vectors of all the PVs of the circuit saved in a text file. These results contain the same information as that presented in Fig. 3.22. In this form, the results can be read by the next phase in order to estimate circuit reliability.

### 4.2 ERROR PROBABILITY CALCULATION

This is the second phase of reliability estimation, where the probability of errors is calculated by processing the data obtained from the simulation phase. The block diagram of this process is shown in Fig .4.2. The critical values vectors and the PDF of the LET represent the input of this process. The error zone of each gate is determined. However, if there are more than one error zones, their union will be determined and accounted as the error zone of that gate. The probability of the error zone is calculated and multiplied by the rate of neutrons in one clock cycle to obtain the error probability of that gate. For each Vdd value applied to the circuit, the corresponding propagation delay is calculated and assigned as the operating clock period. After obtaining the error probabilities of all vulnerable gates in the circuit, the overall error probability of the circuit is calculated. The steps of the script used in this phase are shown in Algorithm 4.2.


Figure 4.2: Process flow of calculating the error probability phase.

### 4.3 BENCHMARK RELIABILITY ESTIMATION

Several benchmark circuits have been chosen to derive their reliability using the proposed approach, and the specifications of the circuits chosen are shown in Table 4.1. Each circuit is selected to be different from the others in terms of structure and the length of paths. The impact of these differences on a circuit's reliability is explored in this section.

| Oもて | $729 \times$ | Z¢ | Z¢ | ェə！̣d！̣［nu 9I x 9I | $8879{ }^{\circ}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | ヤ！̣ワ．！̣ |  |
| 9 | I I Z I | ¢ 7 | $\varepsilon \varepsilon$ |  | 80610 |
| $\checkmark$ | $8 \ddagger 8$ | 78 | It | ฉ！ | 66ヵつ |
| G | もLZ | $L$ | 98 |  | Z\＆も |
| syoolq ［euo！̣วuny jo ${ }^{\circ} \mathrm{on}$ |  | $\begin{gathered} \hline \hline \text { səu!̣! } \\ \text { qudұno jo } \circ \mathrm{on} \end{gathered}$ | səu！̣ $\ddagger$ łndui jo ${ }^{\text {on }}$ | uop̣ound |  |



```
Algorithm 4.2 Pseudocode of the script used to calculate the error probability
of a circuit.
    Perr=0
    for each sensitive gate \(i\) in the circuit do
        for each Vdd value from the Vdd range do
            Read the critical values of the glitches
            Determine the error zones
            if there are more than one error zone then
                Find the union of the error zones
            end if
            Calculate the probability of the error zones
            Calculate the rate of neutrons per one clock cycle
            Calculate the error Probability of the gate \(\mathrm{Perr}_{\mathrm{g}}\)
        end for
        Calculate the error probability of the circuit Perr \(=\) Perr + Perr \(_{g}\)
    end for
```

The error probability of each circuit is calculated several times with different input combinations, which have been randomly selected. These input combinations are assumed to be independent of each other. Then the average of the error probabilities obtained has been taken in calculating the overall error probability ( $\mathrm{P}_{\text {err }}$ ) of the circuit. Subsequently, the overall error probability is used to calculate the reliability of the circuit according to the relation $P_{\text {reliability }}=1-P_{\text {err }}$.
The three-way trade-off relation between reliability, performance and energy consumption (REP) is obtained for the selected benchmark circuits. Frequency is used as a performance metric for the cUTs, which is calculated by finding the propagation delay that is needed for an input signal to arrive the primary output terminal of the circuit. As each circuit has more than one primary output, so the propagation delay of the longest path has been chosen to be the propagation delay of the whole circuit. The energy metric is derived by integrating the total consumed power per one clock cycle.

The reliability trajectory of circuit c432 can be seen in Fig. 4.3. Most of the paths in this circuit are short, so the effect of electrical masking on the propagated SETs is not high, which leads to the propagation of most of the glitches that are generated in the circuit. As can be seen in the figure, the reliability of the circuit decreases sharply with reduction in the frequency and energy consumption of the circuit, reaching a minimum level at Vdd=0.35 V. Then the reliability increases again at $V d d=0.2 \mathrm{~V}$ as the effect of attenuation is noticeable at this Vdd value. However, the reliability of the circuit at very
low voltages does not improve significantly. This can be attributed to the property of short paths where the final gates can have an effective impact on the reliability of the circuit compared with the effect of other gates within a path.


Figure 4.3: Reliability, performance and energy trade-off of circuit c432, the data of this figure can be found in Table A.4.

The reliability curve of c499 circuit is illustrated in Fig. 4.4. This circuit is considered to be a short-path circuit too. In this figure, we can see the trend of the reliability curve which drops steadily to reach the lowest reliable operating point at $\mathrm{Vdd}=0.35 \mathrm{~V}$. Then it suddenly shoots up to reach the highest reliability level at $\mathrm{Vdd}=0.2 \mathrm{~V}$. All glitches are attenuated at this Vdd value, even those generated in the final stages. This is because, in this circuit, the output gates are XOR gates which are considered to be large gates that have large delays [96], and so their electrical masking is very high. By comparing the reliability curves of this circuit and c432 circuit, we can see the positive impact of using large gates at the output terminals.

The reliability trajectory of circuit c1908 is shown in Fig. 4.5. This circuit is considered to have combination of short and medium-length paths. This structure has a negative impact on the reliability of the circuit at low voltages. In general, the reliability of the circuit falls steadily with decreases in frequency and energy consumption to reach the lowest level at Vdd=0.4 V. Then, the reliability increases sharply again at $\mathrm{Vdd}=0.3 \mathrm{~V}$ because of the attenuation of


Figure 4.4: Reliability, performance and energy trade-off of circuit c499, the data of this figure can be found in Table A.5.
most of the generated glitches. At Vdd=0.2 V the effect of electrical masking on the prior stages is very high; however, the glitches that are generated at the final stages are widened tremendously to increase the error probability of the circuit at this Vdd value. Also, the high number of output gates relative to the number of the gates in the circuit and the type of these gates affects negatively on the reliability of the circuit at Vdd=0.2 V.

The reliability trajectory of circuit c6288 is illustrated in Fig. 4.6. The trend of the reliability trajectory of this circuit is slightly different from that of circuit c1908, and it is close to the reliability trend of circuit c499. The reliability is decreased to reach the lowest level at $\mathrm{Vdd}=0.6 \mathrm{~V}$. Then it increases sharply to achieve the highest reliable point of the circuit at Vdd=0.2 V. Due to the implementation of the circuit with a long-path structure, the electrical masking effect at low voltages is very high. This leads to the attenuation of all the generated glitches except those at the output gates. As a result, the circuit reliability is improved dramatically at low voltages compared with the c 1908 circuit.

In general, we notice that there is a common property here which is shared between all circuits whose reliability has been derived. This property can be stated as the golden finding of this chapter, which is that the same level of reliability of a circuit can be reached twice, once with high energy consump-


Figure 4.5: Reliability, performance and energy trade-off of circuit c1908, the data of this figure can be found in Table A.6.


Figure 4.6: Reliability, performance and energy trade-off relation of circuit c6288, the data of this figure can be found in Table A.7.
tion and the other with low energy consumption at very low voltages. This property can be exploited in low-speed applications where the circuit can
be tuned between a high-reliability and low-energy consumption mode or a high-reliability and high-energy consumption mode.

The number of vulnerable gates in each benchmark circuit is calculated for each input combination. This number is not fixed and changes from one simulation run to another depending on the input combination that is applied to the circuit. So, the average number of vulnerable gates has been taken and is shown in Table 4.2. Also, depending on the number of vulnerable gates, the simulation time is calculated and this increases with the number of vulnerable gates. The average of the simulation time of each circuit can be seen in Table 4.2. The time is calculated according to the time that is spent on each simulation run and aggregated for the whole circuit.

Table 4.2: Number of vulnerable gates and the total simulation time of each circuit.

| Circuit | No. of vulnerable <br> gates | The simulation <br> time (minuts) |
| :---: | :---: | :---: |
| c 432 | 60 | 210 |
| c 499 | 65 | 355 |
| c 1908 | 260 | 1820 |
| c 6288 | 650 | 23148 |

### 4.4 STOPPING CRITERION

Due to the difficulty of deriving the reliability of these circuits for all input combinations, reliability is derived for a group of input combinations which are randomly selected. This leads to obtaining several results for each circuit. The average of the reliabilities obtained is calculated and considered to represent the reliability of the circuit. However, the number of selected input combinations needs to be determined, as this the number of the simulations that are needed to deliver precise results depends on this. In this work, we used the standard error (SE) metric to measure the convergence between the results obtained. So, the simulations stops when a convergence between the reliabilities obtained is achieved.

The SE is calculated according to the equation: Standard Error $\mathrm{SE}=\sigma / \sqrt{n}$, where $\sigma$ is the standard deviation of the obtained results and $n$ is the number of results obtained.

The SE is calculated for overall error probabilities, and the SE values along with the number of the applied input combinations of circuit c432 are illustrated in Fig. 4.7. The convergence between the results can be noticed clearly, where the results that are obtained by applying the first five input combinations have a high values of SE which means that the level of convergence is very low. Eventually, the values of SE are reduced as a result of including more results. After applying 13 or 14 input combinations to the circuit, the values of the SE become very small. So, the convergence between the results is very high and it is possible to stop the simulation because the addition of any new result will have a negligible effect on the overall average.


Figure 4.7: Standard error calculated for the error probabilities of different input combinations of circuit c432. There is a convergence in the results after 10 input combinations.

The convergence between the obtained error probabilities of circuit c499 is calculated and illustrated in Fig. 4.8. As can be seen in the figure, there is a quick convergence in the results occurs after applying 3 input combinations. However, it was a temporary witch disappeared with more input combinations. The real convergence occurs after applying 16 input combinations. Also, we can notice that the results converge with different trends according to Vdd values. For example, at Vdd=0.2 V the error probabilities of the circuit have converged after applying 10 input combinations to the circuit, which is faster than the results at other Vdd values. Moreover, it can be noticed that all SE values at this Vdd value are less than the other SE values. So, the results at this value of Vdd are very close to each other.

The SE of the error probabilities of circuit c1908 is shown in Fig. 4.9. It can be seen in the figure that convergence occurs in the results after 9 or 10 input combinations. However, at Vdd=0.3 V, the results converge earlier after 6 input combinations.


Figure 4.8: Standard error calculated for the error probabilities of different input combinations of circuit c499. The convergence occurred after 15 or 16 input combinations.


Figure 4.9: Standard error calculated for the error probabilities of different input combinations of circuit c 1908, showing a convergence in the results after 9 or 10 input combinations.

The convergence of the error probabilities of circuit c6288 can be seen in Fig.4.10. The results show high divergence when applying a few input combinations; however, after applying 11 input combinations to the circuit, the results showed a good convergence. This convergence increases when more input combinations are applied. However, we stopped the simulation process after applying 16 input combinations and achieving reasonable convergence.

### 4.5 CONCLUSION

In this chapter, the main contribution of the method for deriving a circuit's reliability is automated to be applicable to large circuits. As example, circuits are selected from ISCAS- 85 benchmark circuits and their reliability is estimated.


Figure 4.10: Standard error calculated for the error probabilities of different input combinations of circuit c6288, good convergence in the results occurring after 11 input combinations.

The reliability of each circuit is evaluated at a group of input combinations which are randomly selected and then the average is taken and considered to represent as the reliability of the circuit.

The reliability of each circuit has a unique trajectory depending on its structure. In the case of circuits with short paths, the glitches that generated in the final stages impact negatively on the reliability of the circuit. This is because the number of gates within a path is not high enough to make this effect negligible. However, the output gates even in short-path circuits have a positive impact on the reliability of the circuit. Some gates, such as XNOR and XNOR gates, have the ability to attenuate the generated glitches. So, the reliability of the circuits implemented using these kinds of gates improves dramatically at very low voltages. The reliability of long-path circuits usually improves at very low voltages due to the dominant effect of prior gates, where the electrical masking effect attenuates most of the generated glitches. So, the effect of the final stages are negligible compared with the effect of the prior stages.

The standard error metric is adopted as a criterion for when to stop all simulations performed to estimate the reliability of large circuits. Once convergence has occurred in the results obtained, the simulations is stopped and the average of the results obtained is calculated. This approach is usually acceptable in large circuits which require time-consuming simulations.

## IMPROVING THE RELIABILITY OF COMBINATIONAL CIRCUITS

This chapter introduces a new technique which can be used to mitigate the soft errors that are generated in combinational circuits. This technique relies on enhancing the inertial delay of the last stages to filter out narrow glitches. It is suggested based on our observations while performing the simulation experiments. It was noticed that slow stages filter out most of the glitches that propagate through them. As a result, the reliability of the circuit is improved. We exploit that effect by making the final stage slower than other prior stages so as to increase the propagation delay of that stage and allowing it to work as a filter. This technique is implemented using active elements where the size of the final stage is modified, and using passive cells where a low-pass filter is added at the end of the paths in the combinational circuit. The results show a dramatic improvement in circuit reliability at the expense of a minor increase in energy consumed and a small decrease in circuit performance.

### 5.1 INTRODUCTION

During the propagation of a transient pulse, it may suffer from degradation in amplitude and duration. This degradation is caused by the gates through which that pulse propagates. Degradation in amplitude could occur if the input of a certain gate is switched to the opposite state before the output of the gate is completely switched to the new state [1]. This usually occurs when the inertial delay of the gate is longer than the duration of the propagated glitch. So, this causes a distortion in narrow glitches and they do not reach the full amplitude of the waveform. Also, when a circuit works at very low voltage, the propagation delay of the gates increases which causes attenuating the propagated glitches that have a duration lower than the transition time of these gates [78, 93, 117, 131].

### 5.2 CIRCUIT RELIABILITY WITH ACTIVE FILTER STAGE

In this type of filtering technique, the parameters of the final stage (here, the size of transistors) in the path are increased so that it works as a filtering stage. By increasing the size of this stage, it becomes slower and has a longer inertial delay compared with other stages in the path. By doing this, this stage is enabled to filter out most of the SETs pulses generated in prior stages. In fact, some of them are attenuated completely, and those which are not are reduced in duration. This filter stage is more effective when the circuit works at low voltage.

(a) A schematice view shows the one stage filter

(b) A schematice view shows the two stages filter

Figure 5.1: Schematic views for the circuit with the filter stage.

As an example, the proposed technique is applied to the circuit constructed with a chain of inverters and described in Section 3.3 to improve its reliability. In this experiment, either the last stage only or the last two stages are replaced with gates of different sizes, and the schematic view of the circuit with the filter stage is demonstrated in Fig. 5.1. The weakest filter in the experiment is implemented as a $16 x$-size inverter at the primary output, while the strongest is constructed of a 0.5 x inverter driving a 32 x inverter (denoted as $0.5 \mathrm{x}+32 \mathrm{x}$ ). The idea of using two-stage combinations comes from the fact that the logical effort method [121] effectively doubles the inertial delay. Altogether, the fol-
lowing filters are simulated: 1 x (no filter), $16 \mathrm{x}, 24 \mathrm{x}, 32 \mathrm{x}, 0.5 \mathrm{x}+16 \mathrm{x}, 0.5 \mathrm{x}+24 \mathrm{x}$, $0.5 \mathrm{x}+32 \mathrm{x}$.

The overall error probability of the circuit before and after adding the filter stage is shown in Fig. 5.2. In general, the overall error probability of the circuit is reduced by different degrees depending on the strength of the filter stage. The lowest error probability is calculated in the case of using the filter with the longest propagation delay $(0.5 x+32 x)$.


Figure 5.2: Overall error probability of the circuit with and without a filter stage.

As can be seen from Fig. 5.2, the 32x and $0.5 x+16 x$ filters produce almost the same effect, as expected according to the logical effort method. Therefore, the $0.5 x+24 x$ and $0.5 x+32 x$ filters are equivalent to $48 x$ and $64 x$. At low voltages, the filtering effect increases because the propagation delay of the filter becomes longer compared to the glitch duration.

The reliability of the circuit before and after adding the filter stage is illustrated in Fig. 5.3. It can be seen from the figure that the reliability trajectory of the circuit is shifted into more reliable regions according to the filter strength. The most reliable operation is obtained by applying the $0.5 x+32 x$ filter, but the circuit with this stage consumes more energy as can be seen in the energyreliability projection in the same figure. In general, the reliability improvement is associated with a change in the performance and energy consumption of the circuit which decreases and increases respectively by different values depending on the strength of the filter stage. So, increasing the filter strength leads to improving circuit reliability but also an increased energy-performance penalty. These penalties are studied in more detail in the next section.


Figure 5.3: Energy-Reliability-Performance trade-off before and after adding the filter stage, the data of this figure can be found in Table A.8.

The percentage reduction of the error probability due to adding the filter stage to the circuit is calculated for each filter size and shown in Fig. 5.4. The error suppression percentage values reflect how much the circuit reliability has improved. The figure shows that, as the supply voltage decreases, more errors are suppressed and dissipated. These suppression values vary according to the strength of the filter used. Also, in the same figure, it can be seen that the two most powerful filters in suppressing errors are $0.5 \mathrm{x}+32 \mathrm{x}$ and $0.5 x+24 x$.


Figure 5.4: Error suppression percentage vs Vdd.

### 5.3 ACTIVE FILTER STAGE EVALUATION

The filter stage is a modified stage inserted into a circuit to eliminate the glitches generated in that circuit. So, in order to identify the advantages and the disadvantages of this stage, its effect on circuit parameters is studied. The main three parameters that are assessed before and after the filter stage is added are performance, energy consumption, and the area occupied by the circuit.

### 5.3.1 The Performance Change

The performance of the circuit is calculated directly by finding the propagation delay of the whole path. This is accomplished by summing the propagation delays of all gates in the path. The propagation delay of the circuit is affected by the filter stage whose delay is increased due to its change in size, and so the performance of the whole path is affected by this stage. Fig. 5.5 shows the extent to which the filter stage with different strengths causes the performance of the circuit to deteriorate. It can be noticed that the percentage reduction decreases at low voltages, so that the influence of the filter stage on performance increases at high voltages. This can be attributed to the fact that the circuit at low voltages is already working at a low performance level, and so the extra delay does not make much difference. In general, the percentages of performance reduction are acceptable values when compared with the improvements in reliability achieved.


Figure 5.5: Effect of the filter stage on the performance of the circuit.

### 5.3.2 Change in Energy Consumption

Increasing the size of the transistors in a gate has a significant effect on their switching speed. They take extra time to switch from one logic state to another compared with regular gates in the same technology library. In other words, the transition time of the signal that propagates through those stages is longer than the transition time in normal stages. This slowness in switching speed leads to increases in the short-circuit current. As a result of this, the energy consumed by the circuit increases [118, 89]. The extra energy consumption due to the addition of the filter stage is calculated and demonstrated in Fig. 5.6. It can be noticed that the extra amount of energy that is consumed by the circuit in the presence of a filter stage depends on the strength of the filter itself. So, the $0.5 x+32 x$ filter contributes to the highest percentage of extra energy consumption. However, this percentage varies with variations in Vdd values. Moreover, if we compare the 32 x and $0.5 \mathrm{x}+16 \mathrm{x}$ filters we can notice that, from the energy consumption and error reduction perspectives, it is better to use the two-stage structure.


Figure 5.6: Effect of the filter stage on the energy consumption of the circuit.

### 5.3.3 Area Overhead

Area overhead is a major concern for chip designers, and so we studied the effect of the filter stage on the area of the circuit by comparing the area before and after adding this stage. The area overhead of the circuit can be seen in Fig. 5.7. It can be said that it this in the acceptable range compared with the
area overhead caused from using other techniques at system level such as triple modular redundancy (TMR), or information redundancy.


Figure 5.7: Effect of the filter stage on the circuit area

The filtering technique that is proposed in this section uses standard cells that could be used for any CMOS circuit implementation, and we merely need to tune the size of these special cells to meet the requirements of reliability and energy consumption. These filters with a certain strength are able to suppress the propagated SETs by $99.6 \%$ at the expense of a minor increase in the energy consumption of the circuit. Using this technique to improve the reliability of a circuit is more effective with circuits constructed using long paths. This can be attributed to the fact that, in this kind of circuit, the extra energy consumption or reduction in performance caused by the filter stage is very small compared with the original energy consumption or performance of the circuit. This may be also true in the case of the area overhead penalty. However, in combinational circuits that have short paths, especially those with high numbers of primary outputs, increasing the size of the final stage is not a practical approach. This approach is applied to c432 and c1908 combinational circuits, and the extra energy consumption and performance reduction penalties are shown in Table 5.1. As can be seen in the table, in the case of c432, the extra energy consumption reaches unacceptable levels, especially at high voltages.

This provided the motivation to propose the implementation of the filter stage using passive components, which is introduced in the next section in detail.

Table 5.1: Effect of using $0.5 x+32 x$ filter stage on c432 and c1908 circuits (\%).

| Vdd(V) | error <br> suppression |  | performance <br> reduction |  | energy <br> consumption |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | c 432 | c 1908 | c 432 | c 1908 | c 432 | c 1908 |
| 2.0 | 50.49 | 38.21 | 33.08 | 13.66 | 256.05 | 175.45 |
| 1.8 | 50.05 | 35.79 | 33.49 | 14.03 | 298.25 | 162.01 |
| 1.6 | 50.06 | 33.93 | 33.94 | 14.44 | 284.96 | 146.22 |
| 1.4 | 51.20 | 33.15 | 34.73 | 14.99 | 260.18 | 126.86 |
| 1.2 | 54.36 | 33.00 | 35.36 | 15.66 | 227.47 | 103.83 |
| 1.0 | 57.69 | 35.78 | 36.74 | 16.43 | 178.72 | 76.27 |
| 0.8 | 66.35 | 49.88 | 38.17 | 17.00 | 112.74 | 47.40 |
| 0.6 | 78.74 | 81.42 | 37.93 | 17.24 | 57.43 | 25.28 |
| 0.4 | 70.55 | 74.65 | 39.92 | 17.39 | 40.33 | 17.09 |
| 0.35 | 51.03 | 21.64 | 39.12 | 16.52 | 43.07 | 17.62 |
| 0.3 | -2.69 | -73.13 | 37.85 | 14.39 | 47.12 | 19.06 |
| 0.2 | -203.1 | -255.5 | 36.06 | 11.11 | 83.33 | 30.89 |

### 5.4 CIRCUIT RELIABILITY with PASSIVE FILTER stage

The same concept that was used in the previous section is used here. However, other components are used here to reduce the consumption of extra energy. So, the active filter stage is replaced by an RC circuit (low-pass filter) to filter out the narrow glitches before they arrive at the primary output of the circuit. The resistor ( R ) and capacitor ( C ) values are chosen to filter glitches with durations $\leqslant 500 \mathrm{Ps}$, because this is the dominant duration noticed during the experiments performed. The whole idea of our technique is to add a slow stage to create a transitional region able to attenuate most of the propagated glitches. The main steps of the process that is used to select the type and strength of filters are shown in Fig. 5.8. The filter type can be determined according to the topology of the circuit. An active filter stage is effective with circuits that have long paths due to the high energy consumption and performance penalties with short-path circuits. However, a passive stage filter can be used effectively with both circuit topologies.

The passive filter stage is added to the c432 and c 1908 ISCAS-85 benchmark circuits to improve their reliability. This is introduced in the next sections.


Figure 5.8: Flowchart of the systematic method of selecting filters type and strength.


Figure 5.9: RC filters connected to circuit outputs

### 5.4.1 Improving the Reliability of c432 Circuit

The RC circuit is connected to all the output terminals of the circuit, as shown in Fig. 5.9. These RC circuits add a delay to the transition edges of the propagated signals and so in cases of narrow pulses, and due to their short duration they do not reach their full amplitude, which leads to them being attenuated.

The reliability of the circuit is evaluated after adding different passive filters with different values of capacitor. We fixed the value of the resistor at $10 \mathrm{k} \Omega$, and the capacitor value is changed to values of 30,40 and 50 fF . So, the passive filter is implemented at different strengths, the weakest with $\mathrm{R}=10$ $\mathrm{k} \Omega$ and $\mathrm{C}=30 \mathrm{fF}$, and the strongest with $\mathrm{R}=10 \mathrm{k} \Omega$ and $\mathrm{C}=50 \mathrm{fF}$. As a result of applying these filters to the circuit, its reliability improved according to the filter stage's strength. The reliability of the circuit before and after adding the filter stage is shown in Fig. 5.10. As can be seen in the figure, there is a significant improvement in circuit reliability. This improvement varies depending on the value of Vdd and the strength of the filter stage. The effect of the filter stage on the reliability metric is shown in the solid lines. The dashed lines show projections of the reliability metric against the energy consumption and performance of the circuit. The best reliability trajectory is achieved by applying the strongest filter stage (with $\mathrm{C}=50 \mathrm{fF}$ ) to the circuit. The reliability of the circuit in this case is very high and it is not correlated with the value of Vdd of the circuit as it was before the addition of the filter stage. Moreover, an interesting finding here is that at $\mathrm{Vdd}=0.3 \mathrm{~V}$, the reliability of the circuit
was at its lowest level before adding the filter stage. However, after adding the weakest filter stage (with $\mathrm{C}=30 \mathrm{fF}$ ) to the circuit, this point (Vdd=0.3 V) becomes the most reliable point in the reliability trajectory. The lowest reliable point is shifted to the higher Vdd value of 0.6 V .


Figure 5.10: The reliability improvement of the circuit c432 that occurred due to adding the passive filter stage, the data of this figure can be found in Table A. 9

The error elimination rates are calculated by finding the percentage reduction in error probability of the circuit due to the addition of the filter stage. The percentage reductions in error probability (or error suppression percentages) are shown in Fig. 5.11. It is clearly shown that, in the case of using the strongest filter with $\mathrm{C}=50 \mathrm{fF}$, most of the errors generated in the circuit are eliminated. In general, the percentage of error elimination decreases gradually when scaling the Vdd down to 0.6 V , and then it increases again at lower Vdds values. The trend of these curves correlates with the behaviour of the reliability improvement trajectories shown in Fig. 5.10.

This filtering circuit yields effective results in terms of improving the reliability of the circuit due to its ability to suppress the generated glitches. The cost of these improvements is an increase in the energy consumption of the circuit and a reduction in the performance. In order to validate the proposed


Figure 5.11: Error suppression percentage of c432 circuit vs vdd.
filtering circuit, these penalties are calculated and introduced in details in the next section.

### 5.4.1.1 Evaluation of the Filtering Circuit

The performance reduction due to the addition of the filtering stage to the circuit is calculated and the results are shown in Fig. 5.12. In general, the trend of performance reduction is correlated with the Vdd value of the circuit, where the reduction in performance decreases gradually with the scaling down of the Vdd of the circuit. However, at Vdd $\leqslant 0.8 \mathrm{~V}$, the performance reduction decreases sharply to reach its lowest level of around $2 \%$. Also, by comparing the performance reduction according to filter stage strength, it can be noticed that the stronger filters lead to the highest performance reduction penalty. The curves of the performance of the circuit before and after adding the filter stage are introduced in Appendix C.

The energy consumption of the circuit increases due to the addition of the filtering circuit by various percentages depending on the filter strength and the voltage of the circuit. The percentage increases are shown in Fig. 5.13. The trend here differs from the trend of performance reduction, where the extra energy consumed by the filtering circuit increases with the scaling down of voltage. This is because, when scaling the voltage of the circuit down, less energy is consumed, and so the amount of the energy that is consumed by the filtering circuit becomes relatively large. The curves of the energy consumption of the circuit can be found in Appendix C. However, when the voltage is scaled down to below the subthreshold voltage, the extra energy


Figure 5.12: Effect of the filter stage on the performance of c 432 circuit


Figure 5.13: Effect of the filter stage on the energy consumption of c432 circuit
consumption decreases to reach around $12 \%$. All the filters exhibit the same trend in extra energy consumption, but with different values.

### 5.4.2 Improving the Reliability of the c1908 Circuit

The passive filtering circuit is applied to the c1908 benchmark circuit to improve its reliability. The same procedure as in the previous section is followed, so that filters with different strengths are applied to the circuit, and the weakest is implemented with a $\mathrm{C}=30 \mathrm{fF}$ capacitor, and the strongest with a $\mathrm{C}=50 \mathrm{fF}$ capacitor.


Figure 5.14: Reliability improvement of c1908 circuit that occurred due to adding the passive filter stage, the data of this figure can be found in Table A. 10 .

The reliability of the circuit before and after adding the filtering circuit is shown in Fig. 5.14. The figure shows that the reliability of the circuit is improved remarkably. This improvement correlates significantly with filter strength. It is noteworthy that the reliability of the circuit at Vdd= 0.4 V before adding the filtering circuit was at its lowest level; however, this changes promptly after adding the filtering circuit and circuit reliability increases drastically to reach its highest level. It is noticed that the effectiveness of the filtering circuit is very high at low voltages; however, the reliability of the circuit has been improved significantly at all Vdd values.

The degree of error suppression due to the application of the passive filtering stage to the circuit is calculated and shown in Fig. 5.15. From the results in the last chapter, we found that, in the voltage range $0.6 \mathrm{~V} \leqslant \mathrm{Vdd}<2 \mathrm{~V}$, the error probability of the circuit increases with the scaling down of Vdd of the circuit; however, the percentages of suppressed errors decrease. This means that the filtering circuit has a fixed filtering rate regardless of the voltage that is applied to the circuit. The highest suppression percentage occurred at $\mathrm{Vdd}=0.4 \mathrm{~V}$, which matches the highest error probability of the circuit. In terms of the filter strength, more than the $99.5 \%$ of errors are suppressed as a result of applying the strongest filter stage to the circuit.


Figure 5.15: Error suppression percentage of c1908 circuit vs Vdd.

### 5.4.2.1 Evaluation of Passive Filter Stage

The performance of the circuit is reduced due to the addition of the filtering circuit. This reduction is the cost of improving the reliability of the circuit. We calculated this reduction by finding the extra propagation delay that is added to the circuit with each filter type. These percentage reductions are shown in Fig. 5.16. The biggest reduction in circuit performance occurred due to the use of the filtering circuit with $\mathrm{C}=50 \mathrm{fF}$, with a maximum reduction around $24 \%$ at Vdd $=2 \mathrm{~V}$. However, this reduction decreases with scaling the voltage down, to reach around $7 \%$ at $\mathrm{Vdd}=0.2 \mathrm{~V}$. The other two filtering circuits with $\mathrm{C}=40 \mathrm{fF}$ and $\mathrm{C}=30 \mathrm{fF}$ cause a reduction in performance of the circuit too. The maximum reductions were around $20 \%$ and $15 \%$ at Vdd=2 V respectively. It can be noticed that the influence of the filtering circuit in reducing circuit performance decreases steadily as the Vdd declines from 1.2 V to 0.4 V . The performance of the circuit with and without the filter stage is shown in Appendix C.

The effect of the filtering stage on the energy consumption of the circuit is studied too. This is essential in order to evaluate the use of this stage with large benchmark circuits. The extra energy consumption caused by the filtering stage is calculated and shown in Fig. 5.17. It can be noticed from the figure that the increase in energy consumption depends on the filter strength, where the filtering stage with $\mathrm{C}=50 \mathrm{fF}$ has the highest impact on the energy consumption of the circuit. Moreover, the influence of the filtering circuit on the energy consumption of the circuit increases gradually with the scaling down of the voltage to Vdd=0.35 V. Below this Vdd value the extra energy


Figure 5.16: The effect of the filter stage on the performance of c 1908 circuit


Figure 5.17: The effect of the filter stage on the energy consumption of c 1908 circuit
consumption decreases with reductions in Vdd. The energy consumption of the circuit with and without the filter stage is introduced in Appendix C.

Table 5.2 shows a comparison between the proposed technique and various techniques that are used to mitigate soft errors in combinational circuits. Our technique suffers from a high penalty in the performance compared with other techniques. However, it outperforms these techniques and can provide high average error reductions up to $96.2 \%$ as well as low energy consumption.

Table 5.2: Comparison between the proposed technique and other techniques.

| Used approach | Error <br> reduction | Performance <br> reduction | Energy <br> consumption |
| :---: | :---: | :---: | :---: |
| Proposed <br> (R=10k, C=30fF) | $39.9 \%$ | $11.8 \%$ | $8.6 \%$ |
| Proposed <br> (R=10k, C=40fF) | $74.7 \%$ | $15.3 \%$ | $10.8 \%$ |
| Proposed <br> (R=10k, C=50fF) | $96.2 \%$ | $18.6 \%$ | $13 \%$ |
| Choudhury et al. <br> [21] | $95.5 \%$ | Not reported | $30.6 \%$ |
| Raji et al. <br> $[109]$ | $67.3 \%$ | $3.2 \%$ | Not reported |
| Zhou et al. <br> [140] | $53 \%$ | $5.1 \%$ | $20.9 \%$ |

### 5.5 CONCLUSIONS

By taking a close look at the results, we can develop a good idea of the tradeoff between circuit reliability, energy consumption and performance according to the effect of each filter on each parameter.

The reliability of a circuit can be improved by inserting a filter stage at the end of the circuit paths. The filter stages used in this work can be categorised in two types: active and passive filter stages.

The active filter stage is constructed by changing the size of one or two of the gates located at the end of the path. The one-stage filter is implemented by changing the size of the final stage, where the two-stages filter is implemented by changing the size of the last two stages. The reliability of the circuit is evaluated again after adding the filter stage to the circuit. The new results show a remarkable improvement in circuit reliability, where most of the generated SETs are attenuated, and the error probability is decreased by around $99 \%$ at some Vdd values, which is considered to be a dramatic decrease in error probability. However, the duration of those SETs which were not attenuated decreased by around $50 \%$, which leads to a decreased chance of these SETs being captured by the output flip-flop. By adding this stage to a circuit, the performance of the circuit is reduced by around $3 \%$ to $7 \%$, and the energy consumption of the circuit is increased by different values depending on the filter strength; for the strongest filter it was between $10 \%$ to $65 \%$. These values
represent the worst case; however, they are considered acceptable values in the light of the improvements in reliability.

A passive filter stage is proposed for use with large circuits to reduce the performance and energy consumption penalties produced by using the active filter stage. This filter stage is implemented using passive components; a resistor and capacitor. The results obtained show dramatic improvements in the reliability of the circuits after adding this filter stage. This improvement varies from one filter to another depending on filter strength. This comes as a result of the elimination of errors due to the filter stage, which reached around $99 \%$ in the case of the use of the strongest filter. The passive filter stage is evaluated by studying its effect on circuit parameters such as performance and energy consumption. The results obtained with our technique are compared with results that are reported using various other techniques, they are considered acceptable. However, the level of improvement in reliability that is achieved using our technique is higher than that achieved using the reference technique.

## SIMPLIFICATION APPROACH USING EQUIVALENT GATES FOR THE EVALUATION OF THE RELIABILITY OF LARGE CIRCUITS

In this chapter a simplification technique is proposed to estimate an approximate reliability of complex circuits where the estimation process is timeconsuming. This technique trades-off the accuracy of estimated reliability against estimation time. The results obtained show a high match between the approximate and the exact values of reliability.

### 6.1 INTRODUCTION

The method that is proposed for the evaluation of the reliability of a circuit in this work is based on dividing the problem into two levels of characterization. The first level is involved in representing the cause of the fault and the second with finding the boundaries between error and no-error zones (the CVM). The latter needs a number of simulation runs to be accomplished. For small circuits, these simulations can be completed in a short time, but in the case of large circuits or systems they may take a long time to finish depending on the complexity of the object under test. Thus, it is important to find a technique to approximate the estimated reliability leading to decreased estimation time.

During the calculation of the probability of error of combinational circuits, we noticed that the effect of electrical masking on the propagation of glitches depends on the value of the Vdd applied to the CUT. So, it increases at low voltages due to increases in the inertial delay of the stage in which the glitch propagates. Based on this observation, an approximation approach is proposed which depends on the equivalence of the gates within the same path. The equivalence of gates can be seen in Fig. 6.1, where the error probabilities of individual gates that are chosen from a path are calculated and shown. The figure can be divided into two regions. the first region at very-low voltages $(\mathrm{Vdd}<0.6 \mathrm{~V})$ and the second region at around the nominal voltage of 0.6 $\mathrm{V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$. At very-low voltages, the location of the gate has a big impact on the error probability of that gate. This is because of the attenuation effect
on the generated glitches changes according to the location of the faulty gate, where it decreases in the case of faulty gates located near the primary output. So, gates can be divided into equivalent gates and non-equivalent gates. Equivalent gates are located near to each other and far from the primary output of the circuit, and non-equivalent gates are those located near the primary output and their error probabilities differ from one gate to another. On the other hand, in the voltage range $0.6 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$, all gates have nearly the same impact on the overall error probability of a circuit. Accordingly, the suggested simplification approach is divided into two sub-sections depending on operating region. The first sub-section is for around nominal voltage, and the second is where very low voltages are applied.


Figure 6.1: Average error probability of different gates selected from different locations within a single path circuit.

### 6.2 APPROXIMATE RELIABILITY OF DIFFERENT PATH TOPOLOGIES

The simplification technique is applied to different path topologies which can be found in any multipath circuit. The structure of these topologies helps in understanding the core idea of the simplification technique, and how we can differentiate between equivalent and non-equivalent gates.

### 6.2.1 At Around Nominal Voltage

This section introduces the use of the simplification technique at $0.6 \mathrm{~V} \leqslant \mathrm{Vdd}$ $\leqslant 2 \mathrm{~V}$. In this voltage range, the effect of all gates in a path on the overall error probability is nearly equal. This is because the electrical masking that
causes an attenuation in generated glitches does not change significantly in adjacent gates. This causes a negligible change in the duration of the propagated glitches.

The simplification formula that is proposed to estimate the approximate reliability in this voltage range is:

$$
\begin{equation*}
\mathrm{P}_{\mathrm{err}}=\mathrm{m} * \mathrm{P}_{\mathrm{err}}^{\mathrm{Ij}} \tag{6.1}
\end{equation*}
$$

where $m$ is a constant representing the number of vulnerable gates, and $\mathrm{P}_{\mathrm{err}}^{\mathrm{Ij}}$ is the error probability of a gate ( $j$ ). We recommend choosing a value of $j$ at the end of the path to reduce the number of simulated gates, which leads to significantly reduced simulation time.

The first example is a single path that was introduced in Section 3.4, which is chosen to show how the simplification technique can be used to estimate the approximate reliability of a single path. The block diagram of this path is shown in Fig. 6.2, and it is constructed from various types of gates; NAND, NOR, and NOT.


Figure 6.2: Block diagram of a single path-circuit containing n gates.

The approximate error probability of the circuit is calculated several times using (6.1). Each time, we choose a gate from a different location in the path, where a different value of $j$ is chosen to find the value of $P_{e r r}^{I j}$, and then it is multiplied by the number of vulnerable gates within the path. This enables us to explore the effect of gate location on the accuracy of the approximate reliability. As a result, several approximate error probabilities for the circuit have been obtained, as shown in Fig. 6.3. In this figure, we are interested in the error probability curves from Vdd=0.6 V to 2 V , where all of the approximate error probabilities match the exact one.

The accuracy of the approximate error probabilities for the circuit is calculated by comparing the approximate error probability with the exact one in each case. The error caused by using the approximation formula, which is called the approximation error in the rest of this Chapter, is shown in Table


Figure 6.3: Overall error probability of the path calculated by using both exact and approximate approaches.
6.1. As can be seen in the table, the approximation error caused by using the error probability of the gate No. 121 is the lowest. However, in general, all values of approximation error can be considered to be acceptable.

Table 6.1: Approximation error caused by calculating the overall error probability using the error probability of different gates in the path (\%).

| Vdd (V) | gate 2 | gate 82 | gate 114 | gate 121 |
| :---: | :---: | :---: | :---: | :---: |
| 2.0 | 1.0 | 1.8 | 1.8 | 0.8 |
| 1.8 | 2.23 | 1.5 | 0.2 | 0.4 |
| 1.6 | 1.3 | 1.5 | 1.5 | 1.0 |
| 1.4 | 2.1 | 1.3 | 2.1 | 0.4 |
| 1.2 | 0.2 | 1.3 | 1.3 | 0.3 |
| 1.0 | 0.4 | 2.0 | 1.8 | 0.7 |
| 0.8 | 1.3 | 1.3 | 2.3 | 1.3 |
| 0.6 | 3.5 | 2.5 | 5.5 | 3.5 |
| Avg. | 1.5 | 1.7 | 2.1 | 1.1 |

The approximate reliability of the path has been obtained by using the approximate error probability of the circuit calculated using the error probability of the gate No. 121 as shown in Fig. 6.4. It can be seen from the figure that the approximate reliability and the exact reliability of the path are very close to each other.

The second example is another type of path topology, which includes divergent paths. This topology is common in multipath circuits, where a certain


Figure 6.4: Approximate and exact reliability for the single path with the vdd range $0.6 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$.
gate drives more than one fan-out. The structure of this kind of path is shown in Fig. 6.5.


Figure 6.5: Block diagram of a circuit with forked path topology.

In order to estimate the approximate reliability of this topology, the circuit is divided into three sub-paths. The gates in each sub-path contribute to the overall error probability to unique extents which may differ from the gates in the other sub-paths depending on the location and the number of these gates. In terms of error probability, sub-path1 has unique characteristics compared with the other sub-paths, where any glitch generated in this sub-path may propagate to both output terminals outl and out2. This leads to an increased error probability for any gate in this sub-path. However, any glitch generated in sub-path2 or sub-path3 may propagate to either outl or out2. As a result
of this, the error zone that determines the error probability of any gate in sub-path1 is wider than the corresponding zones in sub-path2 or sub-path3, as can be seen in Fig. 6.6. The expansion that has occurred in the error zone of sub-path 1 is caused by the difference between the propagation times of sub-path2 and sub-path3. So, the arrival of the glitch at the output terminals at different times increases the probability of that glitch being latched by the output flip-flop. This difference in the error zones affects the error probabilities of these sub-paths, as can be seen in Fig. 6.7. Because of the similarity in the error probabilities of the gates of sub-path2 and sub-path3, the approximate error probability of those two sub-paths can be calculated using the error probability of any gate from either of them and aggregating them to both sub-paths. This assumption is adopted here in calculating the approximate error probability of the whole path circuit using the least possible numbers of simulated gates.


Figure 6.6: Error zones of different gates chosen from different sub-paths.
To estimate the approximate reliability of this kind of path, we have applied the same simplification formula in 6.1 to just two sub-paths: sub-path1, and either sub-path2 or sub-path3. So, for these two sub-paths, the same procedure as in the first example has been followed. The approximate error probability of sub-path $1, \mathrm{P}_{\text {err1 }}$, is calculated by applying 6.1 to this sub-path. One gate is chosen at the end of the sub-path to reduce the simulation time, and the error probability of that gate is multiplied by the number of the vulnerable gates in sub-path1. As the gates of the two sub-paths (sub-path2,


Figure 6.7: Error probability caused by different gates located in different sub-paths.
and sub-path3) are equivalent to each other, so one gate from one sub-path is chosen to calculate its error probability, then this value is multiplied by the number of the vulnerable gates on both sub-paths. $P_{\text {err2 }}$ represents the error probability of sub-path2 and sub-path3. The overall error probability is calculated from the summation of these two error probabilities $P_{\text {err }}=P_{\text {err } 1}+$ $\mathrm{P}_{\mathrm{err} 2}$.


Figure 6.8: Approximate and exact reliability of the divergent path for the $V$ dd range: $0.6 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$.

Both input values of 0 and 1 are applied to the path and the overall error probability is calculated as the average value of the two error probabilities obtained. Then the approximate reliability of this topology is calculated as shown in Fig. 6.8. The exact reliability is also calculated in order to compare the two trends. The approximate reliability matches the exact one.

The difference in propagation delay of sub-path2 and sub-path3 can be reduced by reducing the difference between the lengths of those two subpaths. Also, it can be reduced by adding a filter or a buffer stage at the end of short paths to add the required delay so that both signals arrive at the output terminals at the same time.

The third example is a topology with reconvergent paths, and the structure of this topology can be seen in Fig. 6.9.


Figure 6.9: Block diagram of a reconvergent topology path circuit.
In order to apply our simplification approach to this topology, it is divided into four sub-paths, sub-path1, sub-path2, sub-path3, and sub-path4. Any glitch generated in sub-path 1 has three different scenarios in propagating to the primary output. The first is that this glitch may propagate through instance $I_{j+1}$ and be masked at instance $I_{j+2}$ to arrive at the output terminal through sub-path2. The second scenario is that it may propagate through instance $I_{j+2}$ and be masked at $I_{j+1}$ to arrive at the output terminal through sub-path3. The third scenario is that it may split into two glitches, and those propagate through both sub-paths (sub-path2 and sub-path3). In this case, the two propagated glitches recombine again at the fan-in instance $I_{\mathfrak{m}+1}$, and the new glitch may be wider or narrower than the original glitch depending on the arriving time and the type of recombining instance. The arrival time is related to the number of instances in sub-path2 and sub-path3, and the type of instance depends on the circuit structure. The recombination cases of the split glitch can be seen in Fig. 6.10.

The gates of each sub-path contribute to the overall error probability by approximately the same values. So, the error probability of each sub-path is calculated using (6.1) by simulating one gate from each sub-path to calcu-


Figure 6.10: The possible recombination cases of tow glitches propagated through two different sub-paths.
late its error probability and then multiplying this value by the number of vulnerable gates in that sub-path. The error probability of sub-path1 is $\mathrm{P}_{\text {err1 }}$. The approximate error probability of sub-path2 and sub-path3, $P_{\text {err2 }}$, is found using the same process as in the previous example. The error probability of sub-path4 $\mathrm{P}_{\text {err4 }}$ is calculated by calculating the error probability of a chosen gate and multiplying it by the number of vulnerable gates.

The approximate error probability of each sub-path is calculated for the two input values of 0 and 1 . The summation of the average of these error probabilities has been found, which is the approximate overall error probability. By using the approximate overall error probability, the approximate reliability of this topology path is calculated and shown against the exact reliability in Fig. 6.11. As seen in the figure, the approximate reliability trajectory is very close to the exact one.

### 6.2.2 Including Very Low Voltages

In this section, another simplification formula is introduced, which is valid at the nominal voltage and very low voltages $(0.2 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V})$. This formula is proposed based on the behaviour of the gates at very-low voltages, as can be seen in Fig. 6.1. In this figure, the error probability of prior stages within a


Figure 6.11: Approximate and exact reliability of the reconvergent path for the Vdd range: $0.6 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$.
path is negligible at very low voltages ( $\mathrm{Vdd} \leqslant 0.4 \mathrm{~V}$ ) because of the attenuation effect. However, in the case of stages that are close to the output terminal, the duration of generated glitches is quite wide, and they have a tremendous effect on the overall error probability. Therefore, the last six or five gates in a path should be included in the formula that is suggested to approximate the reliability of digital circuits at very low voltages. This formula is introduced in (6.2).

$$
\begin{equation*}
P_{e r r}=m * P_{e r r}^{I_{j}}+\sum_{k=n-4}^{n} P_{e r r}^{I_{k}} \tag{6.2}
\end{equation*}
$$

where n is the number of all vulnerable gates within a path, and m is the number of vulnerable gates located away from the output terminal (equivalent gates). We adopt a value of $m=n-5 . P_{e r r}^{\mathrm{I}_{\mathrm{j}}}$ is the error probability of a gate that is chosen from the equivalent gates. $\mathrm{P}_{\text {err }}^{\mathrm{I}_{\mathrm{k}}}$ is the error probability of the last five gates connected to the primary output (the non-equivalent gates), $k=n-4$, $\mathrm{n}-3, \mathrm{n}-2, \mathrm{n}-1$ and n .
(6.2) is constructed using two terms, the first for the equivalent gates (the multiplication part), and the other for the non-equivalent gates (the summation part). The accuracy of values of approximate reliability derived
using this formula can be adjusted according to requirements. So, if accuracy is more important, we need to increase the number of gates that are used in the summation part to include more gates from the non-equivalent gates. On the other hand, to reduce the estimation time, the number of gates that are used in the multiplication part should be increased.

The same examples of topologies that were used in the previous section have been also used in this section.

The first example is the single-path circuit illustrated in Fig. 6.2 which is used to evaluate approximate reliability. A gate from the path is chosen to calculate its error probability. This gate represents gate $j$ in (6.2). In this case, the path is constructed using 125 gates, of which there are 62 vulnerable gates, so $\mathrm{n}=62$ and $\mathrm{m}=57$. The error probability of the last five gates in the path is calculated and included in the summation part of the formula, and those for the rest of the vulnerable gates are used in the multiplication part.

The approximate reliability of the path is calculated and shown against the exact value of reliability in Fig. 6.12. The figure shows that the approximated reliability trajectory matches the exact one, with only minor deviation.


Figure 6.12: Approximate and exact reliability of the single path at the $\mathrm{V} d \mathrm{~d}$ range from 0.2 V to 2 V .

The second example is the divergent path that is illustrated in Fig. 6.5. The same procedure as in the previous section is followed for this type of path, and so it is divided into three sub-paths: sub-path1, sub-path2 and sub-path3.


Figure 6.13: Approximate and exact reliability of the divergent path in the Vdd range $0.2 \mathrm{~V} \geqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$.

The approximate error probability of sub-path 1 is found by using the first part of (6.2) (the multiplication part) because this path is not connected to the output terminals directly and all gates on this sub-path are equivalent. The error probability of one gate in the middle of the path has been calculated and multiplied by the number of vulnerable gates on sub-path1. However, the approximate error probability of the other two sub-paths is calculated using both terms of (6.2) ( multiplication and summation). Due to the equivalence of the structure of the two sub-paths, it is sufficient to choose one gate from one sub-path and to use aggregation for the two sub-paths. So, one gate has been chosen from sub-path2 whose error probability is calculated and multiplied by the number of vulnerable gates in both sub-paths. The last five vulnerable gates within sub-path2 have been simulated to find their error probability and applied to the second part of (6.2).

The approximate reliability of this topology is compared to the exact one in Fig. 6.13. The figure shows high matching between the approximate and exact reliability trajectories.

The third example is the reconvergent topology that is shown in Fig. 6.9. In this example, the approximate error probability of sub-path4 is calculated using both terms of (6.2). However, the approximate error probability of the
three other sub-paths is calculated by using the multiplication part of the formula.


Figure 6.14: Approximate and exact reliability of the reconvergent path in the Vdd range: $0.2 \mathrm{~V} \geqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$.

The approximate reliability of this path is found and shown in Fig. 6.14. The figure shows that there is a high similarity between the exact and approximate reliability trajectories.

### 6.3 ESTIMATING THE APPROXIMATE RELIABILITY OF COMPLETE CIRCUITS

In this section, we show how the simplification approach can be applied to complete circuits to find their approximate reliability.

In the case of evaluating the approximate reliability of paths, we were interested in the equivalent and non-equivalent gates. This concept can also be applied to complete circuits provided that equivalent gates are found. This can be achieved by extracting the sensitive paths of the whole circuit. These paths are constructed using a group of sensitive gates which enable any generated glitch to propagate and arrive at the primary output of the circuit without any logical masking. In terms of sensitivity, logical gates can be categorised into two types. The first type of gates are always sensitive regardless of their input value, such as NOT, XOR and XNOR. The second
type have sensitivity depending on their input values, such as NAND, NOR, OR and AND.

The flowchart of the process used to calculate the approximate reliability of a combinational circuit is shown in Fig. 6.16, and the pseudocode of this process is introduced in Algorithm 6.1. It starts by applying an input combination to the circuit as initial values of their input terminals. These values are propagated through the whole circuit. Then, by using forward tracking, all the sensitive gates and their sensitive inputs are recognised and marked. By using backwards-traversing search, the sensitive paths are built starting from the primary output gates. Any sensitive path ends when a non-sensitive gate is found or if a primary input terminal of the circuit is arrived at. Then, the sensitive paths obtained are categorised according to type of path topology in order to find the equivalent gates and the equivalence between sub-paths. It is noticed that most of the paths have a divergent path topology, with differences in the numbers of forked paths. Vulnerable gates are found and categorised into groups depending on the contribution of each gate to the overall error probability of the circuit. So, by knowing the number of times the gate has appeared in the sensitive path list, we can know how much that gate contributes to the overall error probability. For example, consider the path topology shown in Fig. 6.15(a), and the extracted sensitive paths of this topology shown in Fig. 6.15(b). The gates are categorised into four different groups. Group 1 represents the gates that have the highest impact on the error probability of the circuit, due to their existence in all the sensitive paths. Group 2 contains gates which appear in three sensitive paths. Group 3 contains gates appearing in two sensitive paths, and group 4 contains gates appearing just once in the sensitive paths.

Any vulnerable gate is not included in the sensitive paths, but is discarded, because any glitch generated in that gate will be blocked by the logical masking effect. Then, from each group, a gate is chosen to calculate its error probability and this is multiplied by the number of vulnerable gates in that group.

A subcircuit that includes the chosen gates is selected and simulated. Simulating a small subcircuit rather than the whole circuit speeds up the simulation process dramatically.


Figure 6.15: Sensitive paths extracted from a path topology to explain the method used to categorise the equivalent gates.

### 6.3.1 Around Nominal Voltage

Two benchmark circuits are chosen as examples to evaluate their approximate reliability. These two circuits are c432 and c1908.

The first example is the c432 benchmark circuit, and its specifications are introduced in Table 4.1. To apply the simplification technique to this circuit, the sensitive paths have been extracted using Algorithm 6.1 for a specific input combination. These paths are categorised depending on their topology. Then the vulnerable gates are categorized according to their contribution to the overall error probability of the circuit. By using (6.1) the approximate error probability of the circuit has been calculated. This process is repeated for different input combinations which are selected randomly, and different values of circuit reliability have been obtained. The average of these values is found and shown in Fig .6.17 along with the exact reliability value. As can be seen in the figure, the approximate reliability is very accurate compared with the exact one.

The same procedure as used in Section 6.2 is followed. So, the approximate reliability is found in both cases of around the nominal voltage and around the whole voltages range.

The second example is the c1908 benchmark circuit, and the specifications of this circuit can be found in Table 4.1. The sensitive paths of the circuit are


Figure 6.16: The flowchart of the process that is followed to calculate the approximate reliability of a combinational circuit.

```
Algorithm 6.1 Finding the sensitive paths and vulnerable gates of large
circuits to apply the simplification approach.
```

```
    Enter the input values
```

    Enter the input values
                            \triangleright Forward simulation performed in linear time
                            \triangleright Forward simulation performed in linear time
    Propagate all the signals through the circuit
    Propagate all the signals through the circuit
            \trianglerightcheck the sensitivity of each gate and each gate's input
            \trianglerightcheck the sensitivity of each gate and each gate's input
    for Each gate i in the netlist do
    for Each gate i in the netlist do
        Determine the type of the gate
        Determine the type of the gate
        if The gate is NOT, XOR or XNOR then
        if The gate is NOT, XOR or XNOR then
            Mark the gate and its input as sensitive
            Mark the gate and its input as sensitive
    else
    else
            Test the gate if it is sensitive or not
            Test the gate if it is sensitive or not
            if The gate is sensitive then
            if The gate is sensitive then
                Determine which input is sensitive
                Determine which input is sensitive
                Mark the gate as a sensitive gate
                Mark the gate as a sensitive gate
                Mark the sensitive input
                Mark the sensitive input
            end if
            end if
        end if
        end if
        Save all the sensitive gates and nodes
        Save all the sensitive gates and nodes
    end for
    end for
                    \triangleright Backward traversing to build the sensitive paths
                    \triangleright Backward traversing to build the sensitive paths
    for Each output gate on the circuit netlists do
    for Each output gate on the circuit netlists do
    if This gate is marked as sensitive then
    if This gate is marked as sensitive then
        Add the gate to the sensitive path
        Add the gate to the sensitive path
        Traverse backward and check all gates
        Traverse backward and check all gates
        Mark all visited nodes
        Mark all visited nodes
            Add any sensitive gate to the sensitive path
            Add any sensitive gate to the sensitive path
            if Not sensitive gate is found or the input terminal is
            if Not sensitive gate is found or the input terminal is
    arrived then
    arrived then
                Stop and start over from unvisited gate
                Stop and start over from unvisited gate
            end if
            end if
        end if
        end if
    end for
    end for
        \triangleright Find the equivalence between gates and apply the approximation
        \triangleright Find the equivalence between gates and apply the approximation
    formula
    formula
    for All the sensitive paths do
    for All the sensitive paths do
    Find the equivalent gates
    Find the equivalent gates
    Find the vulnerable gates and categorise them to different groups
    Find the vulnerable gates and categorise them to different groups
    Apply the formula to find the error probability of the circuit
    Apply the formula to find the error probability of the circuit
    end for
    ```
    end for
```

obtained and the vulnerable gates are categorised using Algorithm 6.1. Due to the complexity of the circuit, the number of forked paths was higher than in the circuit in the previous example. This leads to an increase in the number of gates chosen to represent the vulnerable gates in the circuit. By using


Figure 6.17: The approximate reliability and the exact reliability of the circuit c432 in the range $0.6 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$, it shows a minor contrast between two trajectory.
(6.1) the approximate error probability of the circuit has been calculated. For different input combinations, different approximate values of circuit reliability are obtained. The average of these values is found and compared with the exact reliability value in Fig. 6.18. The approximate reliability shows high accuracy compared with the exact reliability.

### 6.3.2 Including Very-Low Voltage

In this section, the simplification formula in (6.2) is used to evaluate the approximate reliability of the previous two circuits. In this case, we need to include more gates from the non-equivalent gates for the simplification formula for the sub-paths that are connected to primary outputs.

The first example, the approximate reliability of the circuit c432 is evaluated. The same procedure that was followed in the previous section is applied to this case. However, for the sub-paths that are connected to the primary outputs, the error probabilities of at least five vulnerable gates is calculated and included in the error probability calculation formula, as is done in Section 6.2.2.


Figure 6.18: Approximate and exact reliability of circuit c1908 in the range: 0.6 $\mathrm{V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$, showing a minor contrast between the two trajectories.

The approximate reliability of the circuit is calculated by using the average of the error probabilities which are obtained for different input combinations. Fig. 6.19 shows the approximate reliability and the exact reliability, and it can be seen that both trajectories are very close to each other.

Due to the random selection of a group of input combinations to calculate the approximate reliability of the circuit, we need to estimate the convergence between the values of reliability obtained to stop the calculation process. The same procedure is used as explained in Chapter 4, and so the standard error metric is used to calculate the level of convergence. The convergence between the results is shown in Fig. 6.20. As can be seen in the figure, convergence between the results obtained first appeared after applying 10 input combinations. The estimation process is stopped after applying 15 input combinations to the circuit, where an acceptable convergence between the results has occurred.

The second example is evaluating the approximate reliability of circuit c1908. The same procedure is followed as for c432 circuit, but the number of gates chosen is larger in this case due to the length of some paths and the complexity of the circuit. The error probabilities of the last five vulnerable gates are included in the calculation of the approximate error probability of the circuit in the case of paths that are connected to primary inputs. The


Figure 6.19: Approximate and exact reliability of circuit c432 in the range: 0.2 $\mathrm{V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$, showing a minor contrast between the two trajectories.


Figure 6.20: Standard error calculated for the error probabilities of different input combinations of circuit c432, showing a convergence in the results after 12 input combinations.
(6.2) is used to calculate the approximate error probability of the circuit. The approximate reliability of the circuit is calculated and shown with the exact one in Fig. 6.21. The figure shows a high similarity between both reliability trajectories.

Due to the use of various input combinations in evaluating the reliability of the circuit, the convergence between the estimated reliabilities is calculated by using the same procedure as in the last example. So, the standard error


Figure 6.21: Approximate and exact reliability of circuit c1908 in the range: 0.2 $\mathrm{V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$, it shows a minor contrast between two trajectory.
metric is calculated for all obtained reliabilities and the results are shown in Fig. 6.22. The figure shows that convergence between the obtained results starts after applying 10 input combinations to the circuit. The estimation process is stopped after obtaining the error probability of the circuit for 15 input combinations.


Figure 6.22: Standard error calculated for the error probabilities of different input combinations of circuit c1908, showing a convergence in the results after 10 input combinations.

### 6.4 EVALUATION OF THE SIMPLIFICATION APPROACH

Table 6.2: Reduction in simulation time and approximation error obtained from applying the approximation approach at the range ( $0.6 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$ ).

| Circuit type | No. of gates | Time <br> reduction | Approximation <br> error |
| :---: | :---: | :---: | :---: |
| Single path | 125 | 93 x | $3.5 \%$ |
| Divergent path | 52 | 21 x | $2.3 \%$ |
| Reconvergent path | 72 | 19 x | $3.1 \%$ |
| c432 | 274 | 60 x | $1.3 \%$ |
| c1908 | 1211 | 173 x | $3.5 \%$ |

The use of the proposed simplification technique for evaluating the approximate reliability of combinational circuits leads dramatically reduced simulation time. However, this reduction is associated with an imprecision in the evaluation of reliability, which is called in this work the approximation error. The reduction in simulation time and approximation error are calculated at the nominal voltage range for all the previous examples and the results are shown in Table 6.2. The approximate error in this table is calculated as the average value of all the approximate errors that are calculated at different Vdd values. As can be seen in the table, with increases in the number of gates in a circuit, the reduction in simulation time increases. So, this reduction has an exponential relationship with the number of gates within a circuit. However, in the case of divergent and reconvergent path topologies, the time reductions were 21 x and 19 x respectively because of the difference between the topologies.

Due to the inclusion of more gates in the simplification formula that has been suggested in order to obtain the approximate reliability in the low voltage range, the simulation time increases compared with the other formula. This is also applicable to the approximation error, which increased too. The reductions in simulation time and approximate error percentages for all previous examples can be found in Table 6.3. In general, the use of the simplification technique in the voltages range from 0.2 V to 2 V achieves a noticeable acceleration in the evaluation process, with an acceptable reduction in the accuracy of the results.

Table 6.3: Percentage error and time saved obtained from applying the approximation approach at the Vdd range ( $0.2 \mathrm{~V} \leqslant \mathrm{Vdd} \leqslant 2 \mathrm{~V}$ ).

| Circuit type | No. of gates | Time <br> reduction | Approximation <br> error |
| :---: | :---: | :---: | :---: |
| Single path | 125 | 30 x | $8.1 \%$ |
| Divergent path | 52 | 9 x | $5.1 \%$ |
| Reconvergent path | 72 | 12 X | $4.7 \%$ |
| c432 | 274 | 24 x | $3.2 \%$ |
| c1908 | 1211 | 74 x | $7.4 \%$ |

## 6.5 conclusions

In this chapter, a simplification approach is introduced. This approach is proposed to tackle the problem of time consumption when evaluating the reliability of large circuits. The proposed approach relies on dividing the gates of any combinational circuit into two groups: equivalent and non-equivalent gates. The equivalent gates are those which contribute to the overall error probability of the circuit by nearly the same value. The equivalence property of the gates depends on two main factors: the voltage applied to the circuit and the location of the gate. At the nominal voltage, all gates within a path are equivalent. However, at low voltages, the equivalence between gates within a path decreases in the gates located near the output terminal of the circuit. To show how this approach is used, the operating voltage of a combinational circuit is divided into two ranges: around the nominal voltage range and in the whole voltage range where very low voltages are included. These ranges are proposed due to the difference in the behaviour of the logic gates within the same path in the two ranges. The first voltage range is around the nominal voltage where all gates are equivalent in terms of their contribution to the overall error probability of the circuit. So, the circuit reliability can be evaluated by simulating a few gates which represent all the vulnerable gates in the circuit. By using a simple formula, the error probabilities of the chosen gates are multiplied by the number of the vulnerable gates. The second range is where very low voltages are included in the evaluation range. At this range, the error probabilities of the gates located near the primary output of a circuit are included in the formula that is used to evaluate the reliability of the circuit. This is because their effect is different from that of the other gates within the same path.

This approach is applied with different path topologies and complete circuits. The results show that a dramatic decrease in reliability estimation time is traded-off with the accuracy of approximate reliability.

## CONCLUSIONS AND FUTURE WORK

### 7.1 SUMMARY AND CONCLUSION

Shrinking technology size is providing an opportunity for embedding higher numbers of transistors on a single integrated circuit (IC) chip. It also is the main reason for the decreasing the voltage applied to these ICs. On the other hand, the level of flux neutron particles at ground level is constant. This leads to an increasing need to deal with reliability issues in these circuits. The present thesis addresses two main concerns related the reliability of combinational circuits, which are analysing and improving reliability. In terms of reliability analysis, a new approach is proposed for the evaluation and analysis of the reliability of a circuit along with its performance and energy consumption. In terms of reliability improvement, a new technique is suggested in which standard cells are used.

A new method of deriving the reliability metric for digital circuits has been introduced in this work. The reliability metric is derived without expensive Monte Carlo simulations or physical experiments; however, the use of an analytical method makes its inclusion in ECAD logic synthesis tools possible. This method can be used prior to circuit fabrication and any reliability issues can be discussed in advance and rectified at an early stage of implementation. The core idea of this method is to divide the evaluation process into two levels of characterisations: a stochastic library-specific characterisation of the interference and design-specific characterisation. The former characterisation is fixed and can be applied to different designs which is moved into the platform development stage. Design-specific characterisation represents the parameters of electrical effects registered at the output of the design under test. It is specific to the design and can be obtained by design companies using a number of simulation runs to derive the reliability of their designs.

In this work, the characterisation of interference is represented by the PDF of neutron energy and a fault model which is fixed and used with all combinational circuits. Design-specific characterisation employs the critical values of the SETs that have arrived at the primary output of the CUT which
are related to the circuit whose reliability is being assessed. The transient pulse that results from the interaction between a neutron particle and a transistor in the CUT is modelled using a bias-dependent current source. The most important feature of this model is the dependence of the generated transient pulse on the voltage and bias of the struck node. This model is used with Cadence simulation tool to inject various SETS with different durations according to different values of LETS.

The first set results obtained of the proposed method demonstrate a complex trade-off between the three metrics of reliability, energy consumption and performance. In this work, we evaluate the reliability metric of a circuit at different Vdd values, and then the energy consumption and frequency are determined according to these Vdd values. The energy consumption in digital circuits can be divided into dynamic and leakage energy [115]. The switching activity of a digital circuit during the performance of a computation task is the main reason for the dissipation of dynamic energy. However, the energy that is consumed by a digital circuit when it remains connected to the voltage supply whether or not it is performing useful computation is called leakage energy. In the latest technologies, leakage energy plays a major role in determining energy consumption. Several solutions have been suggested to reduce the energy consumption of digital circuits. One of the most commonly used techniques is dynamic voltage frequency scaling (DVFS), which addresses this problem by scaling down the Vdd applied to the circuit due to the quadratic dependence of dynamic energy consumption on Vdd. However, reducing Vdd causes a reduction in the circuit's frequency, and so it takes longer to perform a given task. Consequently, total energy consumption increases due to the increase in leakage energy. In this work, the total energy consumption (dynamic and static) is calculated according to each value of Vdd applied to the circuit. In general, these results show that, above the nominal voltage of $1-1.2 \mathrm{~V}$, the reliability metric of a circuit has improved slightly at the expense of a considerable increase in the energy consumption. Below the nominal voltage where the circuit optimization is based on power and performance trade-off works, the reliability of the circuit decreases dramatically to reach its lowest value at a certain value of vdd. This region is also known as the low-energy corner, where both reliability and performance drop rapidly, resulting in a recommendation to avoid this zone. At very low voltages the reliability of the circuit improves again to reach the highest level. This improvement can be explained by the fact that, at these values of Vdd the gates act as filters for
narrow SETs, leading to decreases in the error probability in the circuit. This is a promising result for extremely low-power designs.

The results obtained in this work reveal that different factors impact on the reliability of a circuit. The first factor is the Vdd applied to the circuit, It has been found that, in the case of high Vdd, the reliability of the circuit is high and it decreases when Vdd is scaled down. This is because in our analysis the rate of neutron particles per clock cycle is calculated. So, in the case of operations with short clock periods (high voltages), the circuit receives a lower number of neutron hits than during long clock period operations (low voltages).

The second factor is the structure of combinational circuits, including the number of gates, the length of paths, and the number and type of output gates. Circuits with high numbers of gates are usually less reliable than those with fewer gates. This is because more gates means more sensitive nodes and, as a result, more glitches are generated. Also, with high numbers of gates, there are high numbers of branches. This increases the chance of propagating the generated glitches to several paths, which leads to an increasing probability of errors. Circuits with long paths are more reliable than those with short paths, especially at low voltages. This can be attributed to the electrical masking effect which increases in long paths. Increasing the number of the outputs of a circuit has a negative impact on its reliability. This is because large numbers of output gates in a circuit lead to an increasing probability of propagating the generated SETs to the output flip-flops. As a result of this, the probability of error increases. The type of output gate has an impact on the reliability of a circuit. We found that, when implementing a circuit with large gates such as XOR and XNOR gates at the output terminal blocks, most of the propagated SETs are masked, which increases the reliability of the circuit.

The third factor is the combinational input, which has a direct relationship with the vulnerability and the logical masking effect of gates. In this study we took into account the SETs generated on NMOS transistors only. So, specific input values make a gate vulnerable; for example, the NOT gate does not generate an SET if its input is at logic 1. The logical masking effect depends on the type of gate, so it may occur in some gates and not in others. Even in those gates that may be affected by the logical masking effect, this depends on the input values. In this work, we applied different combinational inputs to the circuits under test, and these inputs were randomly chosen. The differences between the results obtained are obvious; however, in our case the average
of the levels of reliability obtained are calculated and used to represent the reliability of the circuit.

Designing ultra-low power circuits can have a positive impact on the reliability of these circuits with further impacts on energy consumption. In this type of circuit, the operating clock increases with decreasing supply voltage at a rate higher than the increase in SET duration [17]. Consequently, more SETs are attenuated, which improves reliability. Therefore, ultra-low power circuits may be an attractive solution for reducing energy consumption and increasing reliability.

The reliability metric improved dramatically at the expense of a minor increase in energy consumption and a decrease in performance. This reliability improvement is obtained by adding slow stages at the output terminals to filter the propagated glitches. Two types of filter stage are suggested in this work: active filter and passive filter stages. The active filter stage is implemented using a logic gate and is more effective in long paths rather than short paths, due to the accumulation effect of the energy consumption and the propagation delay. The passive filter stage is implemented by using a resistor and capacitor and can be used with both long- and short-path circuits.

The problem of time-consuming simulations that are needed to evaluate the reliability of large circuits has been solved by using a simplification technique. The results that are obtained by using this technique are evaluated and compared with the exact results. The comparison showed a high accuracy of the approximate reliability obtained using the simplification technique and a dramatic reduction in the simulation time. This technique is based on the equivalence of the function of gates within the path, and equivalence between paths. So, in order to estimate a circuit's reliability it is sufficient to simulate a segment of the CUT that contains several gates which are equivalent to all vulnerable gates in the circuit. An algorithm is implemented for application to large circuits in order to choose these gates based on their location and the structure of the circuit.

### 7.2 CRITICAL REVIEW AND FUTURE WORK

The objectives of this research include opening a new horizon in low-energy and high reliable design. Therefore, many research directions can be indicated from this work to analyse and study reliability of combinational circuits. The
limitations of this work and directions for future research are discussed as follows:
-Time-consuming analogue simulation: a limitation of the proposed technique is that it depends on the complexity of the CUT. In the case of large circuits, a large number of simulations runs is required in order to estimate reliability. This limitation is solved by proposing a simplification technique which leads to dramatic reductions in estimation time at the expense of accuracy. This limitation can also be solved by proposing a technique which can work on two levels of abstraction, where the circuit level is used in generating an SET due to a particle hit, and the gate level is used to propagate that SET and to observe its duration at the output terminals.
-Impact of variabilities occurring in the field: the continuous scaling of complementary metal oxide semiconductor (CMOS) technology increases the vulnerability of digital circuits to ageing mechanisms. An ageing mechanism such as negative-bias temperature-instability (NBTI) has a negative impact on the susceptibility of these circuits to soft errors. This can be attributed to the fact that NBTI increases the absolute threshold voltage of PMOS transistors by more than 50 mV in ten years [114]. Also, it reduces the critical charge of a node by reducing the restoring current of the pull-up network [113]. In this work, we derive the reliability metric in terms of generating an SET without taking ageing mechanisms into account. More research can be launched to analyse and derive the reliability metric of a circuit by combining the effect of neutron particles with one or more ageing mechanism. This can be done using the proposed method if a stochastic characterisation of the mechanism under study is provided.
-Subthreshold logic: circuits need to be carefully designed in order to operate in subthreshold logic. In such a region of operation, the integrity of digital signals degrades dramatically because of the indifference between active and leakage currents. Also, variations in the process and supply voltage become more significant and impact on the performance of the circuit. According to our findings, the reliability of a combinational circuit improves dramatically in this operating region; however, designing such a circuit to operate in this region is still a challenging topic.

The three-way trade-off explore extends the traditional concept of dynamic voltage-frequency scaling (DVFS) by adding the reliability metric. This will help in the selection of the operating point for circuits regarding their reliability. It can also facilitate the emergence of a new generation of power management
designs which controls the reliability dynamically, power or energy reliability management; PRM or ERM.

The reliability metric is derived without extremely expensive Monte Carlo simulations or physical experiments, which makes its inclusion into ECAD logic synthesis tools possible. This method may become an enabler in achieving the reliability closure for a system at an early design stage, similar to how the timing closure is addressed.

## Part II

Thesis Appendices

## RELIABILITY AND PROBABILITY OF ERRORS DATA

Table A.1: Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of the chain of inverters circuit.

| Vdd <br> $(\mathrm{V})$ | Frequency <br> $(\mathrm{MHz})$ | Energy (J) | Error <br> probability | Reliability |
| :---: | :---: | :---: | :---: | :---: |
| 2.0 | 436.87 | $2.55 \mathrm{E}-12$ | $1.63 \mathrm{E}-10$ | $1-(1.63 \mathrm{E}-10)$ |
| 1.8 | 413.56 | $2.00 \mathrm{E}-12$ | $1.70 \mathrm{E}-10$ | $1-(1.70 \mathrm{E}-10)$ |
| 1.6 | 384.32 | $1.55 \mathrm{E}-12$ | $1.78 \mathrm{E}-10$ | $1-(1.78 \mathrm{E}-10)$ |
| 1.4 | 347.95 | $1.16 \mathrm{E}-12$ | $1.88 \mathrm{E}-10$ | $1-(1.88 \mathrm{E}-10)$ |
| 1.2 | 302.39 | $8.40 \mathrm{E}-13$ | $2.01 \mathrm{E}-10$ | $1-(2.01 \mathrm{E}-10)$ |
| 1.0 | 246.43 | $5.72 \mathrm{E}-13$ | $2.20 \mathrm{E}-10$ | $1-(2.20 \mathrm{E}-10)$ |
| 0.8 | 178.79 | $3.62 \mathrm{E}-13$ | $2.47 \mathrm{E}-10$ | $1-(2.47 \mathrm{E}-10)$ |
| 0.6 | 101.20 | $2.01 \mathrm{E}-13$ | $2.99 \mathrm{E}-10$ | $1-(2.99 \mathrm{E}-10)$ |
| 0.4 | 26.06 | $9.11 \mathrm{E}-14$ | $1.69 \mathrm{E}-10$ | $1-(1.69 \mathrm{E}-10)$ |
| 0.35 | 13.95 | $7.25 \mathrm{E}-14$ | $1.12 \mathrm{E}-10$ | $1-(1.12 \mathrm{E}-10)$ |
| 0.3 | 6.21 | $5.97 \mathrm{E}-14$ | $2.28 \mathrm{E}-11$ | $1-(2.28 \mathrm{E}-11)$ |
| 0.2 | 0.82 | $6.90 \mathrm{E}-14$ | $4.55 \mathrm{E}-11$ | $1-(4.55 \mathrm{E}-11)$ |

Table A.2: Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of the non-uniform path circuit.

| Vdd <br> $(\mathrm{V})$ | Frequency <br> $(\mathrm{MHz})$ | Energy (J) | Error <br> probability | Reliability |
| :---: | :---: | :---: | :---: | :---: |
| 2.0 | 397.30 | $2.20 \mathrm{E}-12$ | $9.80 \mathrm{E}-11$ | $1-(9.80 \mathrm{E}-11)$ |
| 1.8 | 380.66 | $1.74 \mathrm{E}-12$ | $1.03 \mathrm{E}-10$ | $1-(1.03 \mathrm{E}-10)$ |
| 1.6 | 359.20 | $1.35 \mathrm{E}-12$ | $1.08 \mathrm{E}-10$ | $1-(1.08 \mathrm{E}-10)$ |
| 1.4 | 331.02 | $1.01 \mathrm{E}-12$ | $1.14 \mathrm{E}-10$ | $1-(1.14 \mathrm{E}-10)$ |
| 1.2 | 294.38 | $7.23 \mathrm{E}-13$ | $1.22 \mathrm{E}-10$ | $1-(1.22 \mathrm{E}-10)$ |
| 1.0 | 246.43 | $4.92 \mathrm{E}-13$ | $1.33 \mathrm{E}-10$ | $1-(1.33 \mathrm{E}-10)$ |
| 0.8 | 185.08 | $3.10 \mathrm{E}-13$ | $1.49 \mathrm{E}-10$ | $1-(1.49 \mathrm{E}-10)$ |
| 0.6 | 108.79 | $1.73 \mathrm{E}-13$ | $1.77 \mathrm{E}-10$ | $1-(1.77 \mathrm{E}-10)$ |
| 0.4 | 30.32 | $7.80 \mathrm{E}-14$ | $2.32 \mathrm{E}-10$ | $1-(2.32 \mathrm{E}-10)$ |
| 0.35 | 16.42 | $6.20 \mathrm{E}-14$ | $1.13 \mathrm{E}-10$ | $1-(1.13 \mathrm{E}-10)$ |
| 0.3 | 7.24 | $5.00 \mathrm{E}-14$ | $1.51 \mathrm{E}-11$ | $1-(1.51 \mathrm{E}-11)$ |
| 0.2 | 1.00 | $5.30 \mathrm{E}-14$ | $1.33 \mathrm{E}-11$ | $1-(1.33 \mathrm{E}-11)$ |

Table A.3: Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of the 3 -bit adder circuit.

| Vdd <br> (V) | Frequency <br> $(\mathrm{GHz})$ | Energy (J) | Error <br> probability | Reliability |
| :---: | :---: | :---: | :---: | :---: |
| 2.0 | 1.52 | $7.58 \mathrm{E}-13$ | $2.46 \mathrm{E}-11$ | $1-(2.46 \mathrm{E}-11)$ |
| 1.8 | 1.49 | $5.95 \mathrm{E}-13$ | $2.56 \mathrm{E}-11$ | $1-(2.56 \mathrm{E}-11)$ |
| 1.6 | 1.47 | $4.54 \mathrm{E}-13$ | $2.69 \mathrm{E}-11$ | $1-(2.69 \mathrm{E}-11)$ |
| 1.4 | 1.43 | $3.36 \mathrm{E}-13$ | $2.85 \mathrm{E}-11$ | $1-(2.85 \mathrm{E}-11)$ |
| 1.2 | 1.37 | $2.38 \mathrm{E}-13$ | $3.07 \mathrm{E}-11$ | $1-(3.07 \mathrm{E}-11)$ |
| 1.0 | 1.28 | $1.60 \mathrm{E}-13$ | $3.36 \mathrm{E}-11$ | $1-(3.36 \mathrm{E}-11)$ |
| 0.8 | 1.11 | $9.91 \mathrm{E}-14$ | $3.84 \mathrm{E}-11$ | $1-(3.84 \mathrm{E}-11)$ |
| 0.6 | 0.83 | $5.47 \mathrm{E}-14$ | $4.81 \mathrm{E}-11$ | $1-(4.81 \mathrm{E}-11)$ |
| 0.4 | 0.36 | $2.26 \mathrm{E}-14$ | $8.83 \mathrm{E}-11$ | $1-(8.83 \mathrm{E}-11)$ |
| 0.35 | 0.22 | $1.55 \mathrm{E}-14$ | $9.15 \mathrm{E}-11$ | $1-(9.15 \mathrm{E}-11)$ |
| 0.3 | 0.18 | $7.50 \mathrm{E}-15$ | $6.94 \mathrm{E}-11$ | $1-(6.94 \mathrm{E}-11)$ |
| 0.2 | 0.12 | $1.41 \mathrm{E}-15$ | $7.30 \mathrm{E}-12$ | $1-(7.30 \mathrm{E}-12)$ |

Table A.4: Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of c 432 circuit.

| Vdd <br> $(\mathrm{V})$ | Frequency <br> $(\mathrm{GHz})$ | Energy (J) | Error <br> probability | Reliability |
| :---: | :---: | :---: | :---: | :---: |
| 2.0 | 815.66 | $1.04 \mathrm{E}-11$ | $1.26 \mathrm{E}-10$ | $1-(1.26 \mathrm{E}-10)$ |
| 1.8 | 794.28 | $6.85 \mathrm{E}-12$ | $1.32 \mathrm{E}-10$ | $1-(1.32 \mathrm{E}-10)$ |
| 1.6 | 765.7 | $4.97 \mathrm{E}-12$ | $1.39 \mathrm{E}-10$ | $1-(1.39 \mathrm{E}-10)$ |
| 1.4 | 729.93 | $3.48 \mathrm{E}-12$ | $1.49 \mathrm{E}-10$ | $1-(1.49 \mathrm{E}-10)$ |
| 1.2 | 675.22 | $2.29 \mathrm{E}-12$ | $1.62 \mathrm{E}-10$ | $1-(1.62 \mathrm{E}-10)$ |
| 1.0 | 601.32 | $1.42 \mathrm{E}-12$ | $1.84 \mathrm{E}-10$ | $1-(1.84 \mathrm{E}-10)$ |
| 0.8 | 484.26 | $8.32 \mathrm{E}-13$ | $2.29 \mathrm{E}-10$ | $1-(2.29 \mathrm{E}-10)$ |
| 0.6 | 301.11 | $4.44 \mathrm{E}-13$ | $2.95 \mathrm{E}-10$ | $1-(2.95 \mathrm{E}-10)$ |
| 0.4 | 94.73 | $1.81 \mathrm{E}-13$ | $3.62 \mathrm{E}-10$ | $1-(3.62 \mathrm{E}-10)$ |
| 0.35 | 51.81 | $1.37 \mathrm{E}-13$ | $3.99 \mathrm{E}-10$ | $1-(3.99 \mathrm{E}-10)$ |
| 0.3 | 23.34 | $1.04 \mathrm{E}-13$ | $3.77 \mathrm{E}-10$ | $1-(3.77 \mathrm{E}-10)$ |
| 0.2 | 3.14 | $7.20 \mathrm{E}-14$ | $2.10 \mathrm{E}-10$ | $1-(2.10 \mathrm{E}-10)$ |

Table A.5: Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of c499 circuit.

| Vdd <br> $(\mathrm{V})$ | Frequency <br> $(\mathrm{GHz})$ | Energy (J) | Error <br> probability | Reliability |
| :---: | :---: | :---: | :---: | :---: |
| 2.0 | 1070.32 | $6.19 \mathrm{E}-12$ | $1.10 \mathrm{E}-10$ | $1-(1.10 \mathrm{E}-10)$ |
| 1.8 | 1056.41 | $4.81 \mathrm{E}-12$ | $1.15 \mathrm{E}-10$ | $1-(1.15 \mathrm{E}-10)$ |
| 1.6 | 1035.95 | $3.64 \mathrm{E}-12$ | $1.20 \mathrm{E}-10$ | $1-(1.20 \mathrm{E}-10)$ |
| 1.4 | 993.05 | $2.67 \mathrm{E}-12$ | $1.27 \mathrm{E}-10$ | $1-(1.27 \mathrm{E}-10)$ |
| 1.2 | 932.84 | $1.88 \mathrm{E}-12$ | $1.38 \mathrm{E}-10$ | $1-(1.38 \mathrm{E}-10)$ |
| 1.0 | 811.69 | $1.25 \mathrm{E}-12$ | $1.50 \mathrm{E}-10$ | $1-(1.50 \mathrm{E}-10)$ |
| 0.8 | 647.25 | $7.70 \mathrm{E}-13$ | $1.71 \mathrm{E}-10$ | $1-(1.71 \mathrm{E}-10)$ |
| 0.6 | 412.54 | $4.30 \mathrm{E}-13$ | $2.03 \mathrm{E}-10$ | $1-(2.03 \mathrm{E}-10)$ |
| 0.4 | 127.68 | $1.90 \mathrm{E}-13$ | $2.60 \mathrm{E}-10$ | $1-(2.60 \mathrm{E}-10)$ |
| 0.35 | 69.88 | $1.50 \mathrm{E}-13$ | $2.71 \mathrm{E}-10$ | $1-(2.71 \mathrm{E}-10)$ |
| 0.3 | 31.64 | $1.10 \mathrm{E}-13$ | $1.99 \mathrm{E}-10$ | $1-(1.99 \mathrm{E}-10)$ |
| 0.2 | 4.35 | $1.90 \mathrm{E}-13$ | $3.68 \mathrm{E}-12$ | $1-(3.68 \mathrm{E}-12)$ |

Table A.6: Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of c1908 circuit.

| Vdd <br> $(\mathrm{V})$ | Frequency <br> $(\mathrm{GHz})$ | Energy (J) | Error <br> probability | Reliability |
| :---: | :---: | :---: | :---: | :---: |
| 2.0 | 764.53 | $2.15 \mathrm{E}-11$ | $4.40 \mathrm{E}-10$ | $1-(4.40 \mathrm{E}-10)$ |
| 1.8 | 741.84 | $1.69 \mathrm{E}-11$ | $4.63 \mathrm{E}-10$ | $1-(4.63 \mathrm{E}-10)$ |
| 1.6 | 712.25 | $1.30 \mathrm{E}-11$ | $4.88 \mathrm{E}-10$ | $1-(4.88 \mathrm{E}-10)$ |
| 1.4 | 672.95 | $9.65 \mathrm{E}-12$ | $5.15 \mathrm{E}-10$ | $1-(5.15 \mathrm{E}-10)$ |
| 1.2 | 618.81 | $6.89 \mathrm{E}-12$ | $5.54 \mathrm{E}-10$ | $1-(5.54 \mathrm{E}-10)$ |
| 1.0 | 541.71 | $4.67 \mathrm{E}-12$ | $6.16 \mathrm{E}-10$ | $1-(6.16 \mathrm{E}-10)$ |
| 0.8 | 428.45 | $2.92 \mathrm{E}-12$ | $7.12 \mathrm{E}-10$ | $1-(7.12 \mathrm{E}-10)$ |
| 0.6 | 268.46 | $1.60 \mathrm{E}-12$ | $9.04 \mathrm{E}-10$ | $1-(9.04 \mathrm{E}-10)$ |
| 0.4 | 85.54 | $6.26 \mathrm{E}-13$ | $1.20 \mathrm{E}-09$ | $1-(1.20 \mathrm{E}-09)$ |
| 0.35 | 47.24 | $4.71 \mathrm{E}-13$ | $5.64 \mathrm{E}-10$ | $1-(5.64 \mathrm{E}-10)$ |
| 0.3 | 20.65 | $3.62 \mathrm{E}-13$ | $4.17 \mathrm{E}-10$ | $1-(4.17 \mathrm{E}-10)$ |
| 0.2 | 2.72 | $3.39 \mathrm{E}-13$ | $9.55 \mathrm{E}-10$ | $1-(9.55 \mathrm{E}-10)$ |

Table A.7: Error probability and reliability data corresponding with the value of the supply voltage, energy consumption and frequency of c6288 circuit.

| Vdd <br> $(\mathrm{V})$ | Frequency <br> $(\mathrm{GHz})$ | Energy (J) | Error <br> probability | Reliability |
| :---: | :---: | :---: | :---: | :---: |
| 2.0 | 370.37 | $2.07 \mathrm{E}-10$ | $2.85 \mathrm{E}-09$ | $1-(2.85 \mathrm{E}-9)$ |
| 1.8 | 357.14 | $1.62 \mathrm{E}-10$ | $3.02 \mathrm{E}-09$ | $1-(3.05 \mathrm{E}-9)$ |
| 1.6 | 334.45 | $1.25 \mathrm{E}-10$ | $3.33 \mathrm{E}-09$ | $1-(3.35 \mathrm{E}-9)$ |
| 1.4 | 308.64 | $9.27 \mathrm{E}-11$ | $3.58 \mathrm{E}-09$ | $1-(3.55 \mathrm{E}-9)$ |
| 1.2 | 277.01 | $6.54 \mathrm{E}-11$ | $3.99 \mathrm{E}-09$ | $1-(3.95 \mathrm{E}-9)$ |
| 1.0 | 238.1 | $4.39 \mathrm{E}-11$ | $4.79 \mathrm{E}-09$ | $1-(4.75 \mathrm{E}-9)$ |
| 0.8 | 177.62 | $2.85 \mathrm{E}-11$ | $6.34 \mathrm{E}-09$ | $1-(6.35 \mathrm{E}-9)$ |
| 0.6 | 103.84 | $1.58 \mathrm{E}-11$ | $1.04 \mathrm{E}-08$ | $1-(1.04 \mathrm{E}-8)$ |
| 0.4 | 28.46 | $6.91 \mathrm{E}-12$ | $3.45 \mathrm{E}-09$ | $1-(3.45 \mathrm{E}-9)$ |
| 0.35 | 15.3 | $5.34 \mathrm{E}-12$ | $1.68 \mathrm{E}-09$ | $1-(1.65 \mathrm{E}-9)$ |
| 0.3 | 6.84 | $4.07 \mathrm{E}-12$ | $1.09 \mathrm{E}-09$ | $1-(1.09 \mathrm{E}-9)$ |
| 0.2 | 0.92 | $2.64 \mathrm{E}-12$ | $1.04 \mathrm{E}-09$ | $1-(1.04 \mathrm{E}-9)$ |

Table A.8: Data of Figure 5.3, shows the relation between reliability, energy consumption and performance for the circuit chain of inverters in the cases: without filter, with $16 \mathrm{x}, 32 \mathrm{x}, 32 \mathrm{x}+0.5 \mathrm{x}$ filters.

| Vdd | Without filter |  |  | 16x filter |  |  | 32x filter |  |  | $32 \mathrm{x}+0.5 \mathrm{x}$ filter |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Freq. (MHz) | En. (J) | Rel. | Freq. (MHz) | En. (J) | Rel. | Freq. (MHz) | En. (J) | Rel. | Freq. (MHz) | En. (J) | Rel. |
| 2.0 | 438.60 | $\begin{gathered} 2.53 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(1.64 \mathrm{E}- \\ 10) \end{gathered}$ | 429.18 | $\begin{gathered} 2.96 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(1.56 \mathrm{E}- \\ 10) \end{gathered}$ | 423.53 | $\begin{gathered} 3.43 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(1.42 \mathrm{E}- \\ 10) \end{gathered}$ | 407.66 | $\begin{gathered} 4.24 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(7.89 \mathrm{E}- \\ 11) \end{gathered}$ |
| 1.8 | 414.94 | $\begin{aligned} & 2.01 \mathrm{E}- \\ & 12 \end{aligned}$ | $\begin{gathered} 1-(1.68 \mathrm{E}- \\ 10) \end{gathered}$ | 406.50 | $\begin{gathered} 2.33 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(1.61 \mathrm{E}- \\ 10) \end{gathered}$ | 401.61 | $\begin{gathered} 2.72 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(1.47 \mathrm{E}- \\ 10) \end{gathered}$ | 386.10 | $\begin{gathered} 3.25 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(8.11 \mathrm{E}- \\ 11) \end{gathered}$ |
| 1.6 | 386.10 | $\begin{aligned} & 1.55 \mathrm{E}- \\ & 12 \end{aligned}$ | $\begin{gathered} 1-(1.75 \mathrm{E}- \\ 10) \end{gathered}$ | 378.79 | $\begin{gathered} 1.78 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(1.66 \mathrm{E}- \\ 10) \end{gathered}$ | 374.13 | $\begin{gathered} 2.06 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(1.53 \mathrm{E}- \\ 10) \end{gathered}$ | 359.71 | $\begin{gathered} 2.40 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(8.07 \mathrm{E}- \\ 11) \end{gathered}$ |
| 1.4 | 348.43 | $\begin{aligned} & 1.17 \mathrm{E}- \\ & 12 \end{aligned}$ | $\begin{gathered} 1-(1.87 \mathrm{E}- \\ 10) \\ \hline \end{gathered}$ | 342.47 | $\begin{gathered} 1.32 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(1.75 \mathrm{E}- \\ 10) \\ \hline \end{gathered}$ | 337.84 | $\begin{aligned} & 1.52 \mathrm{E}- \\ & 12 \end{aligned}$ | $\begin{gathered} 1-(1.63 \mathrm{E}- \\ 10) \end{gathered}$ | 325.23 | $\begin{gathered} 1.73 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(8.02 \mathrm{E}- \\ 11) \\ \hline \end{gathered}$ |
| 1.2 | 303.03 | $\begin{gathered} 8.40 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(2.01 \mathrm{E}- \\ 10) \end{gathered}$ | 298.51 | $\begin{gathered} 9.29 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(1.86 \mathrm{E}- \\ 10) \end{gathered}$ | 294.12 | $\begin{gathered} 1.05 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(1.72 \mathrm{E}- \\ 10) \end{gathered}$ | 283.29 | $\begin{gathered} 1.18 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(7.06 \mathrm{E}- \\ 11) \end{gathered}$ |
| 1.0 | 246.31 | $\begin{gathered} 5.73 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(2.16 \mathrm{E}- \\ 10) \end{gathered}$ | 243.31 | $\begin{aligned} & 6.23 \mathrm{E}- \\ & 13 \end{aligned}$ | $\begin{gathered} 1-(2.02 \mathrm{E}- \\ 10) \end{gathered}$ | 239.88 | $\begin{gathered} 6.76 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(1.81 \mathrm{E}- \\ 10) \end{gathered}$ | 231.48 | $\begin{gathered} 7.45 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(5.43 \mathrm{E}- \\ 11) \end{gathered}$ |
| 0.8 | 178.89 | $\begin{gathered} 3.61 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(2.46 \mathrm{E}- \\ 10) \end{gathered}$ | 177.08 | $\begin{gathered} 3.86 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(2.23 \mathrm{E}- \\ 10) \end{gathered}$ | 174.53 | $\begin{gathered} 4.09 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(1.90 \mathrm{E}- \\ 10) \end{gathered}$ | 169.09 | $\begin{gathered} 4.24 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(1.34 \mathrm{E}- \\ 11) \end{gathered}$ |
| 0.6 | 101.11 | $\begin{gathered} 2.00 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(2.95 \mathrm{E}- \\ 10) \end{gathered}$ | 100.40 | $\begin{gathered} 2.10 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(2.59 \mathrm{E}- \\ 10) \end{gathered}$ | 98.91 | $\begin{gathered} 2.22 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(1.76 \mathrm{E}- \\ 10) \end{gathered}$ | 95.97 | $\begin{gathered} 2.27 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(1.04 \mathrm{E}- \\ 12) \end{gathered}$ |
| 0.4 | 26.56 | $\begin{gathered} 9.14 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(4.46 \mathrm{E}- \\ 10) \end{gathered}$ | 26.38 | $\begin{gathered} 9.56 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(1.10 \mathrm{E}- \\ 10) \end{gathered}$ | 26.03 | $\begin{gathered} 9.96 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(1.31 \mathrm{E}- \\ 12) \end{gathered}$ | 25.42 | $\begin{gathered} 1.01 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(1.60 \mathrm{E}- \\ 12) \end{gathered}$ |
| 0.35 | 14.08 | $\begin{gathered} 7.27 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(5.58 \mathrm{E}- \\ 10) \end{gathered}$ | 13.98 | $\begin{gathered} 7.62 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(4.98 \mathrm{E}- \\ 11) \end{gathered}$ | 13.83 | $\begin{gathered} 7.96 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(1.83 \mathrm{E}- \\ 12) \end{gathered}$ | 13.53 | $\begin{gathered} 8.05 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(1.95 \mathrm{E}- \\ 12) \end{gathered}$ |
| 0.3 | 6.22 | $\begin{gathered} 5.98 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(3.06 \mathrm{E}- \\ 11) \end{gathered}$ | 6.17 | $\begin{gathered} 6.23 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(3.09 \mathrm{E}- \\ 12) \end{gathered}$ | 6.11 | $\begin{gathered} 6.49 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(2.53 \mathrm{E}- \\ 12) \end{gathered}$ | 6.01 | $\begin{gathered} 6.55 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(2.39 \mathrm{E}- \\ 12) \end{gathered}$ |
| 0.2 | 0.81 | $\begin{gathered} 6.91 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(1.09 \mathrm{E}- \\ 11) \end{gathered}$ | 0.81 | $\begin{gathered} 7.20 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(4.42 \mathrm{E}- \\ 12) \end{gathered}$ | 0.80 | $\begin{gathered} 7.49 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(3.86 \mathrm{E}- \\ 12) \end{gathered}$ | 0.79 | $\begin{gathered} 7.56 \mathrm{E}- \\ 14 \end{gathered}$ | $\begin{gathered} 1-(3.82 \mathrm{E}- \\ 12) \end{gathered}$ |

- Freq.=Frequency, Rel.=Reliability, En.=Energy


|  | $\begin{gathered} \text { ØI } \\ -709 {fd87a54cd-c8ff-47e5-857d-bed90f24fbba} 6 \end{gathered}$ | $98^{\circ} 977$ | $\begin{gathered} (0 \mathrm{I} \\ \left.-\mathrm{G8} \mathrm{G}^{\circ} \mathrm{z}\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \varepsilon \mathrm{I} \\ -\mathrm{y} \ell 8 \cdot 8 \end{gathered}$ | 99＊687 | $\begin{gathered} (0 \mathrm{I} \\ \left.-\mathcal{H} \angle \mathcal{G}^{\circ} \mathcal{E}\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \varepsilon \mathrm{I} \\ -\mathrm{H} 66^{\circ} \mathrm{L} \end{gathered}$ | $9 Z^{\prime} \sqcap 87$ | $8^{\circ} 0$ |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} (\mathrm{I} \text { ( } \\ \left.-\mathcal{G} \& I^{\circ} \mathrm{Z}\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} Z \mathrm{I} \\ -\mathcal{G I} G^{\prime} \mathrm{I} \end{gathered}$ | 90＊967 | $\begin{gathered} (\mathrm{I} \text {, } \\ \left.-\mathrm{G} 99^{\circ} 8\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \text { ZI } \\ -\mathrm{H} 87^{\prime} \mathrm{I} \end{gathered}$ | モI‘ヵIG | $\begin{gathered} (0 \mathrm{I} \\ -\exists 6 Z^{\prime} \text { ) }-\mathrm{I} \end{gathered}$ | $\begin{gathered} \text { ZI } \\ -\mathrm{GGD} \cdot \mathrm{I} \end{gathered}$ | LT゙も\＆G | $\begin{gathered} (0 \mathrm{I} \\ \left.-\mathrm{y} 88^{\circ} \mathrm{z}\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \text { ZI } \\ -\mathcal{G C E} \cdot \mathrm{I} \end{gathered}$ | $\text { ZЕ‘' } 109$ | O＊I |  |  |
| $\begin{gathered} (\mathrm{I} \text { I } \\ \left.-G \nabla \nabla^{\cdot} \mathrm{I}\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \text { ZI } \\ - \text {-HIE } Z \end{gathered}$ | $\mathrm{G} L \cdot 97 \mathrm{G}$ | $\begin{gathered} (\mathrm{I}, \\ \left.-\mathrm{G} 9 \varepsilon^{\cdot} \mathrm{G}\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} Z \mathrm{I} \\ -马 \angle Z^{\prime} Z \end{gathered}$ | $08 \cdot 69 \mathrm{G}$ | $\begin{gathered} (0 \mathrm{I} \\ \left.-\exists \zeta L^{\circ} \mathrm{I}\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} Z \mathrm{I} \\ -\Im \succcurlyeq \square \cdot Z \end{gathered}$ | 8I’も6G | $\begin{gathered} (0 \mathrm{I} \\ \left.-\mathrm{G} \varnothing \mathrm{G}^{\circ} \mathrm{Z}\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \text { ZI } \\ - \text { GLO } \mathrm{Z} \end{gathered}$ |  | $Z^{\prime} \mathrm{I}$ |  |  |
| $\begin{gathered} (\mathrm{I} \text { I } \\ \left.-\mathcal{3} 60^{\circ} \mathrm{I}\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \text { ZI } \\ -马 G E^{\circ} \varepsilon \end{gathered}$ | 88＊089 | $\begin{gathered} (\mathrm{I} \text { I } \\ \left.-马 Z L^{\circ} \varepsilon\right)-\mathrm{I} \end{gathered}$ | ZI <br> －${ }^{-H}$ I $\varepsilon^{\circ}$ \＆ | $69^{\circ} 909$ | $\begin{gathered} (0 \mathrm{I} \\ \left.-\exists Z \nabla^{\circ} \mathrm{I}\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \text { ZI } \\ -\mathrm{H} 97^{\prime} \varepsilon \end{gathered}$ | I L•६६9 | $\begin{gathered} (0 \mathrm{I} \\ -\mathrm{G}\left(\varepsilon^{\prime} Z\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \text { ZI } \\ -马 \succcurlyeq 0 \cdot \varepsilon \end{gathered}$ | 86＊6ZL | $\dagger^{\circ} \mathrm{I}$ |  |  |
| $\begin{gathered} (\mathrm{Z} \\ \left.-\exists \varepsilon \varepsilon^{\circ} 8\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \text { ZI } \\ - \text { H99ㄲ } \end{gathered}$ | LL＇Z09 | $\begin{gathered} (\mathrm{I} \text { I } \\ \left.-马 89^{\circ} Z\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \text { ZI } \\ - \text { H09ㄲ } \end{gathered}$ | L I $\quad$ Z 89 | $\begin{gathered} (0 \mathrm{I} \\ \left.-马 \varepsilon Z^{{f0d413d29-f993-4796-9cc6-c75385b845d8} 8 \end{gathered}$ | $99^{\circ} \angle 99$ | $\begin{gathered} (\mathrm{I} \text { I } \\ \left.- \text {-直 } 1 \varepsilon^{*} 6\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \text { ZI } \\ -\mathrm{G} 76.2 \end{gathered}$ | $\angle L \cdot 00 L$ | $\begin{gathered} (0 \mathrm{I} \\ \left.-\mathrm{GG} \cdot 6^{\circ} \mathrm{I}\right)-\mathrm{I} \end{gathered}$ | $\begin{gathered} \text { ZI } \\ -\mathrm{G} Z \mathrm{c}^{\prime} \mathrm{L} \end{gathered}$ | $99^{\circ} \mathrm{GI} 8$ | $0 \% 3$ |
| ＇IPY | (ऽ) ‘u'f | $\begin{aligned} & (\text { (ZHN) } \\ & \cdot \text { bəı }_{4} \end{aligned}$ |  | （r）ut |  | ＇IPY |  | $\begin{aligned} & \left(\mathrm{zHN}_{\mathrm{HN}}\right) \\ & \text { baI }_{\mathrm{H}} \end{aligned}$ |  |  | $\begin{aligned} & (\mathrm{ZHN}) \\ & \text { 'baı }_{\mathrm{H}} \end{aligned}$ |  |  |  |
|  |  |  |  |  |  |  |  |  | ІәІІЧ ұпоч1！M |  |  | $\begin{gathered} (\Lambda) \\ \mathrm{pp}_{\Lambda} \end{gathered}$ |  |  |


Table A.10: Data of Figure 5.14, shows the relation between reliability, energy consumption and performance for the circuit c1908 in the cases: without filter, with $\mathrm{R}=10 \mathrm{k} \Omega$ and $\mathrm{C}=30 \mathrm{fF}, \mathrm{R}=10 \mathrm{k} \Omega$ and $\mathrm{C}=40 \mathrm{fF}, \mathrm{R}=10 \mathrm{k} \Omega$ and $\mathrm{C}=50 \mathrm{fF}$ filters.

|  | Without filter |  |  | ( $\mathrm{R}=10 \mathrm{k} \Omega, \mathrm{C}=30 \mathrm{fF}$ ) filter |  |  | ( $\mathrm{R}=10 \mathrm{k} \Omega, \mathrm{C}=40 \mathrm{fF}$ ) filter |  |  | ( $\mathrm{R}=10 \mathrm{k} \Omega, \mathrm{C}=50 \mathrm{fF}$ ) filter |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Freq. (MHz) | En. (J) | Rel. | Freq. <br> (MHz) | En. (J) | Rel. | Freq. (MHz) | En. (J) | Rel. | Freq. (MHz) | En. (J) | Rel. |
| 2.0 | 854.70 | $\begin{gathered} 1.19 \mathrm{E}- \\ 11 \end{gathered}$ | $\begin{gathered} 1-(7.03 \mathrm{E}- \\ 10) \end{gathered}$ | 721.50 | $\begin{gathered} 1.27 \mathrm{E}- \\ 11 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { 1-(1.61E- } \\ & 10) \end{aligned}$ | 683.53 | $\begin{gathered} 1.29 \mathrm{E}- \\ 11 \end{gathered}$ | $\begin{gathered} \text { 1-(1.02E- } \\ 11) \end{gathered}$ | 650.62 | $\begin{gathered} 1.31 \mathrm{E}- \\ 11 \end{gathered}$ | $\begin{gathered} 1-(9.06 \mathrm{E}- \\ 14) \end{gathered}$ |
| 1.8 | 833.33 | $\begin{gathered} 9.32 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(7.34 \mathrm{E}- \\ 10) \end{gathered}$ | 705.22 | $\begin{gathered} 9.97 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(2.01 \mathrm{E}- \\ 10) \end{gathered}$ | 669.79 | $\begin{gathered} 1.02 \mathrm{E}- \\ 11 \end{gathered}$ | $\begin{gathered} 1-(2.14 \mathrm{E}- \\ 11) \end{gathered}$ | 638.16 | $\begin{gathered} 1.04 \mathrm{E}- \\ 11 \end{gathered}$ | $\begin{gathered} \text { 1-(2.26E- } \\ 13) \end{gathered}$ |
| 1.6 | 806.45 | $\begin{gathered} 7.14 \mathrm{E}- \\ 12 \\ \hline \end{gathered}$ | $\begin{gathered} \text { 1-(7.74E- } \\ 10) \\ \hline \end{gathered}$ | 684.93 | $\begin{gathered} 7.65 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(2.45 \mathrm{E}- \\ 10) \\ \hline \end{gathered}$ | 650.62 | $\begin{gathered} 7.81 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} \text { 1-(4.50E- } \\ 11) \\ \hline \end{gathered}$ | 619.96 | $\begin{gathered} 7.96 \mathrm{E}- \\ 12 \\ \hline \end{gathered}$ | $\begin{gathered} \text { 1-(4.69E- } \\ 13) \\ \hline \end{gathered}$ |
| 1.4 | 769.23 | $\begin{gathered} 5.29 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} \hline 1-(8.24 \mathrm{E}- \\ 10) \end{gathered}$ | 655.31 | $\begin{gathered} 5.69 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} \hline 1-(2.97 \mathrm{E}- \\ 10) \end{gathered}$ | 625.00 | $\begin{gathered} 5.80 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} \hline \text { 1-(7.64E- } \\ 11) \\ \hline \end{gathered}$ | 596.66 | $\begin{gathered} 5.92 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} \hline \text { 1-(9.81E- } \\ 13) \end{gathered}$ |
| 1.2 | 714.29 | $\begin{gathered} 3.76 \mathrm{E}- \\ 12 \\ \hline \end{gathered}$ | $\begin{gathered} 1-(8.87 \mathrm{E}- \\ 10) \\ \hline \end{gathered}$ | 614.25 | $\begin{gathered} 4.05 \mathrm{E}- \\ 12 \\ \hline \end{gathered}$ | $\begin{gathered} 1-(3.60 \mathrm{E}- \\ 10) \end{gathered}$ | 586.85 | $\begin{gathered} 4.14 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(1.23 \mathrm{E}- \\ 10) \end{gathered}$ | 561.48 | $\begin{gathered} 4.22 \mathrm{E}- \\ 12 \\ \hline \end{gathered}$ | $\begin{gathered} 1-(1.75 \mathrm{E}- \\ 12) \end{gathered}$ |
| 1.0 | 632.91 | $\begin{gathered} 2.52 \mathrm{E}- \\ 12 \\ \hline \end{gathered}$ | $\begin{gathered} 1-(9.84 \mathrm{E}- \\ 10) \end{gathered}$ | 553.10 | $\begin{gathered} 2.73 \mathrm{E}- \\ 12 \\ \hline \end{gathered}$ | $\begin{gathered} \text { 1-(4.44E- } \\ 10) \end{gathered}$ | 530.50 | $\begin{gathered} 2.79 \mathrm{E}- \\ 12 \\ \hline \end{gathered}$ | $\begin{gathered} 1-(2.05 \mathrm{E}- \\ 10) \end{gathered}$ | 509.16 | $\begin{gathered} 2.85 \mathrm{E}- \\ 12 \\ \hline \end{gathered}$ | $\begin{gathered} \text { 1-(2.96E- } \\ 12) \\ \hline \end{gathered}$ |
| 0.8 | 510.20 | $\begin{gathered} 1.57 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} 1-(1.13 \mathrm{E}- \\ 09) \end{gathered}$ | 454.34 | $\begin{gathered} 1.71 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} \text { 1-(5.65E- } \\ 10) \end{gathered}$ | 438.79 | $\begin{gathered} 1.75 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} \text { 1-(3.19E- } \\ 10) \end{gathered}$ | 424.45 | $\begin{gathered} 1.78 \mathrm{E}- \\ 12 \end{gathered}$ | $\begin{gathered} \text { 1-(4.75E- } \\ 12) \end{gathered}$ |
| 0.6 | 327.87 | $\begin{gathered} 8.55 \mathrm{E}- \\ 13 \\ \hline \end{gathered}$ | $\begin{gathered} 1-(1.44 \mathrm{E}- \\ 09) \\ \hline \end{gathered}$ | 299.94 | $\begin{gathered} 9.41 \mathrm{E}- \\ 13 \\ \hline \end{gathered}$ | $\begin{gathered} 1-(7.51 \mathrm{E}- \\ 10) \\ \hline \end{gathered}$ | 292.40 | $\begin{gathered} 9.64 \mathrm{E}- \\ 13 \\ \hline \end{gathered}$ | $\begin{gathered} \text { 1-(4.66E- } \\ 10) \\ \hline \end{gathered}$ | 283.93 | $\begin{gathered} 9.86 \mathrm{E}- \\ 13 \\ \hline \end{gathered}$ | $\begin{gathered} 1-(8.13 \mathrm{E}- \\ 12) \\ \hline \end{gathered}$ |
| 0.4 | 103.20 | $\begin{gathered} 3.69 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(1.97 \mathrm{E}- \\ 09) \end{gathered}$ | 97.18 | $\begin{gathered} 4.13 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} \hline 1-(2.72 \mathrm{E}- \\ 10) \\ \hline \end{gathered}$ | 95.51 | $\begin{gathered} 4.25 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} \text { 1-(8.83E- } \\ 11) \end{gathered}$ | 93.63 | $\begin{gathered} 4.36 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(6.17 \mathrm{E}- \\ 12) \end{gathered}$ |
| 0.35 | 57.05 | $\begin{gathered} 2.83 \mathrm{E}- \\ 13 \\ \hline \end{gathered}$ | $\begin{gathered} 1-(6.67 \mathrm{E}- \\ 10) \end{gathered}$ | 54.02 | $\begin{gathered} 3.17 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} \text { 1-(1.35E- } \\ 10) \end{gathered}$ | 53.16 | $\begin{gathered} 3.26 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(9.58 \mathrm{E}- \\ 11) \end{gathered}$ | 52.25 | $\begin{gathered} 3.35 \mathrm{E}- \\ 13 \\ \hline \end{gathered}$ | $\begin{gathered} 1-(3.37 \mathrm{E}- \\ 12) \end{gathered}$ |
| 0.3 | 25.95 | $\begin{gathered} 2.14 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(5.10 \mathrm{E}- \\ 10) \end{gathered}$ | 24.69 | $\begin{gathered} 2.38 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} \text { 1-(1.64E- } \\ 10) \end{gathered}$ | 24.32 | $\begin{gathered} 2.45 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} \text { 1-(1.45E- } \\ 10) \end{gathered}$ | 23.98 | $\begin{gathered} 2.52 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(1.11 \mathrm{E}- \\ 17) \end{gathered}$ |
| 0.2 | 3.49 | $\begin{gathered} 1.69 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} 1-(1.13 \mathrm{E}- \\ 09) \\ \hline \end{gathered}$ | 3.32 | $\begin{gathered} 1.83 \mathrm{E}- \\ 13 \\ \hline \end{gathered}$ | $\begin{gathered} 1-(7.92 \mathrm{E}- \\ 10) \end{gathered}$ | 3.28 | $\begin{gathered} 1.87 \mathrm{E}- \\ 13 \\ \hline \end{gathered}$ | $\begin{gathered} 1-(8.08 \mathrm{E}- \\ 10) \\ \hline \end{gathered}$ | 3.20 | $\begin{gathered} 1.90 \mathrm{E}- \\ 13 \end{gathered}$ | $\begin{gathered} \text { 1-(1.11E- } \\ 17) \end{gathered}$ |

- Freq.=Frequency, Rel.=Reliability, En.=Energy


## DERIVING THE RELIABILITY CODES

## B. 1 FINDING CVM VALUES OF A CIRCUIT, OCEAN SCRIPT.

```
simulator( 'spectre )
option( ?categ 'turboOpts 'uniMode "APS" )
for( i 0 2671
    sprintf(i_str "%d" i)
    netlist_name = strcat("netlist_", i_str)
    design( buildString(list("/scratch/tmp_simulations/c6288/c1/spectre/
        schematic/", netlist_name, "/netlist"), ""))
        resultsDir( buildString(list("/scratch/tmp_simulations/c6288/c1/spectre
        /schematic/", netlist_name), "") )
modelFile(
    '("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90
        N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_
        DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_25IO_NVT
        _V021.lib.scs" "tt")
    '("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/../Models/Spectre/L90_25I0_V 111.lib.scs" "tt")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver. A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . / Models/Spectre/L90_NCAP25_V 113.lib.scs" "typ")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/../Models/Spectre/L90_varmis _25_rf_V011.lib.scs" "typ")
```

' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . . /Models/Spectre/L90_33I0_G0X 52_VT21.lib.scs" "tt")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M- LOW_K_UMK90FDKLMC000000A - FDK - Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_25I0_RF_ V021.lib.scs" "tt")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/../Models/Spectre/L90-resistor - control-V041.scs" "")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ ../Models/Spectre/L90_BJT_V 111.lib.scs" "tt_bip")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/../Models/Spectre/L90_DIODE_V 101.mdl.scs" "")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_LL12_RF_ V021.lib.scs" "tt")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M- LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/../Models/Spectre/L90_LLLVT12_ RF_VTAB.lib.scs" "tt")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_LL12_V 102.lib.scs" "tt")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A - FDK - Ver. A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_LLHVT12 V101.lib.scs" "tt")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_LLLVT12_ V102.lib.scs" "tt")
'("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_LLNVT12_ V011.lib.scs" "tt")
'("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC0000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90SP_NCAP 10_V112.lib.scs" "typ")
'("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC0000000A_A01/umc90nm/ . ./Models/Spectre/L90_NCAP12_ LL_V102.lib.scs" "typ")
'("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_SP10_V 061.lib.scs" "tt")
'("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_SPHVT10_ V111.lib.scs" "tt")
'("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_SPLVT10_ V102.lib.scs" "tt")
'("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_SPNVT10_ V011.lib.scs" "tt")
'("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/../Models/Spectre/L90_mimcaps _20f_kf_V011.lib.scs" "typ")
'("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC0000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/../Models/Spectre/L90_momcaps_ V041.lib.scs" "typ")
'("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/../Models/Spectre/L90_vardiop_ rf_v011.lib.scs" "typ")

```
    '("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90
        N-1P9M-LOW_K_UMK90FDKLMC000000A - FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01
        DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_varmis
    _12_llrf_V021.lib.scs" "typ")
    '("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/../Models/Spectre/momcaps_ array_vp3_rfvcl_V011.lib.scs" "typ")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . /Models/Spectre/momcaps_ array_vp4_rfvcl_V011.lib.scs" "typ")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/../Models/Spectre/rnhr_rf_V 011.lib.scs" "typ")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK - Ver. A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/rnnpo_rf_V 011.lib.scs" "typ")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M- LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/../Models/Spectre/rnppo_rf_V 011.lib.scs" "typ")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M- LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/../Models/Spectre/L90_varmis _10_sprf_V011.lib.scs" "typ")
'("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/bond_pad_v 011.lib.scs" "typ")
' ("/home/dk/UMC/90nm/1.4_P2/Designkits/Cadence_6.1/G-9FD-LOGIC_MIXED_MODE90 N-1P9M-LOW_K_UMK90FDKLMC000000A-FDK-Ver.A01_PB/UMK90FDKLMC000000A_A01_ DESIGNKIT/UMK90FDKLMC000000A_A01/umc90nm/ . ./Models/Spectre/L90_SP10_RF_ V021.lib.scs" "tt")
'("/home/CAMPUS/b5000001/tutorial/csou.lib.scs" "")
```

```
)
```

)
stimulusFile( ?xlate nil

```
```

    "/scratch/tmp_simulations/c6288/c1/spectre/schematic/netlist/_graphical_
        stimuli.scs")
    out = outfile("results/CVM.txt" "a")
myvdd=list( 2 1.8 1.6 1.4 1.2 1 0.8 0.6 0.4 0.35 0.3 0.2 )
prog(() foreach((vvdd) myvdd
desVar("vdd" vvdd)
vd=vvdd*0.5
LoadList1 = list( 100 75 50 25 5 2 1 )
foreach((let) LoadList1
desVar( "a" let )
analysis('tran ?start "80n" ?stop "150n" )
envOption('analysisOrder list("tran") )
temp( 27 )
run()
selectResult( 'tran )
;plot(getData("/out545") getData("/out1581") getData("/out1901") getData("/out
2223") getData("/out2548") getData("/out2877") getData("/out3211") getData
("/out3552") getData("/out3895") getData("/out4241") getData("/out4591")
getData("/out4946") getData("/out5308") getData("/out5672") getData("/out
5971") getData("/out6123") getData("/out6150") getData("/out6160") getData
("/out6170") getData("/out6180") getData("/out6190") getData("/out6200")
getData("/out6210") getData("/out6220") getData("/out6230") getData("/out

```
```

    6240") getData("/out6250") getData("/out6260") getData("/out6270") getData
    ("/out6280") getData("/out6287") getData("/out6288") )
    tr2=cross(v("/out545" ?result "tran") vd 1 "falling" nil nil )
trl=cross(v("/out545" ?result "tran") vd 1 "rising" nil nil )
if((trl==nil) then trl=0)
if((tr2==nil) then tr2=0)
tr3=cross(v("/out1581" ?result "tran") vd 1 "rising" nil nil )
tr4=cross(v("/out1581" ?result "tran") vd 1 "falling" nil nil )
if((tr3==nil) then tr3=0)
if((tr4==nil) then tr4=0)
tr5=cross(v("/out1901" ?result "tran") vd 1 "rising" nil nil )
tr6=cross(v("/out1901" ?result "tran") vd 1 "falling" nil nil )
if((tr5==nil) then tr5=0)
if((tr6==nil) then tr6=0)
tr7=cross(v("/out2223" ?result "tran") vd 1 "falling" nil nil )
tr8=cross(v("/out2223" ?result "tran") vd 1 "rising" nil nil )
if((tr7==nil) then tr7=0)
if((tr8==nil) then tr8=0)
tr9=cross(v("/out2548" ?result "tran") vd 1 "falling" nil nil )
tr10=cross(v("/out2548" ?result "tran") vd 1 "rising" nil nil )
if((tr9==nil) then tr9=0)
if((tr10==nil) then tr10=0)
tr11=cross(v("/out2877" ?result "tran") vd 1 "falling" nil nil )
tr12=cross(v("/out2877" ?result "tran") vd 1 "rising" nil nil )
if((tr11==nil) then tr11=0)
if((tr12==nil) then tr12=0)
tr13=cross(v("/out3211" ?result "tran") vd 1 "falling" nil nil )

```
```

tr14=cross(v("/out3211" ?result "tran") vd 1 "rising" nil nil )
if((tr13==nil) then tr13=0)
if((tr14==nil) then tr14=0)
tr15=cross(v("/out3552" ?result "tran") vd 1 "falling" nil nil )
tr16=cross(v("/out3552" ?result "tran") vd 1 "rising" nil nil )
if((tr15==nil) then tr15=0)
if((tr16==nil) then tr16=0)
tr17=cross(v("/out3895" ?result "tran") vd 1 "falling" nil nil )
tr18=cross(v("/out3895" ?result "tran") vd 1 "rising" nil nil )
if((tr17==nil) then tr17=0)
if((tr18==nil) then tr18=0)
tr19=cross(v("/out4241" ?result "tran") vd 1 "falling" nil nil )
tr20=cross(v("/out4241" ?result "tran") vd 1 "rising" nil nil )
if((tr19==nil) then tr19=0)
if((tr20==nil) then tr20=0)
tr21=cross(v("/out4591" ?result "tran") vd 1 "falling" nil nil )
tr22=cross(v("/out4591" ?result "tran") vd 1 "rising" nil nil )
if((tr21==nil) then tr21=0)
if((tr22==nil) then tr22=0)
tr23=cross(v("/out4946" ?result "tran") vd 1 "falling" nil nil )
tr24=cross(v("/out4946" ?result "tran") vd 1 "rising" nil nil )
if((tr23==nil) then tr23=0)
if((tr24==nil) then tr24=0)
tr25=cross(v("/out5308" ?result "tran") vd 1 "falling" nil nil )
tr26=cross(v("/out5308" ?result "tran") vd 1 "rising" nil nil )
if((tr25==nil) then tr25=0)
if((tr26==nil) then tr26=0)

```
```

tr27=cross(v("/out5672" ?result "tran") vd 1 "falling" nil nil )
tr28=cross(v("/out5672" ?result "tran") vd 1 "rising" nil nil )

```
if((tr27==nil) then tr27=0)
if((tr28==nil) then tr28=0)
tr29=cross(v("/out5971" ?result "tran") vd 1 "falling" nil nil )
tr30=cross(v("/out5971" ?result "tran") vd 1 "rising" nil nil )
if((tr29==nil) then tr29=0)
if((tr30==nil) then tr30=0)
tr31=cross(v("/out6123" ?result "tran") vd 1 "falling" nil nil )
tr32=cross(v("/out6123" ?result "tran") vd 1 "rising" nil nil )
if((tr31==nil) then tr31=0)
if((tr32==nil) then tr32=0)
tr33=cross(v("/out6150" ?result "tran") vd 1 "falling" nil nil )
tr34=cross(v("/out6150" ?result "tran") vd 1 "rising" nil nil )
if((tr33==nil) then tr33=0)
if((tr34==nil) then tr34=0)
tr35=cross(v("/out6160" ?result "tran") vd 1 "falling" nil nil )
tr36=cross(v("/out6160" ?result "tran") vd 1 "rising" nil nil )
if((tr35==nil) then tr35=0)
if((tr36==nil) then tr36=0)
tr37=cross(v("/out6170" ?result "tran") vd 1 "falling" nil nil )
tr38=cross(v("/out6170" ?result "tran") vd 1 "rising" nil nil )
if((tr37==nil) then tr37=0)
if((tr38==nil) then tr38=0)
tr39=cross(v("/out6180" ?result "tran") vd 1 "falling" nil nil )
tr40=cross(v("/out6180" ?result "tran") vd 1 "rising" nil nil )
if((tr39==nil) then tr39=0)
```

if((tr40==nil) then tr40=0)
tr41=cross(v("/out6190" ?result "tran") vd 1 "falling" nil nil )
tr42=cross(v("/out6190" ?result "tran") vd 1 "rising" nil nil )
if((tr41==nil) then tr41=0)
if((tr42==nil) then tr42=0)
tr43=cross(v("/out6200" ?result "tran") vd 1 "falling" nil nil )
tr44=cross(v("/out6200" ?result "tran") vd 1 "rising" nil nil )
if((tr43==nil) then tr43=0)
if((tr44==nil) then tr44=0)
tr45=cross(v("/out6210" ?result "tran") vd 1 "falling" nil nil )
tr46=cross(v("/out6210" ?result "tran") vd 1 "rising" nil nil )
if((tr45==nil) then tr45=0)
if((tr46==nil) then tr46=0)
tr47=cross(v("/out6220" ?result "tran") vd 1 "falling" nil nil )
tr48=cross(v("/out6220" ?result "tran") vd 1 "rising" nil nil )
if((tr47==nil) then tr47=0)
if((tr48==nil) then tr48=0)
tr49=cross(v("/out6230" ?result "tran") vd 1 "falling" nil nil )
tr50=cross(v("/out6230" ?result "tran") vd 1 "rising" nil nil )
if((tr49==nil) then tr49=0)
if((tr50==nil) then tr50=0)
tr51=cross(v("/out6240" ?result "tran") vd 1 "falling" nil nil )
tr52=cross(v("/out6240" ?result "tran") vd 1 "rising" nil nil )
if((tr51==nil) then tr51=0)
if((tr52==nil) then tr52=0)
tr53=cross(v("/out6250" ?result "tran") vd 1 "falling" nil nil )
tr54=cross(v("/out6250" ?result "tran") vd 1 "rising" nil nil )

```
```

if((tr53==nil) then tr53=0)
if((tr54==nil) then tr54=0)
tr55=cross(v("/out6260" ?result "tran") vd 1 "falling" nil nil )
tr56=cross(v("/out6260" ?result "tran") vd 1 "rising" nil nil )
if((tr55==nil) then tr55=0)
if((tr56==nil) then tr56=0)
tr57=cross(v("/out6270" ?result "tran") vd 1 "falling" nil nil )
tr58=cross(v("/out6270" ?result "tran") vd 1 "rising" nil nil )
if((tr57==nil) then tr57=0)
if((tr58==nil) then tr58=0)
tr59=cross(v("/out6280" ?result "tran") vd 1 "falling" nil nil )
tr60=cross(v("/out6280" ?result "tran") vd 1 "rising" nil nil )
if((tr59==nil) then tr59=0)
if((tr60==nil) then tr60=0)
tr61=cross(v("/out6287" ?result "tran") vd 1 "falling" nil nil )
tr62=cross(v("/out6287" ?result "tran") vd 1 "rising" nil nil )
if((tr61==nil) then tr61=0)
if((tr62==nil) then tr62=0)
tr63=cross(v("/out6288" ?result "tran") vd 1 "falling" nil nil )
tr64=cross(v("/out6288" ?result "tran") vd 1 "rising" nil nil )
if((tr63==nil) then tr63=0)
if((tr64==nil) then tr64=0)
if(((vvdd==2) \&\& (let==100) \&\& (tr1==0) \&\& (tr3==0) \&\& (tr5==0) \&\& (tr7==0) \&\&
(tr9==0) \&\& (tr11==0) \&\& (tr13==0) \&\& (tr15==0) \&\& (trl7==0) \&\& (tr19==0)
\&\& (tr21==0) \&\& (tr23==0) \&\& (tr25==0) \&\& (tr27==0) \&\& (tr29==0) \&\& (tr
31==0) \&\& (tr33==0) \&\& (tr35==0) \&\& (tr37==0) \&\& (tr39==0) \&\& (tr41==0) \&\&
(tr43==0) \&\& (tr45==0) \&\& (tr47==0) \&\& (tr49==0) \&\& (tr51==0) \&\& (tr53==0)

```
```

    && (tr55==0) && (tr57==0) && (tr59==0) && (tr61==0) && (tr63==0)) then
    return())
    ocnPrint(?output out let,tr1,tr2,tr3,tr4,tr5,tr6,tr7,tr8,tr9,tr10,tr11,tr12,tr
13,tr14,tr15,tr16,tr17,tr18,tr19,tr20,tr21,tr22,tr23,tr24,tr25,tr26,tr27,tr
28,tr29,tr30,tr31,tr32,tr33,tr34,tr35,tr36,tr37,tr38,tr39,tr40,tr41,tr42,tr
43,tr44,tr45,tr46,tr47,tr48,tr49,tr50,tr51,tr52,tr53,tr54,tr55,tr56,tr57,tr
58,tr59,tr60,tr61,tr62,tr63,tr64 )
)
)
)
)

```
B. 2 CALCULATING THE ERROR PROBABILITY OF A CIRCUIT, C-LANGUAGE CODE.
```

\#include <stdio.h>
\#include <stdlib.h>
\#include <math.h>
//this function calculates the probability of LET
double errb(int i);
int main()
{
// This part reading the LET value and the intersection between the output
waveform and Vdd/2
// (the parameter vectors )PV, where i is number of simulations according to
different value of LET and n number of the outputs
// that the glitch is propagated to.
// varl is LET value, var the starting and finishing the glitch (the glitch
period)
FILE *fp1;
FILE *fp2;
FILE *fp3;
fp1 = fopen("c1908/RCfilter/r10c50.txt", "r");
fp2 = fopen("c1908/RCfilter/errorfile-r10c50.txt","a");
fp3 = fopen("c1908/clock.txt", "r");
double err;
float rate,prob,nr=20;
float mins[7], maxs[7],minb[7], maxb[7],t[7][7],var1[7],let1[7],probability
[12],minimum,minimumb;
float trs[7],trb[7],tr[7],v[12],T[12];
int i,ii,iii,nn,n,k,kk,m,jj,j=0,out=50,let[7];
float lit[out],vars[7][out],varb[7][out],var[7][out];
//j is number of let values that used in the simulation stage. out: is
number of glitches critical values
for(j=0;j<12;j++){
probability[j]=0;
}

```
```

for (kk=0; kk<350 ; kk++)
{
for (k=0; k<12 ;k++)
{
fscanf(fp3," %f %f",\&v[k],\&T[k]);
prob=0;
err=0;
maxs[0]=0;
for (i = 0 ; i < 7 ; i++)
{
minimum=350;
minimumb=350;
fscanf(fpl, "%f ",\&varl[i]);
for(n=0 ; n<out ; n+=2)
{
lit[n]=0;
fscanf(fpl, "%f %f ",\&var[i][n],\&var[i][n+1]);
if ((var[i][n] != 0) \&\& (var[i][n+1] != 0) \&\& (var[i][n] > var[i][n+1])
)
{
lit[n] = var[i][n];
var[i][n] = var[i][n+1];
var[i][n+1] = lit[n];
}
}
}
for (i = 0 ; i < 7 ; i++)
{
for(n=0 ; n<out ; n++)
{
varb[i][n] = 0;
vars[i][n] = 0;
}
}
for(n=0 ; n<out ; n++)
{
if ((var[0][n] != 0) \&\& (var[0][n] < minimum))
{
minimum=var[0][n];

```
```

        maxs[0]=var[0][n+1];
    }
    }
for (i = 0 ; i < 7 ; i++)
{
for(n=0 ; n<out ; n+=2)
{
if ((var[i][n] != 0) \&\& (var[i][n] > maxs[0] ))
{
varb[i][n]=var[i][n];
varb[i][n+1]=var[i][n+1];
if (varb[i][n] < minimumb)
{
minimumb=varb[i][n];
}
}
}
}
printf ( "\n minimumb= %f", minimumb );
for (i = 0 ; i < 7 ; i++)
{
for(n=0 ; n<out ; n+=2)
{
if ((var[i][n] != 0) \&\& (var[i][n] <= maxs[0] ))
{
vars[i][n]=var[i][n];
vars[i][n+1]=var[i][n+1];
printf( "\n \t %f %f %f %d",vars[i][n],vars[i][n+1],var1[i],n);
}
}
}
mins[0]=maxs[0]=maxs[1]=maxs[2]=maxs[3]=maxs[4]=maxs[5]=maxs[6]=minimum;
minb[0]=maxb[0]=maxb[1]=maxb[2]=maxb[3]=maxb[4]=maxb[5]=maxb[6]=minimumb;
for(i=0 ; i<7 ; i++)
{
for(n=0 ; n<out ; n++)
{
if ( vars[i][n] > maxs[i])
{
maxs[i]=vars[i][n];

```
```

        }
        if ( varb[i][n] > maxb[i])
        {
            maxb[i]=varb[i][n];
        }
    }
    }
for (m=0 ; m<6 ; m++)
{
let1[m+1]=(var1[m]+var1[m+1])/2;
let[m+1] = ceil (let1[m+1]);
}
let[0]=var1[6];
for(nn=0 ; nn<7 ; nn++)
{
printf("\n %f %f \t %f %f \n",maxs[nn],mins[0],maxb[nn],minb[0]);
}
for (ii=1; ii<7 ; ii++)
{
trs[ii]=fabs(maxs[ii-1]-maxs[ii]);
printf(" \n trs = %f \n",trs[ii]);
}
for (ii=1; ii<7 ; ii++)
{
trb[ii]=fabs(maxb[ii-1]-maxb[ii]);
if (maxb[ii] == minb[0])
{
trb[ii]=fabs(maxb[ii-1]-minb[0]);
}
printf(" \n trb =[%d] %f \n",ii,trb[ii]);
}
trb[0] = maxb[6] - minb[0];
trs[0] = maxs[6] - mins[0] ;
printf("v= %f %f \n",v[k],trs[0]);
for (jj=0; jj<7; jj++)
{
tr[jj]=trs[jj]+trb[jj];
printf(" \n\n %d %f %f %f \n",let[jj],tr[jj],maxs[jj],mins[0]);
}
printf("v= %f",v[k]);

```
```

    rate = (nr/ 3600.00)*T[k]*1e-9 ;
    for(iii=0 ; iii<7 ; iii++ )
    {
        err = err+ errb(let[iii])*tr[iii]/T[k];
    }
    prob=err*rate;
    probability[k]=probability[k]+prob;
    fprintf(fp2," %f \t %.3e %0.3e \n",v[k],prob,probability[k]);
    printf(" %f \t %.3e %0.3e %0.3e \n",v[k],prob,err,probability[k]);
    }
    }
return 0;
}
double errb(int i)
{
double f[100];
double pi = 3.141592654;
double a, g, d, sum;
a = 20 * sqrt(pi / 2);
int j;
j = i;
sum = 0;
double prob;
do
{
g = (i * i) / (2 * a * a);
d = exp(-g);
f[i] = (sqrt(2 / pi))*(((i * i)*d) / (a*a*a));
i = i + 1;
}
while (i<101);
while (j < 100)
{
sum = sum + f[j] + f[j + 1];
j = j + 1;
}
prob = sum / 2 * 1;
return prob;

```
C. 1 ENERGY CONSUMPTION AND PERFORMANCE OF CHAIN OF INVERTERS CIRCUIT.

The performance of chain of inverters circuit is affected by the filter stage, this effect is introduced in C.1.


Figure C.1: The effect of the filter stage on the performance of the chain of inverters circuit.

The energy consumption of chain of inverters circuit is affected by the filter stage, this effect is introduced in C.2.


Figure C.2: The effect of the filter stage on the energy consumption of the chain of inverters circuit.

\section*{C. 2 ENERGY CONSUMPTION AND PERFORMANCE OF C432 CIRCUIT.}

The performance of c432 circuit is affected by the filter stage, this effect is introduced in C.3.


Figure C.3: The effect of the filter stage on the performance of c432 circuit

The energy consumption of chain of inverters circuit is affected by the filter stage, this effect is introduced in C.4.


Figure C.4: The effect of the filter stage on the energy consumption of c 432 circuit

\section*{C. 3 EnERGY CONSUMPTION AND PERFORMANCE OF C 1908 CIRCUIT.}

The performance of c1908 circuit is affected by the filter stage, this effect is introduced in C.5.


Figure C.5: The effect of the filter stage on the performance of c1908 circuit

The energy consumption of c1908 circuit is affected by the filter stage, this effect is introduced in C.6.


Figure C.6: The effect of the filter stage on the energy consumption of c 1908 circuit

\section*{Part III}

Thesis Bibliography
[1] V. D. Agrawal. Low-power design by hazard filtering. In Proceedings Tenth International Conference on VLSI Design, pages 193-197, Jan 1997. doi: 10.1109/ICVD.1997.568075.
[2] Y. Aizik and A. Kolodny. Exploration of energy-delay tradeoffs in digital circuit design. In 2008 IEEE 25th Convention of Electrical and Electronics Engineers in Israel, pages 001-005, Dec 2008. doi: 10.1109/EEEI.2008. 4736618.
[3] M. Anglada, R. Canal, J. L. Aragon, and A. Gonzalez. Maskit: Soft error rate estimation for combinational circuits. In 2016 IEEE 34th International Conference on Computer Design (ICCD), pages 614-621, Oct 2016. doi: 10.1109/ICCD.2016.7753348.
[4] L. Artola, M. Gaillardin, G. Hubert, M. Raine, and P. Paillet. Modeling single event transients in advanced devices and ics. IEEE Trans. on Nuclear Science, 62(4):1528-1539, Aug 2015. ISSN 0018-9499. doi: 10.1109/TNS.2015.2432271.
[5] J. L. Autran, S. Serre, S. Semikh, D. Munteanu, G. Gasiot, and P. Roche. Soft-error rate induced by thermal and low energy neutrons in 40 nm srams. IEEE Transactions on Nuclear Science, 59(6):2658-2665, Dec 2012. ISSN 0018-9499. doi: 10.1109/TNS.2012.2222438.
[6] J.L. Autran and D. Munteanu. Soft Errors: From Particles to Circuits. Devices, Circuits, and Systems. CRC Press, 2015. ISBN 9781466590847.
[7] J.L. Autran, D. Munteanu, P. Roche, G. Gasiot, S. Martinie, S. Uznanski, S. Sauze, S. Semikh, E. Yakushev, S. Rozov, P. Loaiza, G. Warot, and M. Zampaolo. Soft-errors induced by terrestrial neutrons and natural alpha-particle emitters in advanced memory circuits at ground level. Microelectronics Reliability, 50(9): 1822 - 1831, 2010. ISSN 00262714. doi: https://doi.org/10.1016/j.microrel.2010.07.033. URL http: //www.sciencedirect.com/science/article/pii/S0026271410003069. 21st European Symposium on the Reliability of Electron Devices, Failure Physics and Analysis.
[8] Algirdas Avizienis, Vytautas Magnus U, Jean-claude Laprie, and Brian Randell. Fundamental concepts of dependability. 042001.
[9] Algirdas Avižienis, Jean-Claude Laprie, and Brian Randell. Dependability and its threats: A taxonomy. In Renè Jacquart, editor, Building the Information Society, pages 91-120, Boston, MA, 2004. Springer US. ISBN 978-1-4020-8157-6.
[10] P. B. Basyurt, E. Bonizzoni, F. Maloberti, and D. Y. Aksin. A low-power low-noise cmos voltage reference with improved psr for wearable sensor systems. In 2017 IEEE International Symposium on Circuits and Systems (ISCAS), pages 1-4, May 2017. doi: 10.1109/ISCAS.2017.8050266.
[11] R. C. Baumann. Radiation-induced soft errors in advanced semiconductor technologies. IEEE Transactions on Device and Materials Reliability, 5(3):305-316, Sept 2005. ISSN 1530-4388. doi: 10.1109/TDMR.2005.853449.
[12] M. P. Baze and S. P. Buchner. Attenuation of single event induced pulses in cmos combinational logic. IEEE Transactions on Nuclear Science, 44 (6):2217-2223, Dec 1997. ISSN 0018-9499. doi: 10.1109/23.659038.
[13] M. P. Baze, J. Wert, J. W. Clement, M. G. Hubert, A. Witulski, O. A. Amusan, L. Massengill, and D. McMorrow. Propagating set characterization technique for digital cmos libraries. IEEE Transactions on Nuclear Science, 53(6):3472-3478, Dec 2006. ISSN 0018-9499. doi: 10.1109/TNS.2006.884969.
[14] D. A. Black, W. H. Robinson, I. Z. Wilcox, D. B. Limbrick, and J. D. Black. Modeling of single event transients with dual double-exponential current sources: Implications for logic cell characterization. IEEE Trans. on Nuclear Science, 62(4):1540-1549, Aug 2015. ISSN 0018-9499. doi: 10.1109/TNS.2015.2449073.
[15] Hao Cai, Kaikai Liu, Lirida Alves de Barros Naviner, You Wang, Mariem Slimani, and Jean-FranÃ§ois Naviner. Efficient reliability evaluation methodologies for combinational circuits. Microelectronics Reliability, 64:19-25, 2016. ISSN 0026-2714. doi: https://doi.org/10.1016/ j.microrel.2016.07.116. URL http://www.sciencedirect.com/science/ article/pii/S0026271416302608. Proceedings of the 27th European Symposium on Reliability of Electron Devices, Failure Physics and Analysis.
[16] J. Cai and C. Chen. Circuit reliability analysis using signal reliability correlations. In 2017 IEEE International Conference on Software Guality, Reliability and Security Companion (GRS-C), pages 171-176, July 2017. doi: 10.1109/GRS-C.2017.34.
[17] Megan Colleen Casey. SINGLE-EVENT EFFECTS IN DIGITAL CMOS CIRCUITS OPERATING AT ULTRA-LOW POWER. PhD thesis, Vanderbilt University, 2009.
[18] A. C. C. Chang, R. H. M. Huang, and C. H. P. Wen. Casser: A closed-form analysis framework for statistical soft error rate. IEEE Transactions on Very Large Scale Integration (VLSI) Systems, 21(10):1837-1848, Oct 2013. ISSN 1063-8210. doi: 10.1109/TVLSI.2012.2220386.
[19] Geng Chao, Liu Jie, Zhang Zhan-Gang, Xi Kai, Gu Song, Hou MingDong, Sun You-Mei, Duan Jing-Lai, Yao Hui-Jun, Mo Dan, and Luo Jie. Modeling the applicability of linear energy transfer on single event upset occurrence. Chinese Physics C, 37(6):066001, 2013. URL http: //stacks.iop.org/1674-1137/37/i=6/a=066001.
[20] Liang Chen, Mojtaba Ebrahimi, and Mehdi B. Tahoori. Cep: Correlated error propagation for hierarchical soft error analysis. Journal of Electronic Testing, 29(2):143-158, Apr 2013. ISSN 1573-0727. doi: 10.1007/ s10836-013-5365-0. URL https://doi.org/10.1007/s10836-013-5365-0.
[21] Mihir R. Choudhury, Quming Zhou, and Kartik Mohanram. Soft error rate reduction using circuit optimization and transient filter insertion. Journal of Electronic Testing, 25(2):197-207, Jun 2009. ISSN 15730727. doi: 10.1007/s10836-009-5103-9. URL https://doi.org/10. 1007/s10836-009-5103-9.
[22] Michael Andrew Clemens. ENERGY DEPOSITION MECHANISMS FOR PROTON- AND NEUTRON-INDUCED SINGLE EVENT UPSETS IN MODERN ELECTRONIC DEVICES. PhD thesis, Graduate School of Vanderbilt University, 2012.
[23] Actel corporation. Effects of neutrons on programmable logic. Technical report, 2002.
[24] S. DasGupta, A. F. Witulski, B. L. Bhuva, M. L. Alles, R. A. Reed, O. A. Amusan, J. R. Ahlbin, R. D. Schrimpf, and L. W. Massengill. Effect of well
and substrate potential modulation on single event pulse shape in deep submicron cmos. IEEE Transactions on Nuclear Science, 54(6):24072412, Dec 2007. ISSN 0018-9499. doi: 10.1109/TNS.2007.910863.
[25] Y. S. Dhillon, A. U. Diril, and A. Chatterjee. Soft-error tolerance analysis and optimization of nanometer circuits. In Design, Automation and Test in Europe, pages 288-293 Vol. 1, March 2005. doi: 10.1109/DATE. 2005.274.
[26] P. E. Dodd, M. R. Shaneyfelt, J. A. Felix, and J. R. Schwank. Production and propagation of single-event transients in high-speed digital logic ics. IEEE Transactions on Nuclear Science, 51(6):3278-3284, Dec 2004. ISSN 0018-9499. doi: 10.1109/TNS.2004.839172.
[27] E. Dubrova. Fault-Tolerant Design. Springer New York, 2013. ISBN 9781461421139. URL https://books.google.co.uk/books?id=FRs_ AAAAQBAJ.
[28] E. Dupont, M. Nicolaidis, and P. Rohr. Embedded robustness ips for transient-error-free ics. IEEE Design Test of Computers, 19(3):54-68, May 2002. ISSN 0740-7475. doi: 10.1109/MDT.2002.1003798.
[29] Gordon E. Moore. Cramming more components onto integrated circuits, reprinted from electronics, volume 38, number 8, april 19, 1965, pp. 114 ff. 11:33-35, 102006.
[30] P. Eaton, J. Benedetto, D. Mavis, K. Avery, M. Sibley, M. Gadlage, and T. Turflinger. Single event transient pulsewidth measurements using a variable temporal latch technique. IEEE Transactions on Nuclear Science, 51(6):3365-3368, Dec 2004. ISSN 0018-9499. doi: 10.1109/TNS.2004. 840020.
[31] M. Ebrahimi, A. Evans, M. B. Tahoori, E. Costenaro, D. Alexandrescu, V. Chandra, and R. Seyyedi. Comprehensive analysis of sequential and combinational soft errors in an embedded processor. IEEE Trans. on Computer-Aided Design of Integrated Circuits and Systems, 34(10):15861599, Oct 2015. ISSN 0278-0070. doi: 10.1109/TCAD.2015.2422845.
[32] L. Entrena, M. Garcia-Valderas, R. Fernandez-Cardenal, A. Lindoso, M. Portela, and C. Lopez-Ongil. Soft error sensitivity evaluation of microprocessors by multilevel emulation-based fault injection. IEEE

Transactions on Computers, 61(3):313-322, March 2012. ISSN 00189340. doi: 10.1109/TC.2010.262.
[33] D. Ernst, Nam Sung Kim, S. Das, S. Pant, R. Rao, Toan Pham, C. Ziesler, D. Blaauw, T. Austin, K. Flautner, and T. Mudge. Razor: a low-power pipeline based on circuit-level timing speculation. In Proceedings. 36th Annual IEEE/ACM International Symposium on Microarchitecture, 2003. MICRO-36., pages 7-18, Dec 2003. doi: 10.1109/MICRO.2003.1253179.
[34] A. Evans, D. Alexandrescu, V. Ferlet-Cavrois, and M. Nicolaidis. New techniques for set sensitivity and propagation measurement in flashbased fpgas. IEEE Trans. on Nuclear Science, 61(6):3171-3177, Dec 2014. ISSN 0018-9499. doi: 10.1109/TNS.2014.2365410.
[35] V. Ferlet-Cavrois, P. Paillet, M. Gaillardin, D. Lambert, J. Baggio, J. R. Schwank, G. Vizkelethy, M. R. Shaneyfelt, K. Hirose, E. W. Blackmore, O. Faynot, C. Jahan, and L. Tosti. Statistical analysis of the charge collected in soi and bulk devices under heavy lon and proton irradiation mdash;implications for digital sets. IEEE Transactions on \(\mathrm{Nu}-\) clear Science, 53(6):3242-3252, Dec 2006. ISSN 0018-9499. doi: 10.1109/TNS.2006.885111.
[36] V. Ferlet-Cavrois, P. Paillet, D. McMorrow, N. Fel, J. Baggio, S. Girard, O. Duhamel, J. S. Melinger, M. Gaillardin, J. R. Schwank, P. E. Dodd, M. R. Shaneyfelt, and J. A. Felix. New insights into single event transient propagation in chains of inverters evidence for propagation-induced pulse broadening. IEEE Transactions on Nuclear Science, 54(6):23382346, Dec 2007. ISSN 0018-9499. doi: 10.1109/TNS.2007.910202.
[37] V. Ferlet-Cavrois, D. Kobayashi, D. McMorrow, J. R. Schwank, H. Ikeda, A. Zadeh, O. Flament, and K. Hirose. Large set duration broadening in a fully-depleted soi technology-mitigation with body contacts. IEEE Transactions on Nuclear Science, 57(4):1811-1819, Aug 2010. ISSN 0018-9499. doi: 10.1109/TNS.2010.2048927.
[38] V. Ferlet-Cavrois, L. W. Massengill, and P. Gouker. Single event transients in digital cmos 2014; a review. IEEE Trans. on Nuclear Science, 6 (1):1767-1790, 2013.
[39] F. Firouzi, M. E. Salehi, F. Wang, S. M. Fakhraie, and S. Safari. Reliability-aware dynamic voltage and frequency scaling. In 2010 IEEE

Computer Society Annual Symposium on VLSI, pages 304-309, July 2010. doi: 10.1109/ISVLSI.2010.54.
[40] Farshad Firouzi, Mostafa E. Salehi, Fan Wang, and Sied Mehdi Fakhraie. An accurate model for soft error rate estimation considering dynamic voltage and frequency scaling effects. Microelectronics Reliability, 51 (2):460-467, 2011. ISSN 0026-2714. doi: https://doi.org/10.1016/ j.microrel.2010.08.016. URL http://www.sciencedirect.com/science/ article/pii/S0026271410004804. 2010 Reliability of Compound Semiconductors (ROCS) Workshop Prognostics and Health Management.
[41] J. Torras Flaquer, J.M. Daveau, L. Naviner, and P. Roche. Fast reliability analysis of combinatorial logic circuits using conditional probabilities. Microelectronics Reliability, 50(9): 1215 - 1218, 2010. ISSN 00262714. doi: https://doi.org/10.1016/j.microrel.2010.07.058. URL http: //www.sciencedirect.com/science/article/pii/S0026271410003318. 21st European Symposium on the Reliability of Electron Devices, Failure Physics and Analysis.
[42] International Technology Roadmap for Semiconductor. Itrs executive summary. Technical report, International Roadmap Committee, 2011. URL https://www.semiconductors.org/clientuploads/Research_ Technology/ITRS/2011/2011ExecSum.pdf.
[43] International Technology Roadmap for Semiconductor. Itrs executive summary. Technical report, International Roadmap Committee, 2007. URL http://www.itrs2.net/itrs-reports.html.
[44] A. M. Francis, M. Turowski, J. A. Holmes, and H. A. Mantooth. Efficient modeling of single event transients directly in compact device models. In 2007 IEEE International Behavioral Modeling and Simulation Workshop, pages 73-77, Sept 2007. doi: 10.1109/BMAS.2007.4437528.
[45] D. T. Franco, M. Correia Vasconcelos, L. Naviner, and J. F. Naviner. Reliability analysis of logic circuits based on signal probability. In 2008 15th IEEE International Conference on Electronics, Circuits and Systems, pages 670-673, Aug 2008. doi: 10.1109/ICECS.2008.4674942.
[46] Rajesh Garg. Analysis and Design of Resilient VLSI Circuits: Mitigating Soft Errors and Process Variations. Springer Publishing Company, Incorporated, 2014. ISBN 1489985107, 9781489985101.
[47] C. S. Guenzer, E. A. Wolicki, and R. G. Allas. Single event upset of dynamic rams by neutrons and protons. IEEE Transactions on Nuclear Science, 26(6):5048-5052, Dec 1979. ISSN 0018-9499. doi: 10.1109/ TNS. 1979.4330270.
[48] G. Bany Hamad, S. R. Hasan, O. A. Mohamed, and Y. Savaria. New insights into the single event transient propagation through static and tspc logic. IEEE Transactions on Nuclear Science, 61(4):1618-1627, Aug 2014. ISSN 0018-9499. doi: 10.1109/TNS.2014.2305434.
[49] J. Han, H. Chen, J. Liang, P. Zhu, Z. Yang, and F. Lombardi. A stochastic computational approach for accurate and efficient reliability evaluation. IEEE Transactions on Computers, 63(6):1336-1350, June 2014. ISSN 0018-9340. doi: 10.1109/TC.2012.276.
[50] Jie Han, Hao Chen, Erin Boykin, and JosÃ® Fortes. Reliability evaluation of logic circuits using probabilistic gate models. Microelectronics Reliability, 51(2):468-476, 2011. ISSN 0026-2714. doi: https://doi. org/10.1016/j.microrel.2010.07.154. URL http://www.sciencedirect. com/science/article/pii/S0026271410004270. 2010 Reliability of Compound Semiconductors (ROCS) Workshop Prognostics and Health Management.
[51] Mark C. Hansen, Hakan Yalcin, and John P. Hayes. Unveiling the iscas85 benchmarks: a case study in reverse engineering. IEEE Design and Test, 16(3):72-80, 7 1999. ISSN 2168-2356. doi: 10.1109/54.785838.
[52] M. Hashimoto, W. Liao, and S. Hirokawa. Soft error rate estimation with tcad and machine learning. In 2017 International Conference on Simulation of Semiconductor Processes and Devices (SISPAD), pages 129-132, Sept 2017. doi: 10.23919/SISPAD.2017.8085281.
[53] J. P. Hayes, I. Polian, and B. Becker. An analysis framework for transienterror tolerance. In 25th IEEE VLSI Test Symposium (VTS'07), pages 249-255, May 2007. doi: 10.1109/VTS.2007.13.
[54] T. Heijmen, D. Giot, and P. Roche. Factors that impact the critical charge of memory elements. In 12th IEEE International On-Line Testing Symposium (IOLTS’06), pages 6 pp.-, 2006. doi: 10.1109/IOLTS.2006. 35.
[55] Tino Heijmen. Radiation-induced soft errors in digital circuits - a literature survey, 2002.
[56] M. Hosseinabady, P. Lotfi-Kamran, J. Mathew, S. Mohanty, and D. Pradhan. Single-event transient analysis in high speed circuits. In Electronic System Design (ISED), 2011 International Symposium on, pages 112-117, Dec 2011. doi: 10.1109/ISED.2011.73.
[57] R. H. M. Huang and C. H. P. Wen. Advanced soft-error-rate (ser) estimation with striking-time and multi-cycle effects. In 201451 st ACM/EDAC/IEEE Design Automation Conference (DAC), pages 1-6, June 2014.
[58] S. i. Abe, R. Ogata, and Y. Watanabe. Impact of nuclear reaction models on neutron-induced soft error rate analysis. IEEE Transactions on Nuclear Science, 61(4):1806-1812, Aug 2014. ISSN 0018-9499. doi: 10.1109/TNS.2014.2307298.
[59] E.H. Ibe. Terrestrial Radiation Effects in ULSI Devices and Electronic Systems. Wiley - IEEE. Wiley, 2015. ISBN 9781118479292.
[60] A. Javanainen, T. Malkiewicz, J. Perkowski, W. H. Trzaska, A. Virtanen, G. Berger, W. Hajdas, R. Harboe-Sorensen, H. Kettunen, V. Lyapin, M. Mutterer, A. Pirojenko, I. Riihimaki, T. Sajavaara, G. Tyurin, and H. J. Whitlow. Linear energy transfer of heavy ions in silicon. IEEE Transactions on Nuclear Science, 54(4):1158-1162, Aug 2007. ISSN 0018-9499. doi: 10.1109/TNS.2007.895121.
[61] Barry Johnson. An introduction to the design and analysis of faulttolerant systems. pages 1-87, 021996.
[62] T. Karnik and P. Hazucha. Characterization of soft errors caused by single event upsets in cmos processes. IEEE Transactions on Dependable and Secure Computing, 1(2):128-143, April 2004. ISSN 1545-5971. doi: 10.1109/TDSC.2004.14.
[63] F.L. Kastensmidt, J. Tonfat, T. Both, P. Rech, G. Wirth, R. Reis, F. Bruguier, P. Benoit, L. Torres, and C. Frost. Voltage scaling and aging effects on soft error rate in sram-based fpgas. Microelectronics Reliability, 54(9):2344 - 2348, 2014. ISSN 0026-2714. doi: https://doi.org/10.1016/j.microrel.2014.07.100. URL http://www.
sciencedirect.com/science/article/pii/S0026271414002960. SI: ESREF 2014.
[64] J. S. Kauppila, A. L. Sternberg, M. L. Alles, A. M. Francis, J. Holmes, O. A. Amusan, and L. W. Massengill. A bias-dependent single-event compact model implemented into bsim4 and a 90 nm cmos process design kit. IEEE Trans. on Nuclear Science, 56(6):3152-3157, Dec 2009. ISSN 0018-9499. doi: 10.1109/TNS.2009.2033798.
[65] Jeffrey S. Kauppila. Layout-Aware Modeling and Analysis Methodologies for Transient Radiation Effects on Integrated Circuit Electronics. PhD thesis, Electrical Engineering, Vanderbilt University, 2015.
[66] Wonyoung Kim, M. S. Gupta, G. Wei, and D. Brooks. System level analysis of fast, per-core dvfs using on-chip switching regulators. In 2008 IEEE 14 th International Symposium on High Performance Computer Architecture, pages 123-134, Feb 2008. doi: 10.1109/HPCA.2008.4658633.
[67] H. Kobayashi, N. Kawamoto, J. Kase, and K. Shiraish. Alpha particle and neutron-induced soft error rates and scaling trends in sram. In 2009 IEEE International Reliability Physics Symposium, pages 206-211, April 2009. doi: 10.1109/IRPS.2009.5173252.
[68] Niita Koji, Matsuda Norihiro, Iwamoto Yosuke, Sato Tatsuhiko, Nakashima Hiroshi, Sakamoto Yukio, Iwase Hiroshi, and Sihver Lembit. Phits: Particle and heavy ion transport code system, version 2.23. Technical report, 2010.
[69] S. Krishnaswamy, G. F. Viamontes, I. L. Markov, and J. P. Hayes. Accurate reliability evaluation and enhancement via probabilistic transfer matrices. In Design, Automation and Test in Europe, pages 282-287 Vol. 1, March 2005. doi: 10.1109/DATE.2005.47.
[70] S. Krishnaswamy, I. L. Markov, and J. P. Hayes. On the role of timing masking in reliable logic circuit design. In 2008 45th ACM/IEEE Design Automation Conference, pages 924-929, June 2008. doi: 10.1145/ 1391469.1391703.
[71] S. Krishnaswamy, I.L. Markov, and J.P. Hayes. Design, Analysis and Test of Logic Circuits Under Uncertainty. Lecture Notes in Electrical Engineering. Springer Netherlands, 2012. ISBN 9789048196449.
[72] Smita Krishnaswamy. Design, Analysis and Test of Logic Circuits under Uncertainty. PhD thesis, Computer Science and Engineering, The University of Michigan, 2008.
[73] Santosh Kumar, Shalu Agarwal, and Jae Pil Jung. Soft error issue and importance of low alpha solders for microelectronics packaging. Reviews on advanced materials science., 3(2), 2013. ISSN 1606-5131.
[74] Yu-Hsin Kuo, Huan-Kai Peng, and C. H. P. Wen. Accurate statistical soft error rate (sser) analysis using a quasi-monte carlo framework with quality cell models. In 2010 11th International Symposium on Quality Electronic Design (ISQED), pages 831-838, March 2010. doi: 10.1109/ISQED.2010.5450485.
[75] Cristiano Lazzari, Gilson Wirth, Fernanda Lima Kastensmidt, Lorena Anghel, and Ricardo Augusto da Luz Reis. Asymmetric transistor sizing targeting radiation-hardened circuits. Electrical Engineering, 94(1):1118, Mar 2012. ISSN 1432-0487. doi: 10.1007/s00202-011-0212-8. URL https://doi.org/10.1007/s00202-011-0212-8.
[76] J.L. Leray. Effects of atmospheric neutrons on devices, at sea level and in avionics embedded systems. Microelectronics Reliability, 47(9): 1827 1835, 2007. ISSN 0026-2714. doi: https://doi.org/10.1016/j.microrel. 2007.07.101. URL http://www.sciencedirect.com/science/article/pii/ S0026271407003666. 18th European Symposium on Reliability of Electron Devices, Failure Physics and Analysis.
[77] Ji Li and Jeffrey Draper. Accelerated soft-error-rate (ser) estimation for combinational and sequential circuits. ACM Trans. Des. Autom. Electron. Syst., 22(3):57:1-57:21, May 2017. ISSN 1084-4309. doi: 10.1145/3035496. URL http://doi.acm.org/10.1145/3035496.
[78] R. Liu, A. Evans, B. Wu, Y. Li, L. Chen, S. J. Wen, R. Wong, and R. Fung. Analysis of advanced circuits for set measurement. In 2015 IEEE International Reliability Physics Symposium, pages SE.7.1-SE.7.7, April 2015. doi: 10.1109/IRPS.2015.7112827.
[79] A. Maheshwari, W. Burleson, and R. Tessier. Trading off transient fault tolerance and power consumption in deep submicron (dsm) vlsi circuits. IEEE Transactions on Very Large Scale Integration (VLSI) Systems, 12
(3):299-311, March 2004. ISSN 1063-8210. doi: 10.1109/TVLSI. 2004. 824302.
[80] D. G. Mavis and P. H. Eaton. Seu and set modeling and mitigation in deep submicron technologies. In 2007 IEEE International Reliability Physics Symposium Proceedings. 45th Annual, pages 293-305, April 2007. doi: 10.1109/RELPHY.2007.369907.
[81] D. G. Mavis and P. H. Eaton. Soft error rate mitigation techniques for modern microcircuits. In 2002 IEEE International Reliability Physics Symposium. Proceedings. 40th Annual (Cat. No.02CH37320), pages 216225, 2002. doi: 10.1109/RELPHY.2002.996639.
[82] T. C. May and M. H. Woods. A new physical mechanism for soft errors in dynamic memories. In 16th International Reliability Physics Symposium, pages 33-40, April 1978. doi: 10.1109/IRPS.1978.362815.
[83] T. C. May and M. H. Woods. Alpha-particle-induced soft errors in dynamic memories. IEEE Transactions on Electron Devices, 26(1):2-9, Jan 1979. ISSN 0018-9383. doi: 10.1109/T-ED.1979.19370.
[84] G. C. Messenger. Collection of charge on junction nodes from ion tracks. IEEE Transactions on Nuclear Science, 29(6):2024-2031, Dec 1982. ISSN 0018-9499. doi: 10.1109/TNS.1982.4336490.
[85] N. Miskov-Zivanov and D. Marculescu. Mars-c: modeling and reduction of soft errors in combinational circuits. In 2006 43rd ACM/IEEE Design Automation Conference, pages 767-772, July 2006. doi: 10.1145/ 1146909.1147104.
[86] N. Miskov-Zivanov and D. Marculescu. Circuit reliability analysis using symbolic techniques. IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, 25(12):2638-2649, Dec 2006. ISSN 0278-0070. doi: 10.1109/TCAD.2006.882592.
[87] N. Miskov-Zivanov and D. Marculescu. Multiple transient faults in combinational and sequential circuits: A systematic approach. IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, 29(10):1614-1627, Oct 2010. ISSN 0278-0070. doi: 10.1109/ TCAD.2010.2061131.
[88] Sparsh Mittal. A survey of techniques for improving energy efficiency in embedded computing systems. International Journal of Computer Aided Engineering and Technology, 6(4):440-459, 2014. doi: 10.1504/IJCAET. 2014.065419. URL https://hal.archives-ouvertes.fr/hal-01101854.
[89] Arkadiy Morgenshtein. Short-circuit power reduction by using highthreshold transistors. Journal of Low Power Electronics and Applications, 2(1):69-78, 2012. ISSN 2079-9268. doi: 10.3390/jlpea2010069. URL http://www.mdpi.com/2079-9268/2/1/69.
[90] William J. Morokoff and Russel E. Caflisch. Quasi-random sequences and their discrepancies. SIAM J. Sci. Comput, 15:1251-1279, 1994.
[91] D. Munteanu and J. L. Autran. Modeling and simulation of single-event effects in digital devices and ics. IEEE Trans. on Nuclear Science, 55 (4):1854-1878, Aug 2008. ISSN 0018-9499. doi: 10.1109/TNS.2008. 2000957.
[92] Arthur Musah and Andy Dykstra. Power-management techniques for omap35x applications processors. Technical report, Texas Instruments, 2008.
[93] B. Narasimham, B. L. Bhuva, W. T. Holman, R. D. Schrimpf, L. W. Massengill, A. F. Witulski, and W. H. Robinson. The effect of negative feedback on single event transient propagation in digital circuits. IEEE Trans. on Nuclear Science, 53(6):3285-3290, Dec 2006. ISSN 0018-9499. doi: 10.1109/TNS.2006.885380.
[94] B. Narasimham, M. J. Gadlage, B. L. Bhuva, R. D. Schrimpf, L. W. Massengill, W. T. Holman, A. F. Witulski, R. A. Reed, R. A. Weller, and X. Zhu. Characterization of neutron- and alpha-particle-induced transients leading to soft errors in 90-nm cmos technology. IEEE Trans. on Device and Materials Reliability, 9(2):325-333, June 2009. ISSN 1530-4388. doi: 10.1109/TDMR.2009.2020912.
[95] R. Naseer, Y. Boulghassoul, J. Draper, S. DasGupta, and A. Witulski. Critical charge characterization for soft error rate modeling in 90 nm sram. pages 1879-1882, May 2007. ISSN 0271-4302. doi: 10.1109/ ISCAS.2007.378282.
[96] Miskov-Zivanov Natasa and Marculescu Diana. Modeling and analysis of ser in combinational circuits. In IEEE Workshop on Silicon Errors in Logic System Effects (SELSE), Mar 2010.
[97] V. P. Nelson. Fault-tolerant computing: fundamental concepts. Computer, 23(7):19-25, July 1990. ISSN 0018-9162. doi: 10.1109/2.56849.
[98] D. M. Newberry, D. H. Kaye, and G. A. Soli. Single event induced transients in i/o devices: a characterization. IEEE Transactions on Nuclear Science, 37(6):1974-1980, Dec 1990. ISSN 0018-9499. doi: 10.1109/23.101217.
[99] M. Nicolaidis. Soft Errors in Modern Electronic Systems. Frontiers in Electronic Testing. Springer US, 2010. ISBN 9781441969934.
[100] M. Nicolaidis. Time redundancy based soft-error tolerance to rescue nanometer technologies. In Proceedings 17th IEEE VLSI Test Symposium (Cat. No.PROO146), pages 86-94, 1999. doi: 10.1109/VTEST. 1999. 766651.
[101] M. Nicolaidis. Graal: a new fault tolerant design paradigm for mitigating the flaws of deep nanometric technologies. In 2007 IEEE International Test Conference, pages 1-10, Oct 2007. doi: 10.1109/TEST.2007. 4437666.
[102] C. Ouyang, J. Jiang, and J. Xiao. Reliability evaluation of flip-flops based on probabilistic transfer matrices. In 2010 IEEE 16th Pacific Rim International Symposium on Dependable Computing, pages 239-240, Dec 2010. doi: 10.1109/PRDC.2010.22.
[103] G. I. Paliaroutis, P. Tsoumanis, N. Evmorfopoulos, G. Dimitriou, and G. I. Stamoulis. Placement-based ser estimation in the presence of multiple faults in combinational logic. In 2017 27th International Symposium on Power and Timing Modeling, Optimization and Simulation (PATMOS), pages 1-6, Sept 2017. doi: 10.1109/PATMOS.2017.8106949.
[104] K. P. Parker and E. J. McCluskey. Analysis of logic circuits with faults using input signal probabilities. IEEE Transactions on Computers, C-24(5):573-578, May 1975. ISSN 0018-9340. doi: 10.1109/T-C. 1975. 224264.
[105] Ketan N. Patel, Igor L. Markov, and John P. Hayes. Evaluating circuit reliability under probabilistic gate-level fault models. In In International Workshop on Logic Synthesis (IWLS, pages 59-64, 2003.
[106] I. Polian, J. P. Hayes, S. M. Reddy, and B. Becker. Modeling and mitigating transient errors in logic circuits. IEEE Trans. on Dependable and Secure Computing, 8(4):537-547, July 2011. ISSN 1545-5971. doi: 10.1109/TDSC.2010.26.
[107] R. Rajaraman, J. S. Kim, N. Vijaykrishnan, Y. Xie, and M. J. Irwin. Seatla: a soft error analysis tool for combinational logic. In 19th International Conference on VLSI Design held jointly with 5th International Conference on Embedded Systems Design (VLSID'06), pages 4 pp.-, Jan 2006. doi: 10.1109/VLSID.2006.143.
[108] M. Raji, F. Saeedi, B. Ghavami, and H. Pedram. An efficient approach for soft error rate estimation of combinational circuits. In 2014 17th Euromicro Conference on Digital System Design, pages 567-574, Aug 2014. doi: 10.1109/DSD.2014.67.
[109] M. Raji, B. Ghavami, and H. Pedram. Gate resizing for soft error rate reduction in nano-scale digital circuits considering process variations. In 2015 Euromicro Conference on Digital System Design, pages 445-452, Aug 2015. doi: 10.1109/DSD.2015.103.
[110] R. R. Rao, K. Chopra, D. T. Blaauw, and D. M. Sylvester. Computing the soft error rate of a combinational logic circuit using parameterized descriptors. IEEE Trans. on Computer-Aided Design of Integrated Circuits and Systems, 26(3):468-479, March 2007. ISSN 0278-0070. doi: 10. 1109/TCAD.2007.891036.
[111] Siavash Rezaei, Seyed Ghassem Miremadi, Hossein Asadi, and Mahdi Fazeli. Soft error estimation and mitigation of digital circuits by characterizing input patterns of logic gates. Microelectronics Reliability, 54(6): 1412 - 1420, 2014. ISSN 0026-2714. doi: https://doi.org/10.1016/ j.microrel.2014.03.003. URL http://www.sciencedirect.com/science/ article/pii/S0026271414000948.
[112] P. Rinard. Neutron interactions with matter. Technical report, 1991. URL https://www.fas.org/sgp/othergov/doe/lanl/lib-www/ la-pubs/00326407.pdf.
[113] D. Rossi, J. M. Cazeaux, M. Omana, C. Metra, and A. Chatterjee. Accurate linear model for set critical charge estimation. IEEE Transactions on Very Large Scale Integration (VLSI) Systems, 17(8):1161-1166, Aug 2009. ISSN 1063-8210. doi: 10.1109/TVLSI.2009.2020391.
[114] D. Rossi, M. Omana, C. Metra, and A. Paccagnella. Impact of aging phenomena on soft error susceptibility. In 2011 IEEE International Symposium on Defect and Fault Tolerance in VLSI and Nanotechnology Systems, pages 18-24, Oct 2011. doi: 10.1109/DFT.2011.45.
[115] K. Roy, S. Mukhopadhyay, and H. Mahmoodi-Meimand. Leakage current mechanisms and leakage reduction techniques in deep-submicrometer cmos circuits. Proceedings of the IEEE, 91(2):305-327, Feb 2003. ISSN 0018-9219. doi: 10.1109/JPROC.2002.808156.
[116] S. Sayil, A. Shah, M. Zaman, and M. Islam. Soft error mitigation using transmission gate with varying gate and body bias. IEEE Design Test, PP (99):1-1, 2015. ISSN 2168-2356. doi: 10.1109/MDAT.2015.2499272.
[117] S. Sayil, A. H. Shah, M. A. Zaman, and M. A. Islam. Soft error mitigation using transmission gate with varying gate and body bias. IEEE Design Test, 34(1):47-56, Feb 2017. ISSN 2168-2356. doi: 10.1109/MDAT. 2015.2499272.
[118] Eitan N. Shauly. Cmos leakage and power reduction in transistors and circuits: Process and layout considerations. Journal of Low Power Electronics and Applications, 2(1):1-29, 2012. ISSN 2079-9268. doi: 10.3390/jlpea2010001. URL http://www.mdpi.com/2079-9268/2/1/1.
[119] N.S.S. Singh, N.H. Hamid, and V.S. Asirvadam. Error threshold for individual faulty gates using probabilistic transfer matrix (ptm). AASRI Procedia, 9:138 - 145, 2014. ISSN 2212-6716. doi: https://doi. org/10.1016/j.aasri.2014.09.022. URL http://www.sciencedirect.com/ science/article/pii/S221267161400122X. 2014 AASRI Conference on Circuit and Signal Processing (CSP 2014).
[120] M. Slimani and L. Naviner. A tool for transient fault analysis in combinational circuits. In 2015 IEEE International Conference on Electronics, Circuits, and Systems (ICECS), pages 125-128, Dec 2015. doi: 10.1109/ICECS.2015.7440265.
[121] I.E. Sutherland, R.F. Sproull, and D.F. Harris. Logical Effort: Designing Fast CMOS Circuits. The Morgan Kaufmann Series in Computer Architecture and Design Series. Morgan Kaufmann Publishers, 1999. ISBN 9781558605572.
[122] S. M. Tahinuzzaman. Modeling and mitigation of soft errors in nanoscale SRAMs. PhD thesis, University of Waterloo, 2008.
[123] M. Turowski, A. Raman, and G. Jablonski. Mixed-mode simulation and analysis of digital single event transients in fast cmosics. In 2007 14th International Conference on Mixed Design of Integrated Circuits and Systems, pages 433-438, June 2007. doi: 10.1109/MIXDES.2007. 4286199.
[124] J. von Neumann. Probabilistic logics and synthesis of reliable organisms from unreliable components. In C. Shannon and J. McCarthy, editors, Automata Studies, pages 43-98. Princeton University Press, 1956.
[125] J. T. Wallmark and S. M. Marcus. Minimum size and maximum packing density of nonredundant semiconductor devices. Proceedings of the IRE, 50(3):286-298, March 1962. ISSN 0096-8390. doi: 10.1109/JRPROC. 1962.288321.
[126] F. Wang and V. D. Agrawal. Single event upset: An embedded tutorial. In 21st International Conference on VLSI Design (VLSID 2008), pages 429-434, Jan 2008. doi: 10.1109/VLSI.2008.28.
[127] F. Wang and V. D. Agrawal. Soft error rate determination for nanometer cmos vlsi logic. In 2008 40th Southeastern Symposium on System Theory (SSST), pages 324-328, March 2008. doi: 10.1109/SSST.2008.4480247.
[128] F. Wang and Y. Xie. Soft error rate analysis for combinational logic using an accurate electrical masking model. IEEE Trans. on Dependable and Secure Computing, 8(1):137-146, Jan 2011. ISSN 1545-5971. doi: 10.1109/TDSC.2009.29.
[129] F. Wang, Y. Xie, R. Rajaraman, and B. Vaidyanathan. Soft error rate analysis for combinational logic using an accurate electrical masking model. pages 165-170, Jan 2007. ISSN 1063-9667. doi: 10.1109/ VLSID.2007.145.
[130] G. Wirth, F. L. Kastensmidt, and I. Ribeiro. Single event transients in logic circuits-load and propagation induced pulse broadening. IEEE Trans. on Nuclear Science, 55(6):2928-2935, Dec 2008. ISSN 0018-9499. doi: 10.1109/TNS.2008.2006265.
[131] G. I. Wirth, M. G. Vieira, E. H. Neto, and F. G. L. Kastensmidt. Single event transients in combinatorial circuits. In 2005 18th Symposium on Integrated Circuits and Systems Design, pages 121-126, Sept 2005. doi: 10.1109/SBCCI.2005.4286843.
[132] J. L. Wirth and S. C. Rogers. The transient response of transistors and diodes to ionizing radiation. IEEE Transactions on Nuclear Science, 11(5): 24-38, Nov 1964. ISSN 0018-9499. doi: 10.1109/TNS2.1964.4315472.
[133] Jie Xiao, William Lee, Jianhui Jiang, and Xuhua Yang. Circuit reliability estimation based on an iterative ptm model with hybrid coding. Microelectronics Journal, 52:117-123, 2016. ISSN 00262692. doi: https://doi.org/10.1016/j.mejo.2016.03.013. URL http: //www.sciencedirect.com/science/article/pii/S0026269216300076.
[134] Ran Xiao and Chunhong Chen. Gate-level circuit reliability analysis: A survey. VLSI Des., 2014:4:4-4:4, January 2014. ISSN 1065-514X. doi: 10.1155/2014/529392. URL http://dx.doi.org/10.1155/2014/529392.
[135] S. Yang, W. Wang, T. Lu, W. Wolf, N. Vijaykrishnan, and Y. Xie. Case study of reliability-aware and low-power design. IEEE Transactions on Very Large Scale Integration (VLSI) Systems, 16(7):861-873, July 2008. ISSN 1063-8210. doi: 10.1109/TVLSI.2008.2000460.
[136] H. Zandevakili, A. Mahani, and M. Saneei. Reliability analysis of logic circuits using binary probabilistic transfer matrix. In 2013 21st Iranian Conference on Electrical Engineering (ICEE), pages 1-6, May 2013. doi: 10.1109/IranianCEE.2013.6599691.
[137] Bin Zhang, Wei-Shen Wang, and M. Orshansky. FASER: fast analysis of soft error susceptibility for cell-based designs. In 7th International Symposium on Quality Electronic Design (ISQED'06), pages 6 pp.-760, March 2006. doi: 10.1109/ISQED.2006.64.
[138] K. Zhang, S. Umehara, J. Yamaguchi, J. Furuta, and K. Kobayashi. Analysis of soft error rates in 65- and 28-nm fd-soi processes depending
on box region thickness and body bias by monte-carlo based simulations. IEEE Transactions on Nuclear Science, 63(4):2002-2009, Aug 2016. ISSN 0018-9499. doi: 10.1109/TNS.2016.2589268.
[139] M. Zhang and N. R. Shanbhag. Soft Error Rate Analysis (SERA) Methodology. IEEE Trans. on Computer-Aided Design of Integrated Circuits and Systems, 25(10):2140-2155, Oct 2006. ISSN 0278-0070. doi: 10.1109/TCAD.2005.862738.
[140] Quming Zhou and K. Mohanram. Gate sizing to radiation harden combinational logic. IEEE Trans. on Computer-Aided Design of Integrated Circuits and Systems, 25(1):155-166, Jan 2006. ISSN 0278-0070. doi: 10.1109/TCAD.2005.853696.
[141] Dakai Zhu, R. Melhem, and D. Mosse. The effects of energy management on reliability in real-time embedded systems. In IEEE/ACM International Conference on Computer Aided Design, 2004. ICCAD-2004., pages 35-40, Nov 2004. doi: 10.1109/ICCAD.2004.1382539.
[142] J. Ziegler and W. Lanford. The effect of sea level cosmic rays on electronic devices. In 1980 IEEE International Solid-State Circuits Conference. Digest of Technical Papers, volume XXIII, pages 70-71, Feb 1980. doi: 10.1109/ISSCC.1980.1156060.```

