Hans-Joachim Wunderlich

Universitat Karlsruhe Institut fur Informatik IV
(Prof. Dr. Detlef Schmid)
D-7500 Karlsruhe
Federal Republic of Germany

## Abstract

The CAD-tool PROTEST (Probabilistic Testability Analysis) is presented. PROTEST estimates for each fault of a combinational circuit its detection probability which can be used as a testability measure. Moreover it calculates the number of random test patterns which must be generated in order to achieve the required fault coverage.

It is also demonstrated that the fault coverage will increase and the necessary number of random patterns will drastically decrease, if each primary input is stimulated by test patterns having specific probabilities of being logical "1". PROTEST uses this fact and determines for each input the optimal signal probability for a randomly generated pattern.

### 1.0 Introduction

The test of digital systems by random parterns makes it possible to dispense with the generation of test patterns from a description of the circuit structure. Automatic test pattern generation (ATPG) is one of the most expensive tasks in VLSI-design. The costs are high even if scan-paths, scan-sets, LSSD or simflar "design for testability" methods are used (see [EiWi77], [MuSa81]). These methods reduce ATPG for arbitrary digital systems to ATPG for conbinational circuits. But the size of the resulting combinational circuits in VLSI exceed the capacity of the available on general purpose computers. Test gęneration ${ }_{6}$ for integrated circuits with $10^{4}-10^{6}$ transistors requires a computing time which can be counted by magnitudes of days [Goel81].

An alternative to ATPG is the test with randomly generated patterns. This can be done either by using additional test hardware on the chip for self testing or by an external test.

In order to do self test all storing components of the chip are usually configured as one or more feedback shift registers during testing [Much81]. In this special testmode these registers generate pseudo-random patterns for the combinational part of the circuit and evaluate and compress the responses by signature analysis [HeLe83].

An external random test is carried out by shifting randomly generated patterns in a scan path.

Both external and self test reduce the test problem to the test of combinational circuits. The application of random patterns requires the determination of the necessary test length in order to get the desired fault coverage of the commonly used stuck-at fault model on the gate level. This problem is solved by the procedure called PROTEST (Probabilistic Testability Analysis). It estimates signal probabilities and fault detection probabilities in combinational circuits. They are defined as follows:

## Signal and fault detection probabilities:

Let $I$ be the set of the primary inputs of the circuit $S$. During testing each input 16 Is stimulated by a randomly generated signal, which is logical " 1 " with probability $p_{i}$. These probabilities determine a tupel of boolean random variables $\quad T:=\left\langle\underline{p}_{i}\right|$ ifI $\rangle \quad$ with $P\left(P_{i}=1\right)=P_{i}$.

The signal probability $P_{k}$ of a node $k$ of $S$ is the probability, that $k$ is logical "1" if the circuit is stimulated by a sequence implementing $T$.

The fault detection probability $p_{f}$ of a fault f is the probability that this fault is detected, if the circuit is stimulated by a sequence implementing $T$.

The computation of the fault detection probability can be reduced to the compuring of signal probabilities (see
sect. 3). For combinational circuits without reconvergent fan-out $V$. and $P$. Agrawal proposed an algorithm calculating the signal probabilities [AgAg75].

All known algorithms for the general case show exponential complexity. Recently the author has shown that computing the signal probabilities is NP-hard [Wu84]. Therefore the exact determination of signal probabilities is not an efficient test tool. Consequently the tool PROTEST tries to estimate such probabilities only and works with nearly linear effort. A similar tool -STAFAN - was presented by Jain and Agrawal [AgJa84], which extrapolates such probabilities from runs of logic simulation. Savir et al. proposed a method to determine upper and lower bounds of the signal probabilitiy of a node [BDS84], - PROTEST however computes a real number as estimation of both signal and fault detection probability.

The input for PROTEST is a description of a combinational circuit. The output is:

- an estimation of the signal probabiliy at each node for a given tupel of signal probabilities at each primary input;
- an estimation of the fault detection probability of each fault for a given tupel of signal probabilities at each primary input;
- the number of patterns which must be generated to reach a required fault coverage with a desired confidence.
- a tupel of signal probabilities for the primary inputs which maximizes the fault detection probabilities of the faults in the circuit;
- random pattern sets, which are logical "l" at each primary input with the optimized signal probability calculated above;
- results of a static fault simulation with these patterns.

In this paper we present the algorithms and results of PROTEST.

