Preprint

Probabilistic Sensitization Analysis for Variation-Aware Path Delay Fault Test Evaluation

Marcus Wagner and Hans-Joachim Wunderlich

Proceedings of the 22nd IEEE European Test Symposium (ETS'17), Limassol, Cyprus, 22-26 May 2017

doi: 10.1109/ETS.2017.7968226

This is the author's "personal copy" of the final, accepted version of the paper published by IEEE.
Probabilistic Sensitization Analysis for Variation-Aware Path Delay Fault Test Evaluation

Marcus Wagner, Hans-Joachim Wunderlich
Institute of Computer Architecture and Computer Engineering
University of Stuttgart, Pfaffenwaldring 47, D-70569 Stuttgart, Germany

Abstract—With the ever increasing process variability in recent technology nodes, path delay fault testing of digital integrated circuits has become a major challenge. A randomly chosen long path often has no robust test and many of the existing non-robust tests are likely invalidated by process variations. To generate path delay fault tests that are more tolerant towards process variations, the delay test generation must evaluate different non-robust tests and only those tests that sensitize the target path with a sufficiently high probability in presence of process variations must be selected. This requires a huge number of probability computations for a large number of target paths and makes the development of very efficient approximation algorithms mandatory for any practical application.

In this paper, a novel and efficient probabilistic sensitization analysis is presented which is used to extract a small subcircuit for a given test vector-pair. The probability that a target path is sensitized by the vector-pair is computed efficiently and without significant error by a Monte-Carlo simulation of the subcircuit.

Index Terms—delay test, process variations, delay test quality

I. INTRODUCTION

Increasing process variations and high defect densities present major challenges for the delay test of digital integrated circuits [1]. The critical task of delay testing is to check that all sensitizable paths in the manufactured circuits meet the timing constraints. A path is said to have a path delay fault if the delay of the path exceeds a given threshold, which in most cases is the circuit’s functional clock cycle time. Any path in a manufactured circuit can have a path delay fault due to process variations, a defect or a combination of both [2].

Delay testing is performed by applying a test vector-pair to the circuit inputs which sensitizes one or more paths in the circuit. A path is called sensitized if a transition is propagated from the beginning of the path, along the path, to the end of the path. To consider the impact of process variations on the delay test, the ability of a test vector-pair to detect a particular delay fault must be evaluated on a population of circuit instances. All circuit instances are functionally identical and each circuit instance has unique, fixed gate and interconnect delays. A test vector-pair that sensitizes a particular target path in one circuit instance might fail to sensitize the path in another circuit instance, which can result in lots of test escapes [3].

Classical path sensitization conditions are of limited use to describe the quality of path delay fault tests [4]. For example, a large number of paths have no robust test, but are non-robustly testable [5]. For any such path, usually many different non-robust tests exist [6] of which only very few might sensitize the path with sufficiently high probability in a randomly chosen circuit instance. Furthermore, a large number of paths that are neither robustly nor non-robustly testable can be functionally sensitized in a subset of all circuit instances [7].

Ignoring the impact of process variations on the target path sensitization is known to cause a significant error during the evaluation of small delay fault tests [8], [9]. Indeed, the quality of every delay test depends on the probability $P_{\text{sens}}$ that the test vector-pair sensitizes a particular target path in a randomly chosen circuit instance. To generate and select only those delay tests that most reliably sensitize the target paths under the impact of process variations, $P_{\text{sens}}$ must be efficiently computed for each target path, which clearly requires very efficient computation methods for any practical application.

In [10], all gate delays and transition arrival times are treated symbolically. For each path, conditions are derived under which the path is sensitized. The probability $P_{\text{sens}}$ can then be computed from these conditions. However, this approach is only applicable to small circuits as the size and complexity of these conditions tend to grow rapidly with the circuit size.

The probability $P_{\text{sens}}$ is approximated in [11], [12] by using the bounded delay model. However, it is assumed that all gate and path delays are independent and have a uniform distribution, which results in a large approximation error.

To efficiently compute the probability $P_{\text{sens}}$, a novel probabilistic sensitization analysis is proposed in this work, which extracts for a given test vector-pair a small subcircuit that initially consists only of the target paths. The analysis results are used to extend the subcircuit by additional paths that determine the sensitization of the target paths in any circuit instance. An example of the resulting representative subcircuit $S$ for target path d-h-k-m is shown in fig. 1. Here, the analysis has extended the subcircuit by the path a-e-j-m, which was found to determine the sensitization of the target path by the test vector-pair under the impact of process variations.

The probability $P_{\text{sens}}$ can be computed for all target paths very efficiently and without any significant error by a Monte Carlo simulation of only the representative subcircuit $S$. The experimental results with defect free circuits are compared to a subcircuit $L$, which is obtained by a logic simulation with a 13-valued logic [13]. In presence of a small delay fault, the results are compared to the support region $R$ of the small delay fault [14], which consists of the union of the input cones of all circuit outputs in the output cone of the fault location. The results show that $S$ is much smaller than $L$ and $R$ and that $S$
is extracted very fast, which results in a large speedup of the computation of $P_{\text{sens}}$ by a Monte-Carlo simulation of $S$.

The remainder of this paper is organized as follows. Section II details the probabilistic sensitization analysis of a single target path. The representative subcircuit and its subcircuit or in neither circuit, for all $1 \leq i \leq n$. A detailed description of all major steps of the sensitization analysis is given in the following subsections.

Fig. 1. Circuit and representative subcircuit (red) for a given test vector-pair

II. Sensitization Analysis of Single Target Path

Given a single target path $\pi$. At first, a subcircuit $S$ that consists only of the target path is extracted, where all floating off-path inputs and all floating circuit outputs have constant logic values. Next, a circuit instance $\theta_1$ and its subcircuit $S$ are simulated with the given test vector-pair. Suppose the target path is sensitized in either $S$ or $\theta_1$, but not in both. Then the goal of the sensitization analysis is to find a small extended subcircuit $S'$, such that the target path is sensitized in either both $\theta_1$ and its subcircuit $S'$ or in neither circuit. For this, the analysis traces and compares the propagation of the transitions in the circuit and its subcircuit to identify a sensitized path that determines the sensitization of $\pi$ but that is missing in $S$.

The analysis then proceeds with another circuit instance $\theta_2$ and the extended subcircuit $S'$. An important detail of the analysis is that the subcircuit always shares the same gate and interconnect delays with the circuit instance it is compared to.

The flowchart of the proposed analysis is presented in fig. 2. In the first step (A), the circuit instance and its subcircuit are simulated with the given test vector-pair. If the target path is sensitized in only either the circuit instance or its subcircuit, then the transition is traced backwards along the sensitized path in steps (B) and (C). It is guaranteed that the analysis will eventually trace back a transition along a sensitized path in $\theta_1$ that is not part of the subcircuit. The subcircuit is then extended by this sensitized path in step (D). Steps (B), (C) and (D) are skipped if the target path is sensitized in either both the circuit instance and the subcircuit or in neither circuit.

This algorithm is repeated for $n$ randomly chosen circuit instances $\theta_1, \ldots, \theta_n$ until the target path is either sensitized in both $\theta_i$ and $S$ or in neither circuit, for all $1 \leq i \leq n$.

A detailed description of all major steps of the sensitization analysis is given in the following subsections.

A. Simulation of Circuit Instance and its Subcircuit

The circuit instance and its subcircuit are simulated using a single event-driven timing simulation with the given test vector-pair. After a transition $\tau$ at an input of a gate has been propagated to the gate output, the resulting gate output transition is assigned a reference to $\tau$. Using these references, any sensitized path can be easily identified by following these references from a transition at a circuit output until a circuit input has been reached. To efficiently identify and compare the sensitized paths in different circuit instances and the subcircuit, each target path is assigned a unique number that is used for identification. This number is computed from the structural information of the path (e.g. from the names of the interconnects along the path) using a fast hash function.

Although this step is repeatedly executed by the algorithm, each circuit instance only needs to be simulated once and the simulation of the subcircuit is only repeated after extension.

B. Tracing of Inconsistently Sensitized Path

A path $\pi$ is said to be inconsistently sensitized if and only if $\pi$ is sensitized by the test vector-pair in only either the circuit instance $\theta_i$ or the subcircuit $S$. This means that $\pi$ contains a gate $g$ that propagates the transition from the on-path gate input to the gate output in only either $S$ or $\theta_i$. The goal of this step is to find this gate. In the following, a transition is said to exist in only either $\theta_i$ or $S$, if the transition was propagated along an inconsistently sensitized path.

Without loss of generality, let the target path be sensitized by the test vector-pair in $\theta_i$ but not in $S$. The idea is to trace the transition along the target path in the circuit instance $\theta_i$, starting at the respective circuit output. At each gate, the reference of the gate output transition is followed to the predecessor transition at one of the gate inputs. This tracing continues as long as the following two conditions are satisfied:

Fig. 2. Flowchart of probabilistic sensitization analysis algorithm
(i) The gate is part of the subcircuit \( S \).
(ii) The gate input transition \( \tau \) exists in \( \theta_i \) but not in \( S \).

A violation of the first condition (i) implies that at least one gate of the currently traced sensitized path must be missing in the subcircuit \( S \) and this path is added to the subcircuit in step (D). If the second condition (ii) is not satisfied, then this analysis step is complete and the currently considered gate is gate \( g \). The propagation of the transition \( \tau \) through this gate is analysed in the following step (C).

C. Analysis of Transition Propagation Condition

Suppose the transition \( \tau \) at an input of a gate causes a transition \( \tau' \) at the gate output at time \( t' \), without loss of generality, only in \( \theta_i \) but not in \( S \). By definition, the subcircuit \( S \) always inherits the gate delays from the circuit instance \( \theta_i \) it is compared to. This implies that another transition \( \tilde{\tau} \) must exist at the gate inputs in only either \( \theta_i \) or \( S \), which is responsible for \( \tau \) not being propagated to the gate output in \( S \). The goal of this step is to identify \( \tilde{\tau} \), which can then be traced backwards along an inconsistently sensitized path in step (B).

A gate input transition is propagated to the gate output if and only if it satisfies the transition propagation condition of the gate model, which is the conjunction of the dynamic sensitization condition and the inertial delay condition.

1) Analysis of Dynamic Sensitization Condition: This condition describes that \( \tau \) can only be propagated to the gate output if the result of the logic function that the gate implements changes in response to \( \tau \). Clearly, this condition is always satisfied for a buffer or an inverter. For \((N)AND/(N)OR\) gates, the other gate inputs must have the non-controlling value at the arrival time of \( \tau \). This algorithm requires an exception for \(XOR/XNOR\) gates, where the dynamic sensitization condition is redefined to be satisfied if and only if the logic values at all other gate inputs match in \( \theta_i \) and \( S \) at the arrival time of \( \tau \).