### 2.0 The estimation of the signal probabilities

PROTEST accepts combinational circuits with arbitrary boolean functions as basic components. To simplify the notation in this paper only inverters and 2 -input ANDs are used.

Let $S:=\langle I, O, K, B\rangle$ be a combinational circuit with the set of primary inputs I


Fig. 1: The notation for a combinational circuit.

$x_{1} x_{2}$
$v(a, b)=\left\{x_{1}, x_{2}\right\}$
$x_{1}$ has the fmmediate successors $k_{4}, k_{5}$
Fig. 2: Joining points.
and the set of primary outputs 0 . They are subsets of the set $K$ of all nodes. B is the set of the logic components (see fig. 1).

For two nodes $x, y \in K$ the set of joining points $V(x, y)$ consists of those nodes $k \quad G$ K , which have at least two immediate successors, one of them is on a path to $x$ and the other is on a path to y (see fig. 2).

If the node $c$ is an output of an AND with the inputs $a$ and $b$, then there is a reconvefgent fan-out at $c$ if and only if $v(a, b) k\}$.

Let $\left\langle p_{1} \mid i \in I\right\rangle$ be a tupel of boolean random variables, one for each primary input. This tupel induces boolean random variables $p_{k}$ for each node $k \quad 6 \mathrm{~K}$. In order to determine the signal probability $\mathrm{p}_{\mathrm{k}}=\mathrm{P}\left(\mathrm{p}_{\mathrm{k}}=1\right)$ we must distinguish 4 cases:

1) $k \in I$ :

The signal probability for each primary input is given.
2) $k$ is output of an inverter with the input a.

Then we have $p_{k}=1-p_{a}$
3) $k$ is output of an AND with the input $a$ and $b$ and with $V(a, b)=\{ \}$.

$$
\text { Then } \mathrm{p}_{\mathrm{k}}=\mathrm{p}_{\mathrm{a}} * \mathrm{p}_{\mathrm{b}}
$$

4) $k$ is output of an AND with the inputs a and $b$ and with $V(a, b)$ \{\}.

For each subset $v$ c $V:=V(a, b)$ we define the boolean formula

(1)

$$
\begin{gathered}
P_{k}=P_{k}^{V}:= \\
\sum_{V C V} P_{A}^{V} V_{V} \quad P_{V}\left(P_{a} \mid A_{v}^{V}\right) * P\left(P_{b} \mid A_{v}^{V}\right)
\end{gathered}
$$

The main effort in determining $p_{k}$ arises in case 4, because here the number of summands increases exponentially with the cardinality of $V(a, b)$.

But an estimated value $s_{k}$ of $p_{k}$ is achieved by restricting the evaluation of formula (1) to a bounded subset $W$ c $V$ with cardinality $|W| \leq n$. Then we have
(2)

$$
\begin{gathered}
s_{k}=P_{k}^{W}:= \\
\sum_{v \subseteq W} P_{A}^{W}{ }_{v}{ }^{*} P\left(\underline{P}_{a} \mid A_{v}^{W}\right) * P\left(P_{b} \mid A_{v}^{W}\right)
\end{gathered}
$$

In order to get a small error $\left|p_{k}{ }^{-} p_{k}{ }^{W}\right|$ we have to select appropriate elements for $W$ C V. Let us introduce the notations for the standard deviation

$$
\mathrm{s}\left(\mathrm{P}_{\mathrm{a}}\right):=\sqrt{\mathrm{P}_{\mathrm{a}}\left(1-\mathrm{p}_{\mathrm{a}}\right)}
$$

and for the covariance

$$
\operatorname{Cov}\left(\mathrm{P}_{\mathrm{a}}, \mathrm{P}_{\mathrm{b}}\right):=\mathrm{P}\left(\mathrm{P}_{\mathrm{a}} \& \mathrm{P}_{\mathrm{b}}\right)-\mathrm{P}_{\mathrm{a}} \mathrm{P}_{\mathrm{b}}
$$

For every logical formula $A$ a formula indexed with $A$, e.g.

$$
S_{\mid A}\left(P_{a}\right):=\sqrt{P\left(P_{a} \mid A\right)\left(1-P\left(P_{a} \mid A\right)\right)}
$$

is defined as the restriction to the case of A being true.

With an arbitrary enumeration $\left\langle k_{1}, \ldots, k_{m}\right\rangle$ of $V$, with the sets

$$
v_{0}:=\{ \}, v_{i+1}:=v_{i} \quad\left\{k_{i+1}\right\}
$$

and with

$$
d_{1+1}:=p_{k}{ }^{V_{1+1}}-p_{k}{ }^{v_{i}}, 1=0, \ldots m-1,
$$

we have for $r>s$ :

$$
p_{k} V_{r}-p_{k} V_{s} \sum_{j=s+1, \ldots, r} d_{j}
$$

For $j:=0, \ldots, m-1$ and with $A^{\{ \}}$the following equation holds:

$$
\begin{aligned}
& d_{j+1}=\sum_{t \underline{c} V_{j}} P_{A_{t}} V_{j}^{* k_{j+1}}{ }^{\star} \\
& P\left(\underline{P}_{\mathbf{a}} \mid A_{t}{ }_{j * k_{j+1}}\right) \star P\left(\mathbf{R}_{b} \mid A_{t} V_{j_{k}}{ }_{j+1}\right)+ \\
& P_{A_{t}} V_{j}{ }_{j \bar{k}_{j+1}} * P\left(P_{a} \mid A_{t} V_{j * \bar{k}_{j+1}}\right) * \\
& P\left(p_{b} \mid A_{t}{ }_{V_{k+}}{ }_{j+1}\right) \text { - } \\
& P_{A_{t}} v_{j} * P\left(p_{a} \mid A_{t} V_{j}\right) * \\
& P\left(P_{b} \mid A_{t}{ }^{V_{j}}\right) \text {. }
\end{aligned}
$$

By means of Bayes formula and some straightforward transformations one achieves
$d_{j+1}=\sum_{t \underline{c} V_{j}} p_{A_{t}} v_{j} *$


$$
\left.s\left(\underline{p}_{k j+1}\right)\right|_{A_{t}}{ }^{v}{ }_{j 2} .
$$

The difference $V$ between the total estimation error $\mathrm{p}_{\mathrm{k}}-\mathrm{p}_{\mathrm{k}}$ and the error which arises if we take the jfining ixpoint $x$ into consideration $\quad P_{k}-P_{k}\{x\}$ is
$t h e r e f o r e ~$

$$
\operatorname{Cov}\left(\mathrm{p}_{\mathrm{a}}, \underline{p}_{\mathrm{x}}\right) \operatorname{Cov}\left(\mathrm{p}_{\mathrm{b}}, \underline{p}_{\mathrm{x}}\right) / \mathrm{S}\left(\underline{p}_{\mathrm{x}}\right)^{2}
$$

An appropriate strategy to select a subset $W$ c $V$ is to minimize the value of

$$
\left|\sum_{x \in V-W} \operatorname{Cov}\left(\underline{p}_{a}, \underline{p}_{x}\right) \operatorname{Cov}\left(\underline{p}_{b}, \underline{p}_{x}\right) / s\left(\underline{p}_{x}\right)^{2}\right|
$$

Indeed there are some special cases, where the optimality of this strategy is provable [Wu84]. But in general this procedure is a heuristic to estimate signal probablities and to estimate the possible error in estimation.

This procedure is part of PROTEST and requires the parameters MAXVERB, determining the maximal cardinality of $W$, and MAXLIST, determining the maximal length of the paths in which joining points are searched.

### 3.0 The fault detection probability

The computation of fault detection probabilities can be transformed into the computation of signal probabilities in a rather trivial way. But this yields quadratic complexity and therefore it is not appropriate for all applications.

What is indeed possible with inear complexity is the estimation of the probability of single path sensitizing to an output. A test pattern sensitizes a single path from a pin $x$ of some logical component of the circuit to a primary output o, if there is exactly one path from $x$ to 0 , in which the logical value at each node depends from the value at $x$. The detection probability of a stuck-at-i, $1=0,1$, fault at $x$ can be estimated by the probability that $x$ has the value "NOT(i)" and that at the same time a single path is sensitized. This can be reduced to the calculation of signal probabilities too. This method still needs a considerable computing time.

But for many applications the modeling of the signal flow is sufficent. In this case the transformation of the additional
boolean formulas into new parts of the circuit is avoided.