A violation of the dynamic sensitization condition implies that at least one transition \( \tau' \) exists at one of the off-path inputs in only either \( \theta_i \) or \( S \) and the analysis proceeds by tracing \( \tilde{\tau} \) in step (B). In case multiple transitions exist at the off-path inputs in only either \( \theta_i \) or \( S \), the one which occurs closest in time to \( t \) is selected instead.

The example in fig. 3 shows the last \( NOR \) gate \( (u_{S}) \) in fig. 1, which has a falling transition at each gate input. The waveforms in fig. 3 are the result of the simulation of the circuit instance \( \theta_i \) with the given test vector-pair. At the arrival time \( t \) of the on-path input transition \( \tau \), the off-path input \( 'j' \) has the controlling value so that \( \tau \) is not propagated to the gate output. Suppose the subcircuit \( S \) consists only of the target path \( d-h-k-m \) and the off-path input \( 'j' \) has the constant value \( '0' \) so that \( \tau \) satisfies the dynamic sensitization condition in the subcircuit. In this case, \( \tilde{\tau} \) is responsible for that \( \tau \) is propagated to the gate output only in \( S \) but not in \( \theta_i \) and the analysis proceeds by tracing \( \tilde{\tau} \) in step (B).

2) Analysis of Inertial Delay Condition: The inertial delay condition is used to model the limitation that a real gate cannot produce arbitrary short glitches at the gate output. This condition states that if a transition \( \tau_1 \) occurs at a gate input at time \( t_1 \) and causes a transition at the gate output after a delay \( \delta \), then another transition \( \tau_2 \) that arrives at a time \( t_2 > t_1 \) at the gate inputs will only be propagated to the gate outputs if \( t_2 > t_1 + \delta + 1 \). Otherwise, the incomplete charging or discharging of the gate output capacitance initiated by \( \tau_1 \) is reversed by \( \tau_2 \) and the gate output remains constant.