Each component of the circuit represents a boolean function $f:\{0,1\}^{\text {n }} \rightarrow \quad\{0,1\}$. All those functions can be mapped in a unique way into arithmetic functions $f:[0,1]^{\mathrm{n}} \rightarrow[0,1]$ by the transformations $x \mid->\quad 1-x \quad$ and $x \& y \mid-->x * y$. Now for each pin $x$ of a component we define a function $s(x)$, which represents the probability that there exists a sensitized path from $x$ to a primary output. Let $x$ be the output pin of $f, x_{1}, \ldots, x_{m}$ the input pins of other components which are directly connected to $x$, and $e_{1}, \ldots, e_{n}$ the input pins of $f$.

We define the associative operation $z c y:=z+y-2 z y$. Then we set
$s(x):=s\left(x_{1}\right) \& \ldots \& s\left(x_{m}\right)$ and
$s\left(e_{i}\right):=s(x) *\left(f\left(p_{e_{1}}, \cdots p_{e_{i-1}}, 0, \ldots, p_{e_{n}}\right) \&\right.$ $\left.f\left(p_{e_{1}}, \cdots p_{e_{i-1}}, 1, \ldots, p_{e_{n}}\right)\right)$.
An alternative model for circuits with a large number of primary outputs is $s(x):=1-\left(1-p_{x_{1}}\right) * \ldots *\left(1-p_{x_{m}}\right)$.
$(p, s)=\left(0.5,0.75-2 \cdot 0.375^{-2}\right)$


Fig. 4: Signal modeling
Both alternatives are implemented in PROTEST and they determine fault detection probabilities by $x 0:=p_{x} s(x)$ and $x 1:=\left(1-p_{x}\right) s(x)$.

The accuracy of these procedures is sufficient for all applications described. Moreover PROTEST offers also the option to estimate the probability of single path sensitization.

### 4.0 The validity of PROTEST

Agrawal and Mercer describe in [AgMe82] how they transformed the results of the testability measure SCOAP into values called ${ }^{\text {S COAP }}$ corresponding to the fault detectioncoAprobability. For each fault they determined also the variable P ${ }^{\text {Phich is the quotient of the number }}$ Shit which is the quotient of the number of number of applied test patterns. The investigations in [AgMe82] show that there is only a correlation 0.4 between $P_{\text {SCOAP }}$ and $P_{\text {SIM even for pure }}$ combinational circuits.

For each fault $f$ the value of $P_{\text {PROT }}(f)$ is the estimated detection probability by PROTEST. The variables PPROT and PSIM however correlate with PPROT with morm than 0.9. These correflations were obtained with more than 10 circuits. Two examples are the TTL ALU SN74181 - called ALU - and the circuit MULT, which computes $A+B+C$ * $D$ for 8 bit wide data. MULT is built with 1568 gate equivalents according to the proposal of [Hart80].

Table 1 showis for MAXVERB $=4$ and MAXLIST $=100$ the maximal value $M$, which has been reached by the formufa $\mid P_{\text {PROT }}{ }^{-P_{S I M} \mid \text { for some fault } f . ~}$
$A_{e r r}:=\sum_{f}\left|P_{\text {PROT }}{ }^{-P_{S I M}}\right| /($ Number of faults) is the average difference between the real values obtained by simulation and those estimated by protest. $C$ is the correlation coefficient of $P_{P R O T}$ and $P_{S I M}$.

|  | Merr | Aerr | $C_{0}$ |
| :---: | :---: | :---: | :---: |
| ALU | 0.15 | 0.04 | 0.97 |
| MULT | 0.48 | 0.11 | 0.90 |

correlations

Figure 5 shows the correlation diagram for the ALU, where each fault is positioned according to its values of $\mathrm{P}_{\text {PROT }}$ and $\mathrm{P}_{\text {SIM }}$.

Figure 6 is the analogue for MULT. One easily notices that in general $P_{S I M}$ is higher than $P_{\text {PROT }}$.

This bias is caused by the very simple modeling of the signal flow, which does not take into account that sensitization of several paths at the same time may also result in fault detection. The under-estimation of the fault detection probability has consequences for computing test lengths.


Fig. 5: Correlation diagram for ALU
$P_{\text {PROT }}$


Fig. 6 Correlation diagrain for MULT
$\mathrm{P}_{\text {PROT }}$

### 5.0 Necessary testlengths

Let $F$ be a set of stuck-at faults. For the sake of simplicity we assume that fault detection is statistically independent, - in other words, the probability $p_{f}$ that a pattern detects $f$ is the same, whether this pattern detects some other faults too or not.

The probability that $n$ patterns detect all faults in $F$ is
(3) $P_{F}:=\prod_{f \in F}\left(1-\left(1-p_{f}\right)^{N}\right)$.

For a given $P_{F}$ this formula can be used to approximate ${ }^{F} N$ by an iteration very fast. The necessary number of patterns $N$
to detect all faults in $F$ with probability $p_{F}$ requires only knowledge of the fault detection probability $P_{f}$. But unfortunately there are only estimations $s_{f}$ for each $p_{f}$ available. These eftimations may refult in a systematic over-estimation of $P_{F}$. For compensation in [AgJa84] a weighting factor is proposed. PROTEST does not need such a factor, because its estimations were systematically higher than $P_{f}$ in all investigated examples.

PROTEST also uses formula 3 to solve the following problem: $F$ consists of all faults of the circuit, for each d $\in[0,1]$ F are the d*100 \% faults with highest detection probilities and $e$ is the required probability that a pattern set detects whole $F$. Then PROTEST determines the necessary size $N$ of the pattern set. Table 2 shows the results for MULT and ALU :

|  | d | e | N |
| :--- | :--- | :--- | :--- |
| ALU | 0.98 | 0.98 | 212 |
| MULT | 0.98 | 0.98 | 962 |
| Table 2: Size of test sets |  |  |  |

Table 2: Size of test sets
Several random pattern sets of the required size were created for both the ALU and the MULT. With all those sets fault simulation had reached a coverage of 99,9-100 \%

There are known circuits which can be very poorly tested by random patterns. Some of those circuits were also analyzed by PROTEST. DIV is the combinatorial part of a 16 bit divider and COMP is the connection of 16 slightly modified SN7485 comparators to a cascaded 24 bit word comparator (Fig. 7).
In order to test those circuits PROTEST proposed a number of test patterns listed in table 3.



Fig. 7: 24 bit comparator COMP

### 6.0 0ptimized input signal probabilities

In Table 3 the large number of pattern sets are calculated under the assumption that the primary inputs of the circuit are all stimulated by logical "1" with the probability $p_{f}=0.5$. But aq arbitrary tupel $X:=\left\langle_{p_{i}} \mid i \in I\right\rangle \in[0,1]$ determines pattern sets which have an arbitrary probability $P_{i} \in[0,1]$. $X$ determines a probability $P_{f}(X)$ of detection of each fault $f$.

With some natural number $N$

$$
J_{N}(x)==\prod_{f}\left(1-\left(1-p_{f}(x)\right)^{N}\right)
$$

is an estimation of the probability that $N$ realizations of $X$ detect the whole $F$. For every combinational circuit $\mathrm{J}_{\mathrm{N}}:[0,1]^{\mathrm{I}} \rightarrow[0,1]$ is a real function which can be maximized by a tupel <p, 16I>, thus leading to maximal fault detection. $N$ is only a numerical parameter.

PROTEST includes an optimizing procedure, which finds a local maximum of $\mathrm{J}_{\mathrm{N}}$. The procedure works according to the hill climbing principle also used in many other fields [\$11s80]. Table 4 shows the optimal signal probabilities PROTEST proposed for each primary input of COMP.

| A0 | 0.63 | B0 | 0.56 | A1 | 0.69 | B1 | 0.75 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| A2 | 0.38 | B2 | 0.38 | A3 | 0.25 | B3 | 0.31 |
| A4 | 0.13 | B4 | 0.13 | A5 | 0.94 | B5 | 0.88 |
| A6 | 0.88 | B6 | 0.88 | A7 | 0.88 | B7 | 0.88 |
| A8 | 0.88 | B8 | 0.94 | A9 | 0.94 | B9 | 0.94 |
| A10 | 0.88 | B10 | 0.88 | A11 | 0.88 | B11 | 0.94 |
| A12 | 0.88 | B12 | 0.88 | A13 | 0.88 | B13 | 0.94 |
| A14 | 0.94 | B14 | 0.94 | A15 | 0.94 | B15 | 0.94 |
| A16 | 0.88 | B16 | 0.88 | A17 | 0.94 | B17 | 0.94 |
| A18 | 0.94 | B18 | 0.88 | A19 | 0.94 | B19 | 0.94 |
| A20 | 0.94 | B20 | 0.88 | A21 | 0.94 | B21 | 0.88 |
| A22 | 0.94 | B22 | 0.94 | A23 | 0.94 | B23 | 0.88 |
| TI1 | 0.63 | TI2 | 0.63 | TI3 | 0.63 |  |  |