If \( \tau \) violates the inertial delay condition then at least one other transition \( \tilde{\tau} \) must exist at the gate inputs in only either \( \theta_i \) or \( S \). For a logic gate with only a single input, the proposed analysis selects the last gate input transition before time \( t' \) that exists in only either \( \theta_i \) or \( S \). The analysis then proceeds by tracing this transition in step (B).

For gates with multiple inputs, only those gate input transitions that satisfy the dynamic sensitization condition can be propagated to the gate output. Of those transitions, only those that occur before or directly after \( \tau \) but no later than \( t' \) are relevant for the propagation of \( \tau \). Suppose \( L_{\theta_i} \) and \( L_S \) are the sets of relevant gate input transitions in \( S \) and \( \theta_i \), respectively. Then \( L_{\theta_i} \cup L_S \) must contain a transition that exists in only either \( \theta_i \) or \( S \), which causes \( \tau \) not to be propagated to the gate output in the subcircuit \( S \).

For example, suppose the subcircuit \( S \) in fig. 1 also contains the path \( c-g-i-j-m \) and \( 'f' \) is set to logic \( '0' \). The waveforms at the inputs and outputs of the \( XNOR \) gate \( u_T \) in the circuit instance \( \theta_i \) and the subcircuit \( S \) are shown in fig. 4. In the circuit instance, the glitch at the output \( 'i' \) of \( u_0 \) does not occur, so that \( 'i' \) remains constant zero. In the subcircuit \( S \), however, the falling transition at \( 'g' \) is propagated to the output of \( u_0 \), because \( 'f' \) is set to the non-controlling value \( '0' \). Therefore, \( \tilde{\tau} \) appears at \( 'i' \) shortly after \( \tau \) occurs at \( 'e' \). In this example, \( \tau \) has not been propagated to the gate output by the time \( \tilde{\tau} \) occurs at the gate input, so that the gate output will remain constant \( '1' \).

![Fig. 3. Dynamic sensitization condition of NOR gate satisfied by \( \tilde{\tau} \) but violated by \( \tau \)](image)

![Fig. 4. Waveforms at XNOR gate inputs and output after the simulation of the test vector-pair](image)
In this example, the sets of relevant transitions are $L_{\theta_1} = \{\tau\}$ and $L_S = \{\tau, \bar{\tau}\}$. The analysis then selects the first transition in $L_{\theta_1} \cup L_S$ after $\tau$ that exists in only either $\theta_1$ or $S$. If no such transition exists, then the last transition in $L_{\theta_1} \cup L_S$ before $\tau$ that exists in only either $\theta_1$ or $S$, is chosen instead. In this example, the only possible choice is $\bar{\tau}$, which is then traced back in step (B).

D. Extension of Subcircuit by a Sensitized Path

To add a new path to the subcircuit, all gates and interconnects along this path are marked in the circuit instance and then all marked gates and interconnects are extracted. Afterwards, the floating off-path inputs of the new path are set to their respective non-controlling values. The floating off-path inputs of a XOR/XNOR gate are set the logic value that the off-path inputs had during the simulation of $\theta_1$ at the time the transition occurred at the respective on-path input. Similarly, all floating circuit outputs are set to those logic values that were observed during the simulation of $\theta_1$ at the clock cycle time. The above described constant logic assignments are stored to speed up later extensions of the subcircuit by additional paths.

III. EXTRACTION OF REPRESENTATIVE SUBCIRCUIT

In this section, the proposed sensitization analysis for a single target path is consecutively applied to each of the target paths of a given test vector-pair to extract a so called representative subcircuit, which is defined as follows.

Let $\nu$ denote a test vector-pair that sensitizes any path in a set of target paths $\Pi$ with non-negligible probability. Suppose $\theta$ is a randomly chosen circuit instance and $S$ is its subcircuit, which contains at least the target paths $\Pi$ and all floating inputs of $S$ are set to constant logic values. The subcircuit $S$ is called representative subcircuit for $\nu$, if the probability $P_{ips}$ that a randomly chosen target path is inconsistently sensitized by $\nu$ in $\theta$ and $S$ is below a given threshold $P_{th}$ with 95% confidence.

Given a subcircuit $S$ that consists only of the target paths $\Pi$ and a set of $n$ circuit instances $\Theta = \{\theta_1, \ldots, \theta_n\}$. After the circuit instance $\theta_i \in \Theta$ and its subcircuit $S$ have been simulated, the algorithm in section II is applied to each of the target paths in $\Pi$ that are sensitized in $\theta_i$ or $S$. This process is repeated for all circuit instances in $\Theta$ until none of the paths in $\Pi$ is inconsistently sensitized in $\theta_1, \ldots, \theta_n$ and $S$.

To test if $S$ is a representative subcircuit, another set of $n$ circuit instances $\Theta' = \{\theta'_1, \ldots, \theta'_n\}$ is randomly chosen. Let $p$ denote the probability that at least one of $k$ randomly chosen target paths is inconsistently sensitized in a randomly chosen circuit instance $\theta'_i$ and $S$. If $k$ is much smaller than $|\Pi|$, then $p \approx 1 - (1 - P_{ips})^k$. Suppose none of the $k$ target paths is inconsistently sensitized in $\theta'_1, \ldots, \theta'_n$ and $S$. Then the rule of three states that $p \in [0, 3/n]$ with 95% confidence [15]. Thus, $S$ is a representative subcircuit if and only if

$$n \geq 3/(1 - (1 - P_{ips})^k) \quad \text{(1)}$$

is satisfied, where suitable small values for $n$ and $k$ must be chosen by replacing $P_{ips}$ in ineq. (1) with the threshold $P_{th}$.

Otherwise, if one of the $k$ target paths is inconsistently sensitized, then $S$ is extended further using the joint set of circuit instances $\Theta \cup \Theta'$ and this process is repeated.

It is also possible to extract a subcircuit that is a representative subcircuit for multiple test vector-pairs by extending the representative subcircuit for one test vector-pair with the analysis in section II using another test vector-pair.

IV. EXPERIMENTAL RESULTS

Several NXP benchmark circuits were first optimized for speed and then mapped to the NanGate 45nm Open Cell Library [16] using a commercial synthesis tool. The accurate gate model defined by the Verilog HDL standard [17] is used. For the generation of the circuit instances, every delay value of a gate is assumed to have a normal distribution with mean $\mu$ and variance $(c_v\mu)^2$, where $\mu$ is the nominal delay value from the standard delay format description of the synthesized circuit. To study innovative process technology nodes, a variation coefficient of $c_v = 0.25$ was selected [18]. The correlation coefficient between any pair of delay values is 0.5 to account for both inter-die and intra-die variations.

To detect path delay faults, a commercial static timing analysis tool was used to identify the 10000 longest paths in each benchmark circuit, where at most 5 paths were allowed to terminate at the same circuit input or output. Afterwards, a commercial ATPG tool was used to create test vector-pairs that non-robustly sensitize as many of these paths as possible.

Additional test vector-pairs for the detection of small delay faults have been generated as follows. For each circuit, a set of 20000 randomly chosen marginally detectable small delay faults was created. A small delay fault is marginally detectable if the fault size is equal to the slack of the longest sensitizable path through the fault site. Afterwards, a commercial ATPG tool was used to create test vector-pairs that non-robustly sensitize the longest sensitizable paths through each fault site.

Only sufficiently long paths, which are also sensitized by the test vector-pair, can have a significant impact on the delay test result. For path delay fault tests, it is therefore assumed that the target paths of a test vector-pair are the critical paths that are sensitized by the test vector-pair in a randomly chosen circuit instance with non-negligible probability. A logical path is called critical path if and only if $\mu + 3\sigma \geq T_{clk}$, where $\mu$ and $\sigma$ denote the mean and standard deviation of the path delay, respectively, and $T_{clk}$ is the clock cycle time. For small delay fault tests, the set of target paths is further restricted to only those critical paths that pass through the fault site.

For a fixed $k$, decreasing the threshold $P_{th}$ increases the number of circuit instances $n$ that are required to satisfy ineq. (1), resulting in greater size and simulation accuracy of the subcircuit. For high accuracy, a tiny threshold of $P_{th} = 0.0062$ and a small $k = 10$ was chosen, so that $n = 50$ is sufficient.

The subcircuit $S$ is compared to three other subcircuits $S_L$ and $R$, where $S$ consists only of the critical paths that are sensitized in the nominal circuit instance and $L$ is obtained by a simulation with a 13-valued logic [13] after which any gate with an output that is constant or that has become unconnected
is removed. In presence of a small delay fault, $S$ and $\bar{S}$ are compared to the support region $R$ of the fault location [14].

The accuracy of the simulation of the final subcircuits $\bar{S}$ and $S$ was evaluated using $10^4$ circuit instances of $L$ and $R$, respectively. After the simulation of a circuit instance $\theta$ and its subcircuits $\bar{S}$ and $S$ are identified and compared to compute the probability that a target path is inconsistently sensitized. Furthermore, the logic values at the circuit outputs of $\theta$, $S$ and $\bar{S}$ were observed at the clock cycle time. If the observed output values differ from the expected values, then a fault has been detected. A subcircuit is said to provide an inconsistent test result, if a fault is detected in only either the circuit instance or the subcircuit.

The experimental results for path delay fault tests with defect free circuits are presented in table Ia. Further experimental results are shown in table Ib for small delay fault tests in circuits with a marginally detectable small delay fault. Both tables show the average results over all test vector-pairs.

The name and the number of gates (#gates) of the NXP benchmark circuit is shown in the first and second column, respectively. The clock cycle time $T_{clk}$ was determined such that 40%, 20% or 5% of the defect-free manufactured chips would fail the timing requirements due to process variations. The next columns $|L|$ and $|R|$ present the relative size of the subcircuits $L$ and $R$, respectively. The relative size of a subcircuit is defined as the relative number of gates in the subcircuit, compared to the number of gates in the circuit. The following six columns and the last seven columns present the results for the subcircuit $\bar{S}$ and $S$, respectively.

The average number of target paths of a test vector-pair is shown in column "#targ. paths", $S$ contains many more target paths than $\bar{S}$ because only few critical paths are sensitized by the test vector-pair in the nominal circuit instance and many other critical paths are sensitized in other circuit instances.

The relative size of the subcircuits $\bar{S}$ and $S$ is presented in $|\bar{S}|$ and $|S|$, respectively. The experimental results show that the representative subcircuit $\bar{S}$ is only slightly greater than the subcircuit $\bar{S}$ and, most importantly, much smaller than the

| circuit name | #gates | $T_{clk}$ [ps] | $|\bar{S}|$ [%] | $|S|$ [%] | $P_{ips}$ [%] | $P_{itr}$ [%] | Speedup |
|-------------|--------|-------------|-------------|-------------|-------------|-------------|--------|
| p35k        | 28115  | 1163.6      | 11.1        | 40.92       | 0.28        | 38.89       | 7.67    | 52.0  | 140.3  | 106.8  | 0.27    | 0.10    | 11.7  |
| p45k        | 26954  | 889.4       | 19.2        | 10.30       | 0.81        | 47.81       | 27.39   | 32.7  | 132.1  | 130.2  | 0.15    | 0.02    | 6.2   |
| p77k        | 41797  | 5805.2      | 2.9         | 2.69        | 0.10        | 1.21        | 2.03    | 107.9 | 101.8  | 133.7  | 3.3     | 0.02    | 11.3  |
| p78k        | 57535  | 1213.3      | 72.8        | 16.66       | 1.74        | 40.82       | 43.55   | 35.6  | 158.6  | 595.1  | 37.02   | 1.23    | 3.5   |
| p81k        | 91756  | 1109.7      | 34.00       | 118.6       | 21.72       | 2.17        | 29.49   | 73.13 | 125.7  | 1444.4 | 24.13   | 12.17   | 2.0   |
| p100k       | 61749  | 1400.1      | 42.9        | 22.01       | 30.22       | 59.11       | 197.59  | 31.9  | 248.9  | 19.9   | 3.09    | 0.28    | 9.5   |
| p267k       | 138912 | 87.9        | 29.1        | 11.41       | 1.07        | 69.21       | 52.38   | 26.5  | 120.2  | 908.0  | 16.20   | 2.76    | 6.6   |
| p330k       | 184425 | 1023.5      | 254.5       | 17.28       | 1.39        | 46.46       | 78.49   | 23.5  | 125.4  | 1933.9 | 21.99   | 7.69    | 3.2   |

| circuit name | #gates | $T_{clk}$ [ps] | $|\bar{S}|$ [%] | $|S|$ [%] | $P_{ips}$ [%] | $P_{itr}$ [%] | Speedup |
|-------------|--------|-------------|-------------|-------------|-------------|-------------|--------|
| p35k        | 28115  | 1163.6      | 11.1        | 40.92       | 0.28        | 38.89       | 7.67    | 52.0  | 140.3  | 106.8  | 0.27    | 0.10    | 11.7  |
| p45k        | 26954  | 889.4       | 19.2        | 10.30       | 0.81        | 47.81       | 27.39   | 32.7  | 132.1  | 130.2  | 0.15    | 0.02    | 6.2   |
| p77k        | 41797  | 5805.2      | 2.9         | 2.69        | 0.10        | 1.21        | 2.03    | 107.9 | 101.8  | 133.7  | 3.3     | 0.02    | 11.3  |
| p78k        | 57535  | 1213.3      | 72.8        | 16.66       | 1.74        | 40.82       | 43.55   | 35.6  | 158.6  | 595.1  | 37.02   | 1.23    | 3.5   |
| p81k        | 91756  | 1109.7      | 34.00       | 118.6       | 21.72       | 2.17        | 29.49   | 73.13 | 125.7  | 1444.4 | 24.13   | 12.17   | 2.0   |
| p100k       | 61749  | 1400.1      | 42.9        | 22.01       | 30.22       | 59.11       | 197.59  | 31.9  | 248.9  | 19.9   | 3.09    | 0.28    | 9.5   |
| p267k       | 138912 | 87.9        | 29.1        | 11.41       | 1.07        | 69.21       | 52.38   | 26.5  | 120.2  | 908.0  | 16.20   | 2.76    | 6.6   |
| p330k       | 184425 | 1023.5      | 254.5       | 17.28       | 1.39        | 46.46       | 78.49   | 23.5  | 125.4  | 1933.9 | 21.99   | 7.69    | 3.2   |

(a) Test vector-pairs for the detection of path delay faults, applied to defect free circuits

(b) Test vector-pairs for the detection of small delay faults, applied to circuits with a marginally detectable small delay fault
subcircuits $\mathcal{L}$ and $\mathcal{R}$. Furthermore, the average relative size of the joint input cone of the target paths, which is shown in column "|cone|", is also much larger than $|S|$.

Next, the accuracy of the Monte Carlo simulation of the subcircuits is evaluated. The probability $P_{\text{itr}}$ that a randomly chosen target path is inconsistently sensitized in a randomly chosen circuit instance and its subcircuit is sensitized in the column $P_{\text{ips}}$ in percent. The next column $P_{\text{str}}$ shows the probability of an inconsistent test result in percent. Both probabilities are quite high for the simulation of $\mathcal{S}$ and $P_{\text{str}}$ rapidly with the clock frequency. In contrast, the simulation of the representative subcircuit $\mathcal{S}$ is highly accurate, so that $P_{\text{str}}$ and $P_{\text{ips}}$ are almost zero. For path delay fault and small delay fault tests, it was found that $P_{\text{ips}} \leq P_{\text{itr}}$ holds for 96.3% and 97.7% of all test vector-pairs, respectively. Therefore, the proposed approach meets and exceeds the accuracy goal set by the proposed confidence driven construction of $\mathcal{S}$. Clearly, a target path is sensitized in a circuit instance if and only if the path is sensitized in its subcircuits $\mathcal{L}$, $\mathcal{R}$, and "cone".

Finally, the computational cost for the extraction and Monte-Carlo simulation of the subcircuits is evaluated. The average number of circuit instances that were used for the construction of $\mathcal{S}$ is presented in column "#cir. inst.", excluding the additional $n$ circuit instances that are required to test if $\mathcal{S}$ is a representative subcircuit. The average speedup of the Monte-Carlo simulation of $\mathcal{S}$ and $\mathcal{S}$ is defined as the quotient of the average runtime of the Monte-Carlo simulation of $\mathcal{L}$ or $\mathcal{R}$ and the average runtime for the extraction and Monte-Carlo simulation of the subcircuit $\mathcal{S}$ and $\mathcal{S}$, respectively. The average speedup attained by the extraction and Monte Carlo simulation of the subcircuit $\mathcal{S}$ and $\mathcal{S}$ is shown in column "Speedup". A large average speedup of up to $190 \times$ is achieved by the extraction and Monte Carlo simulation of the subcircuit $\mathcal{S}$. Similarly, the extraction and Monte Carlo simulation of the representative subcircuit $\bar{S}$ is up to $36 \times$ faster than a Monte Carlo simulation of the support region $\mathcal{R}$ of the small delay fault. The speedup is particularly large for p35k because of the relatively large size of $\mathcal{R}$. By adjusting the threshold $P_{\text{thr}}$, a suitable compromise between the speedup and the simulation accuracy can be found.

The experimental results confirm that the representative subcircuit provides very high simulation accuracy and its small size allows the efficient evaluation of the target path sensitization and the delay test with a given test vector-pair in presence of large process variations.

V. CONCLUSION

Under the impact of process variations, a test vector-pair that sensitizes a target path in the nominal circuit instance does not necessarily sensitizes the path in a randomly chosen circuit instance, which can cause a large number of test escapes. To generate and select only those test vector-pairs that most reliably sensitizes the target paths in presence of process variations, it is essential to efficiently compute the probability that a test vector-pair sensitizes the target paths in a randomly chosen circuit instance.

To efficiently compute these probabilities, a small subcircuit is extracted, which initially consists only of the target paths. By analysing the target path sensitization in both circuits under the impact of process variations, the subcircuit is gradually extended by additional paths and finally becomes a representative subcircuit. For path and small delay fault tests, the experimental results show that the target path sensitization probability is computed very efficiently and without any significant error by the extraction and Monte-Carlo simulation of the subcircuit.

VI. ACKNOWLEDGEMENT

This work has been supported by the German Research Foundation (DFG) under grant Wu245/16-1 (PARSIVAL).

REFERENCES