Table 4: Optimized signal probabilities at the primary inputs

It is remarkable how much the optimal input probabilities differ from the conventionally used value of 0.5 . Table 5 shows the number of patterns which are necessary using these probabilities.

| d | e | N(DIV) | N( COMP) |
| :---: | :---: | :---: | :---: |
| 1.0 | 0.95 | 6066 | 8932 |
|  | 0.98 | 6969 | 10284 |
|  | 0.999 | 10063 | 14911 |
| 0.98 | 0.95 | 5097 | 6828 |
|  | 0.98 | 5780 | 7767 |
|  | 0.999 | 8052 | 10893 |

Table 5: The necesarry size of optimized test sets.

The testlength using the optimized input signal probabilities was reduced by several orders of magnitude. This result was validated by fault simulation.

Each circuit has been simulated with two random pattern sets of size 12000 . One of the random pattern sets stimulated each primary input with logical "l" with the commonly used probability of 0.5 . The other pattern aet was created according to the optimized signal probabilities. Table 6 shows for both pattern sets, how the fault coverage increases with the number of used pattern.
For both circuits fault simulation shows that conventional random pattern test yields very insufficient results whereas the pattern sets proposed by PROTEST detect nearly all faults.

| Pattern count | DIV |  | COMP |  |
| :---: | :---: | :---: | :---: | :---: |
|  | not | optim. | not | optim. |
|  | optim. |  | optim |  |
| 10 | 16.8 | 26.1 | 32.1 | 44.5 |
| 100 | 56.5 | 66.3 | 70.4 | 72.7 |
| 1000 | 69.1 | 94.6 | 75.8 | 95.4 |
| 2000 | 71.4 | 98.5 | 76.5 | 97.2 |
| 3000 | 73.2 | 99.0 | 77.2 | 98.3 |
| 4000 | 74.7 | 99.1 | 79.6 | 99.4 |
| 5000 | 76.8 | 99.1 | 80.0 | 99.4 |
| 6000 | 77.2 | 99.4 | 80.4 | 99.4 |
| 7000 | 77.2 | 99.4 | 80.4 | 99.5 |
| 8000 | 77.2 | 99.6 | 80.5 | 99.5 |
| 9000 | 77.2 | 99.7 | 80.5 | 99.5 |
| 10000 | 77.2 | 99.7 | 80.6 | 99.7 |
| 11000 | 77.2 | 99.7 | 80.6 | 99.7 |
| 12000 | 77.2 | 99.7 | 80.7 | 99.7 |

Table 6: Fault detection by simulation of random patterns
7.0 Implementation

PROTEST consists of different programs written in standard PASCAL. They compile a structure description language for circuits, they generate test pattern sets and they carry out the algorithms described above. It runs on a SIEMENS 7561 computer, a machine with approximately 2.4 MIPS. The performance of the analysis program is dependent on both the size of the circuit and the number of joining points.

In table 7 the CPU time and the resulting size of a test set are listed for some circuits. The transistor count for these circuits is based on a CMOS library.

| Transistor count | estimated <br> of a test |  |  | $\begin{aligned} & \text { size } \\ & \text { set } \end{aligned}$ | CPU time <br> (seconds) |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 368 |  |  |  | 594 | 0.4 |
| 1274 |  | 1 | 798 | 000 | 0.7 |
| 2496 | 1 | 120 | 000 | 000 | 1.0 |
| 26450 |  |  | 32 | 160 | 23.0 |
| 47936 |  | 8 | 284 | 000 | 41.0 |

Table 7: CPU time for the analysis by PROTEST
The optimization of the input signal probabilities is more CPU intensive. Here the effort depends on the number of the primary inputs, too.

Table 8 shows the CPU rime needed to optimize the input signal probabilities.

| Transistor count | Inputs | $\begin{aligned} & \text { optim. } \\ & \text { test set } \end{aligned}$ | CPU-time |
| :---: | :---: | :---: | :---: |
| 368 | 11 | 267 | 6.4 |
| 1274 | 32 | 6264 | 49.0 |
| 2496 | 48 | 43010 | 152.0 |
| 26450 | 32 | 1778 | 2181.0 |

Table 8: CPU time for the optimization by PROTEST

### 8.0 Some applications

The optimal input signal probabilities calculated by PROTEST are used to design non-linear feedback shift registers (NLFSR), which generate such optimal pattern sequences [KuWu84]. Similar the wellknown BILBO [Much81] the NLFSR are used for self-testing. Such an NLFSR reaches a higher fault detection probability in shorter test time, generating minimal hardware overhead compared to the standard BILBO.

This self testing strategy is used in the Karlsruhe synthesis system CADDY (Carlsruher Digital Design System) [CKR84], [CKR84ā], [SCHD84] It uses several design for testability features like conventionel BILBOs and NLFSR optionally. When using BILBOs the system gets the necessary testlength from PROTEST. When using NLFSR it also obtains the optimal input signal probability.

The use of PROTEST also reduces the computing time of ordinary ATPGs for combinational circuits or circuits containing scan features. Most ATPG first use fault simulation by random patterns, and second when this becomes inefficient, they use other procedures like the D-algorithm. Computing time for fault simulation is drastically reduced by using optimized pattern sets. (For the optimized patterns the calculation of table 7 needed only a quarter of the computing time needed for the not optimized patterns.). Additionally the number of faults which are to be treated by the more expensive second procedure decreases.

### 9.0 Summary:

The CAD tool PROTEST has been presented. The testability measure given by PROTEST is the random pattern testability of combinational circuits. It finds less testable faults, computes the random pattern test length and determines an optimized input signal probability for each primary input.
This optimization leads to a drastic reduction of the necessary random pattern set. The results were all validated by fault simulation. The design system at the university of Karlsruhe integrates PROTEST as the key tool to achieve design for testability.

## References:

[AgAg75 ] P. Agrawal, V.D. Agrawal; Probabilistic Analysis of Random Test Generation Method for Irredundant Combinational Logic Networks; IEEE Trans. on Comput., Vol. C-24, No. 7, July 1975
[AgJa84 ] S.K. Jain, V.D. Agrawal; STAFAN: An Alternative to Fault Simulation; Proc. of $21 s t$ Design Automation Conference, 1984
[AgMe82] Agrawal, V. D., Mercer, M. R.; Testability Measures - What Do They Tell Us; International Test Conference, 1982, pp. 391 - 396
[BDS84 ] J. Savir, G.S. Ditlow, P.H. Bardell; Random Pattern Testability; IEEE, Trans. Comp., Vol. C-33, No. 1 , Jan. 1984
[CKR84a ] R. Camposano, A. Kunzmann, W. Rosenstiel; Automatic Data Path Synthesis from DSL Spezifications; IEEE, Proce of Int. Conf. on Computer Design, ICCD, 1984
[EiWi77 ] E.B. Eichelberger, T.W. Williams; $A$ logic design structure for LSI testability; Proc. 14 th Design Automation Conference, Pp. 462-468, June 1977
[Goel81 ] P. Goel; An implicit enumeration algorithm to generate tests for combinational logic circuits; IEEE Trans. on Comp., Vol. C-30, no. 3, March 1981
[Hart80 ] R.W. Hartenstein; VLSI-Bausteine in geringen Stueckzahlen fuer Spezialanwendungen; Elektronische Rechenanlagen, Heft 4, 1980
[HeLe83] J.H. Heckmaier, D. Leisengang; Fehlererkennung mit Signaturanalyse; Elektron. Rechenanl. 25, 1983, H. 3, 109 - 116
[KuWu84] A. Kunzmann, H.-J. Wunderlich; Steigerung der Effizienz beim Test mit Zufallsmustern Report $19 / 84$ at the Faculty for Informatics, University of Karlsruhe, October 1984
[Much81 ] J. Mucha; Hardware Techniques for Testing VLSI Circuits Based on Built-In Test; Proc. COMPCON 81, Feb. 1981
[MuSa81] E.I. Muehldorf, A.D. Savkar; LSI Logic Testing - An Overview; IEEE Trans. on Computers, Vol. C-30, No. 1 , January 1981
[Nils80 ] N.J. Nilsson; Principles of Artificial Intelligence Tioga Publishing Company, Palo Alto, California, 1980 ;
[SCHD84 ] D. Schmid et al.; Automatischer Entwurf hochintegrierter Schaltungen aus Beschreibungen der Schaltungsfunktion; Inforamtik-Fachberichte 88, 14. GI-Jahrestagung, Braunschweig Okt. 1984, Springer-Verlag

