A MATRIX MODEL OF DIGITAL SYSTEMS AND ITS
APPLICATION TO AUTOMATIC
test generation

By<br>CHARLOTTE COUCH ACKEN<br>Bachelor of Science<br>University of Arkansas<br>Fayetteville, Arkansas<br>1969<br>Master of Science University of Arkansas Fayetteville, Arkansas 1971<br>Master of Science Oklahoma State University Stillwater, Oklahoma 1977

Submitted to the Faculty of the Graduate College of the Oklahoma State University
in partial fulfillment of the requirements
for the Degree of
DOCTOR OF PHILOSOPHY
May, 1982

$$
\begin{aligned}
& \text { Thesis } \\
& 1982 \mathrm{D} \\
& \text { A } 182 \mathrm{~m} \\
& \text { Cop. } 2
\end{aligned}
$$



A MATRIX MODEL OF DIGITAL SYSTEMS AND ITS
APPLICATION TO AUTOMATIC
TEST GENERATION

Thesis Approved:


## ACKNOWLEDGMENTS

My sincere appreciation is extended to Dr. Ronald P. Rhoten, chairman of my doctoral committee and my thesis adviser, for his invaluable assistance throughout the course of my graduate education in electrical engineering. I am grateful to the other members of my doctoral committee, Dr. C. M. Bacon, Dr. M. E. Daniel, Dr. J. W. Maxwell, and Dr. R. J. Mulholland, for their critical reviews of the manuscript and for their encouragement and friendship.

Financial support for this research has been provided by Sandia National Laboratories. Sandia management directly involved in providing me the opportunity to conduct this work were D. M. Olson, D. M. Schuster, C. W. Gwyn, A. A. Lieber, M. E. Daniel, and W. F. Roherty. Their exhibited confidence in my abilities are much appreciated.

Special thanks are extended to the staff of the Sandia National Laboratories technical library, word processing center, and graphic arts division for their assistance. The typing of the final copy was performed by Charlene Fries, to whom 1 am most grateful.

Well deserved gratitude is extended to my parents, whose personal sacrifice, encouragement, and understanding have inspired me throughout my education. I am thankful for my wonderful husband, John, who has provided loving encouragement and enthusiastic confidence in me during the preparation of this thesis.
Chapter Page

1. INTRODUCTION AND BACKGROUND ..... 1
II. REVIEW OF RELATED LITERATURE ..... 6
Introduction ..... 6
Path Sensitization ..... 6
Equation Manipulation ..... 16
Summary ..... 22
I\|l. MODELING DIGITAL SYSTEMS ..... 23
Introduction ..... 23
Notation ..... 23
Combinational Circuit Model ..... 26
Sequential Circuit Model ..... 39
Summary ..... 42
IV. MODEL CHARACTERISTICS AND EXTENSIONS ..... 45
Introduction ..... 45
Combinational Circuit Topology ..... 45
Combinational Circuit Matrix Complexity ..... 48
Model Extensions ..... 50
Sequential Circuit Topology ..... 53
Sequential Circuit Matrix Complexity ..... 54
Summary ..... 56
V. A MATRIX APPROACH TO AUTOMATIC TEST GENERATION ..... 57
Introduction ..... 57
Path Sensitization Using the Matrix Model ..... 57
Boolean Difference Using the Matrix Model ..... 75
Summary ..... 83
VI. CONCLUSIONS AND RECOMMENDATIONS ..... 85
Conclusions ..... 85
Recommendations for Further Research ..... 86
A SELECTED BIBLIOGRAPHY ..... 91

## LIST OF TABLES

Table Page

1. Boolean Difference Identities ..... 19
2. Truth Tables for "AND" and "OR" Functions ..... 25

## LIST OF FIGURES

Figure Page

1. Sample Circuit lllustrating Path Sensitization and Signal Propagation ..... 10
2. An AND Gate With Its Singular Cover and D-Cubes ..... 11
3. A Simple Combinational Circuit With Its Singular Cover and D-Cubes ..... 13
4. Sequential Circuit Modeled as an Iterative Combinational Array ..... 17
5. Circuit Viewed as Composite Functions ..... 21
6. Labeled Generic Logic Diagram ..... 27
7. A NAND, OR, NOT Circuit ..... 29
8. Model Representation of Logic Gates ..... 32
9. Exclusive-OR (XOR) Representation ..... 34
10. Combinational Circuit Modeling ..... 35
11. NOT and OR Gates Represented in Terms of NAND Gates ..... 37
12. Compact Matrix Formulation ..... 38
13. Sequential Circuit Modeling ..... 40
14. Clocked D-Flip Flop ..... 43
15. Directed Graph of Figure 10 (a) ..... 47
16. Fanout of a Circuit Input ..... 51
17. Labeling Extended to Forks in a Fanout Path ..... 52
18. Labeled Combinational Circuit ..... 60
19. Combinational Circuit ..... 63
20. Schneider's Example ..... 67
Figure Page
21. Circuits With Undetectable Faults ..... 69
22. Gate Level Representation of a Clocked S-R Flip Flop ..... 72
23. Flow Diagram for Combinational Circuit Test Genera- tion Using Single Path Sensitization and the Acken Matrix Model . . . . . . . . . . . . . . . . . . . . . . . . 74
24. Example Circuit for lllustrating Boolean Difference ..... 78
25. A Simple Redundant Circuit ..... 88

## CHAPTER I

## INTRODUCTION AND BACKGROUND

Physical faults can occur at any point during the life of a digital system. Generally speaking, a fault can be defined as anything which causes the system to operate in a manner other than that for which it was designed. Faults can originate during the manufacture, assembly, storage, and/or service phase of the system life. Open circuits, short circuits, and incorrect impedance are example faults. Those which alter the magnitude of a circuit parameter with a resultant modification in circuit speed, current, or voltage are termed parametric faults. Faults which alter the logical behavior of the system are termed logical faults. Because faults can, and do, occur at any time during the life of a digital system, it is necessary to determine, via some testing procedure, the operational status of the device.

A test for a logical fault is defined to be a set of inputs (or input sequences) for which a faulty system will exhibit an unintended logical behavior. Only tests for logical faults will be considered in this research.

The advent of large-scale integration (LSI) and very large-scale integration (VLSI), as well as the increased complexity of digital integrated circuits (ICs), has made manual test generation extremely timeconsuming, unreliable, and physically difficult. For this reason, automatic test generation (ATG) algorithms are desirable. However, most ATG
algorithms are also constrained by the size and complexity of present day ICs. An obvious algorithm for ATG for combinational circuits is to generate all possible input combinations and compare the output of the device under test (DUT) with a known output. This procedure detects all possible logical faults within the system. The disadvantage to this approach becomes apparent as the number of primary inputs, $n$, increases. Assuming a testing system with a stimulus/response cycle of 1 microsecond, it would take 1 second to exhaustively test a combinational logic circuit with 20 primary inputs. The amount of time required rises exponentially as the number of primary inputs increases, and for $n=50$, the time required becomes 35 years!

One approach to narrowing the problem to feasible limits is to consider a subset of all possible faults whose detection will result in a high confidence that all likely faults of interest have been detected. The fault subset is generally defined via a logical fault model.

There are three basic requirements of any logical fault model. The model should indicate what effect the fault will impose upon the operation of the circuit, how many such faults are assumed to be present at one time, and how long the fault is present. The most common logical fault model (also to be utilized in this research) is the single permanent stuck-at model. This model assumes that only one primary input/ output or internal signal line in the circuit will be permanently stuck at logical zero or logical one during the duration of any test.

If a circuit has $n$ primary input $l i n e s$ and $p$ internal signal lines (including primary outputs), then the total possible number of single faults (i.e., occurring one at a time) is $2(n+p)$ since each line could be stuck-at-zero or stuck-at-one.

If two or more of the signal lines are simultaneously faulty, there are a total of $3^{n+p}-1$ such multiple faults to consider. Because this number tends to become large as circuits increase in size, this multiple fault model becomes intractable. Even though the multiple fault model is a valid model, it has not been utilized in practical implementations because of the exponential growth in the number of faults that have to be considered.

One method of generating tests for logical faults is to have a test engineer determine input vectors which would cause a change in signal value on every signal line in the device under test. To achieve this, as well as try to minimize the test length and perform fault location simultaneously, would require a lot of detailed and repetitive work-the type of work that is more efficiently done by a computer.

Automatic test generation refers to the process of generating a set of inputs to an integrated circuit via a computer algorithm. Most algorithms utilize information about the system topology and/or behavior and the faults for which tests are being generated. Almost allautomatic test generation methods are based upon models of the digital circuit in addition to fault models, some of which were discussed earlier.

Many digital system models exist. The two utilized most extensively for automatic test generation are the gate level logic diagram and the register-transfer level (RTL) diagram. The gate level logic diagram characterizes the system as an interconnection of one or more of the basic logic gates (AND, OR, NOT, NAND, NOR). An RTL diagram characterizes the circuit as an interconnection of functional blocks such as registers, counters, or ALUs. Functional level test generation utilizes an RTL circuit model and attempts to generate tests which will detect
whether or not the functional blocks are performing the function for which they were designed (shifting, counting, ect.). Modeling the circuit at the register-transfer level tends to decrease the execution time and memory requirements for ATG, compared to that required for ATG algorithms which utilize a gate level circuit description. However, functional level test generation methods lack the ability to isolate faults to a gate or signal level, may generate invalid tests, and suffer from a lack of adequate fault models.

The efficiency of ATG algorithms which utilize a gate level circuit description depends upon how much information concerning the circuit behavior and topology is passed and how concisely the information is formulated for use in the algorithm. Completely random ATG formulates no information about the circuit behavior and topology to guide it in generating tests. Other algorithms formulate the behavior and/or topological information in various ways.

Chapter 11 is a review of some of the best known and most widely used gate level automatic test generation methods. The manner in which the behavior and/or topological information is formulated and utilized by each is reviewed, and the advantages and weaknesses of each method and its underlying mathematical formulation are pointed out.

A matrix formulation for digital integrated circuits is introduced in Chapter 111 . This representation contains the information about the logical behavior and topology of a circuit necessary for gate level automatic test generation. The concise matrix formulation can be easily stored in and manipulated by a computer. Characteristics of and extensions to the formulation are given in Chapter IV.

Chapter $V$ illustrates several ways in which the matrix representation can be utilized to automatically generate tests. Approaches using path sensitization and Boolean equation manipulation for test generation are presented.

Along with the thesis conclusions, Chapter VI contains suggestions for other possible uses of the matrix representation of a digital system. These include the analytical detection of circuit redundancy and the use of the matrix model as a structure in which to perform testability analysis.

Numerous examples are included in Chapters $\mid 11$ through VI to illustrate concepts and techniques.

## REVIEW OF RELATED LITERATURE

## Int roduction

The first ATG algorithms were based upon gate level circuit models and the single permanent stuck-at fault model. Boolean equation manipulation was an early ATG technique followed by path sensitization approaches. Most of today's gate level ATG algorithms are based upon one or a combination of both these procedures.

In order to fully understand why certain characteristics of digital system models such as topology, behavior, and compact representation are essential to ATG, a close look at digital circuit test generation methods is necessary. Two path sensitization approaches are reviewed, the $D$ algorithm (Roth, 1966) and critical path sensitization (Thomas, 1971). One equation manipulation technique, the Boolean difference approach (Sellers, Hsiao, and Bearnson, 1968) is outlined. Emphasis will be placed on the type of circuit information needed for the technique and the way the information is formulated.

## Path Sensitization

The D-algorithm (Roth, 1966) has formed the basis for most of the ATG programs in use today because it introduced the fundamental concept of path sensitization. Variants of the original path sensitization procedure have proven to be successful.

As it was originally conceived, path sensitization was to be performed on a gate level model of the circuit and generate tests for stuck-type faults. Others have used the idea of path sensitization on partitioned blocks of logic circuitry and on higher level primitives such as registers, counters, etc. (Breuer and Friedman, 1980; Bennetts, Brittle, Prior, and Washington, 1975). Other fault models have also been used in conjunction with the D-algorithm (Breuer and Friedman, 1976).

The basic idea of path sensitization will first be explained, followed by a description of two path sensitization algorithms and their associated model formulation. The advantages and disadvantages to these two techniques and their models will be pointed out.

We first explain the concepts of line justification and error propagation. A value of $j \varepsilon\{0,1\}$ on the output to gate $G$ is justified by assigning values to the gate inputs which, when applied to $G$, will result in the value $j$. For example, the value $l$ on the output of an AND gate can be justified by assigning the value 1 to each of the gate inputs. Similarly, the value 0 on the output of an AND gate can be justified by assigning the value 0 to any one or more of the inputs to the gate. Hence, justifying a 0 output to a 2-input AND gate allows three choices. If the inputs are $u_{1}$ and $u_{2}$, we may choose $u_{1}=1, u_{2}=0 ; u_{1}=$ $0, u_{2}=1 ;$ or $u_{1}=u_{2}=0$.

Adopting the symbolism of (Roth, 1966) the letter D will be used to represent the value of a signal line which has the value 1 in the normal (fault-free) circuit and 0 in the faulty circuit, and $D^{\prime}$ to represent the value of a signal line which has the value 0 in the fault-free
circuit and 1 in the faulty circuit. Hence, if a line has value $D$, it is stuck-at-0 and $D^{\prime}$ represents the stuck-at-1 condition.

The error signal $D$ on an input line of gate $G$ is propagated through the gate by assigning values to the other inputs of gate $G$ which will result in a $D$ or $D^{\prime}$ on the gate output. For example, if an input to an AND gate is assigned the error value $D$, it will be propagated to the output of the gate only if all other inputs are assigned the value 1. If any other input to the AND gate takes the value 0 , the output will be zero and the error value cannot be propagated. To propagate an error signal (either $D$ or $\left.D^{\prime}\right)$ through an $O R$ gate, all other inputs must be zero; through a NAND gate, all other inputs must be one; through a NOR gate, all other inputs must be zero. Hence, no choice in assignments exists in fault propagation for a given gate type.

The path sensitization procedure for combinational circuits can be described as follows:

Step 1. Select a fault (stuck-at-j, $j \varepsilon\{0,1\}$ ) and fault site (some signal line, a).

Step 2. Justify the value $j^{\prime}$ on the signal line a by assigning values to the primary inputs. This justification step may require some choices when assigning values to signal lines and/or primary inputs.

Step 3. Propagate the faulty signal value to a primary output along one path or simultaneously along multiple paths through the circuit. Note that a choice of paths may exist. Propagation of a signal value will require assignments to be made along the chosen path; however, as noted earlier, these assignments are never arbitrary.

Step 4. Justify the assignments made in Step 3 so that they are consistent with the assignments made in Step 2. If a consistent
assignment is not possible, then no test exists for the specified fault.

The following example illustrates the path sensitization procedure. Figure 1 is a simple combinational circuit. Assume line $x_{4}$ is stuck-at0. According to Step 2, we wish to justify alon line $x_{4}$, and this is done by setting input $u_{1}=1$ and $u_{2}=1$. Next we wish to propagate the fault through the $O R$ gate to line $x_{6}$, a primary output. This is done by assigning $x_{5}=0$. Step 4 involves justifying $x_{5}=0$ consistent with the other values already assigned. $\quad x_{5}$ will equal zero if $u_{2}=0, u_{3}=1 ; u_{2}$ $=1, u_{3}=0$; or $u_{2}=u_{3}=0$. We must choose $u_{2}=1, u_{3}=0$ to be consistent with the assignment made in Step 2. Thus our test consists of the input $u_{1}=1, u_{2}=1, u_{3}=0$.

It is apparent that there are two items of information about the circuit necessary to perform path sensitization. The topology, i.e., the gate interconnection or network information, is needed to determine the path through the circuit. In addition, the behavior of each gate must be known. For example, the information that an AND gate output is 1 only if both inputs are 1 , and 0 only if at least one input is 0 , is essential.

Path sensitization procedures differ in the manner in which the topological and behavioral information is stored and manipulated to generate tests. The D-algorithm uses "cubes" to pass behavioral information. An operation called intersection of cubes is performed to establish a chain or path through the circuit. Figure 2 illustrates the cube concept. The inputs to the AND gate are labeled 1 and 2 , and the output line is labeled 4. At the right in Figure 2 is a table whose heading has the input/output labels. The first row specifies that the output is 1 when both inputs are 1 , and the second and third, that the output is 0



Figure 2. An AND Gate With Its Singular Cover and D-Cubes
when either input is 0 . This is termed the singular cover of the function, and each row in the singular cover is called a cube. Below the singular cover is the error propagation information for the function. These are called D-cubes of a failure. The first cube indicates that a fault on input 1 can be propagated to output 4 if input 2 is 1 . These five cubes contain the behavioral information of an AND gate needed to generate a test in a circuit containing an AND gate.

Figure 3 repeats the circuit of Figure 1 showing its singular cover and, within dashed lines, D-cubes. This example is by Roth (1966). The intersection of two cubes determines how circuit conditions specified by the two cubes can be simultaneously satisfied. If the intersection does not exist, the two conditions assign different values to the same line, implying that the conditions are inconsistent. The intersection of cube $A=\left(a_{1}, a_{2}, \ldots, a_{n}\right)$ with cube $B=\left(b_{1}, b_{2}, \ldots, b_{n}\right)$ designated as $C=\left(c_{1}, c_{2}, \ldots, c_{n}\right)=A+B$ is defined as

$$
c_{j}=a_{j}
$$

if $a_{j}=b_{j}$ or if $b_{j}$ is unspecified. If $a_{j} \neq b_{j}$ for some $j$, then the intersection $C$ does not exist.

The algorithm itself involves intersecting the $D$-cubes in a trial and error fashion until a chain is formed from the site of the fault to a primary output. Selected node fanin and fanout information is saved as the algorithm progresses so that the topology of the network is progressively learned. Nodes not specified in the D-cube intersecting phase are assigned by intersecting the incomplete test cube with cubes from the singular cover until all lines for which it is possible to assign values have received them. The entire process may require a


Figure 3. A Simple Combinational Circuit With Its Singular Cover and D-Cubes
great deal of backtracking. A detailed description of the algorithm appears in Breuer and Friedman (1976, pp. 46-49). Detailed examples are also given in the former reference as well as in Roth's original paper (Roth, 1966).

In its most general form, the D-algorithm can always find a test if one exists. If the fault is undetectable, the procedure proves that no test exists.

Schneider (1967) has shown that in some cases it may be necessary to sensitize several paths simultaneously in a reconvergent fanout network to detect a fault. (A network has reconvergent fanout if at least one primary input and/or gate output branches out to two or more gates whose outputs lie on paths through the circuit which later reconverge as inputs to a single gate.) While multiple path sensitization is possible with the D-algorithm, Breuer (1981) asserts that multiple path sensitization cases are rare, and that practical implementations of the D-algorithm are often restricted to single path sensitization in order to reduce computation time.

The cube notation and calculus used by the $D$-algorithm is adequate with respect to behavioral information and is expressed in a format that is easily stored and manipulated by a computer. The representation of the behavioral information suffers from a lack of compactness, however. The need for so much backtracking in the algorithm execution is an indication that a lack of adequate topological information is available in the circuit model. Paths are discovered and problems such as those encountered in circuits containing reconvergent complemented fanout cannot be avoided due to a lack of topological information. (Reconvergent complemented fanout is defined and discussed in Chapter V.)

A variant of the D-algorithm, critical path sensitization, was introduced by Thomas (1971) and is employed in the stimulus generation section, STIMGN, of the D-LASAR system. The procedure involves first selecting a primary output line and assigning to it a critical 1 (0) value. Using sensitizing cubes, this value is driven back toward the primary inputs as in the justification procedure of the D-algorithm. Whenever a choice exists, one alternative is selected. In order to consider all possibilities, the other choices are reserved and used later by backtracking to the site of the choice and making an alternate assignment. For each choice of assignments, all implications of that choice are made. Each line assignment that is critical to the justification procedure is marked as it is generated, and all critical lines are driven back, all noncritical lines are justified using primitive cubes. When an inconsistency arises, making it impossible to justify a critical value by using a sensitizing cube, one can backtrack and use a primitive cube. This procedure is then repeated for each primary output.

The critical path test generation procedure is outlined in detail with examples in Breuer and Friedman (1976). It may fail to generate a test for a fault which requires multiple path sensitization but detects many faults along a sensitized path in one pass. This later characteristic makes it a fault-independent algorithm.

The D-LASAR system models all circuits in terms of their NAND gate equivalent network. This decreases the amount of behavioral information required, thus compacting that information. The disadvantaqes in modeling everything in terms of NAND gates are twofold. The number of gates in the circuit model can be significantly greater than in the original network. More storage may be required for the network description but
less for the cube description. The NAND gate equivalent description has been criticized because it is an abstraction of the original circuit and there may not be a one-to-one correspondence between the stuckat faults on the signal lines in the model and those of the original circuit.

The significant amount of backtracking and arbitrary assignment of line values when choices arise indicate here, as in the D-algorithm, that not enough topological information is contained in the model. Paths are discovered, as in the $D$-algorithm, by intersecting cubes to form a long path through the circuit.

Both the D-algorithm and D-LASAR utilize the iterative combinational array to model sequential circuits. In this model, the feedback loops are cut and the circuit reproduced into cells corresponding to an assigned time frame (see Figure 4). The feedback lines form pseudo outputs of time frame $j$ in cell $j$ and pseudo inputs to time frame $j+1$ in cell $j+1$. The test generation procedure results in a sequence of input vectors for each fault. Due to the memory characteristic of sequential circuits, it is desirable to obtain a test sequence that is independent of the initial circuit condition since initialization sequences may be difficult or sometimes impossible to generate. In addition, the presence of a fault in the circuit may invalidate an initialization sequence.

## Equation Manipulation

The final test generation procedure to be reviewed is the Boolean difference algorithm. The Boolean difference approach to ATG is a faultdependent Boolean equation manipulation procedure which utilizes the stuck-at fault model. As a mathematical concept, difference methods can


Figure 4. Sequential Circuit Modeled as an Iterative Combinational Array (Breuer and Friedman, 1976)
be traced to G. Boole in 1872. The elegant mathematical formulation of the Boolean calculus was first introduced by Akers (1959). The use of this calculus to derive tests for logic faults in digital circuits was first suggested by Professor E. Stabler to L. W. Bearnson at Syracuse University (Bearnson, 1965). Further development of the idea appeared in a paper by Sellers et al. (1968) and has since undergone extensive development. It is considered to be the classical equation manipulation approach to ATG.

Assume that a combinational circuit with inputs $u_{1}, u_{2}, \ldots, u_{n}$ realizes the function $f\left(u_{1}, u_{2}, \ldots, u_{n}\right)$. Let $f_{i}(0)=f\left(u_{1}, \ldots, u_{i-1}\right.$, $\left.0, u_{i+1}, \ldots, u_{n}\right)$ and $f_{i}(1)=f\left(u_{1}, \ldots, u_{i-1}, 1, u_{i+1}, \ldots, u_{n}\right)$. These represent the condition when input $u_{i}$ is stuck-at-0 and stuck-at-1, respectively. The objective in test generation is to find an input vector $U=\left(u_{1}, u_{2}, \ldots, u_{n}\right)$ that causes $f(U)$ and $f_{i}(0)\left(f_{i}(1)\right)$ to take on different values so that the presence of the fault will be detectable at the primary output. Equivalently, we wish to solve the equation $f(U) \oplus f_{i}(0)=1\left(f(U) \oplus f_{i}(1)=1\right)$ for $U$.

By Shannon's expansion algorithm, we have

$$
\begin{aligned}
f(u) \oplus f_{i}(0)= & {\left[u_{i} f_{i}(1)+u_{i}^{\prime} f_{i}(0)\right] \oplus f_{i}(0) } \\
& =\left[u_{i} f_{i}(1)+u_{i}^{\prime} f_{i}(0)\right] f_{i}^{\prime}(0) \\
& +f_{i}(0)\left[u_{i} f_{i}(1)+u_{i}^{\prime} f_{i}(0)\right]^{\prime} \\
& =u_{i} f_{i}(1) f_{i}^{\prime}(0)+u_{i} f_{i}^{\prime}(1) f_{i}(0) \\
& =u_{i}\left[f_{i}(1) \oplus f_{i}(0)\right]
\end{aligned}
$$

The factor $f_{i}(1) \oplus f_{i}(0)$ is referred to as the Boolean difference of $f$ with respect to $u_{i}$ and is given the symbol $d f / d u_{i}$. This symbol should
not be confused with the derivative notation in the calculus. The test for $u_{i}$ stuck-at-0 is the input vector (or vectors) $U$ that satisfy the equation

$$
u_{i} \frac{d f}{d u_{i}}=1 .
$$

Similarly, it can be shown that a test for $u_{i}$ stuck-at-l is the solution of the equation

$$
u_{i}^{\prime} \frac{d f}{d u_{i}}=1 .
$$

The circuit of figure 1 realizes the Boolean function $f\left(u_{1}, u_{2}, u_{3}\right)$
$=u_{2}\left(u_{1}+u_{3}\right)$. The test for $u_{1}$ stuck-at-0 is the solution of $u_{1}[f(0$, $\left.\left.u_{2}, u_{3}\right) \oplus f\left(1, u_{2}, u_{3}\right)\right]=u_{1}\left[u_{2} u_{3} \oplus u_{2}\right]=1$ or $u_{1} u_{2} u_{3}^{\prime}=1$. The solution is ( $1,1,0$ ) which tests for $u_{1}$ stuck-at-0 (see Table 1).

TABLE 1
BOOLEAN DIFFERENCE IDENTITIES

$$
\begin{align*}
& \frac{d f^{\prime}(U)}{d u_{i}}=\frac{d f(U)}{d u_{i}}  \tag{1}\\
& \frac{d[f(U) \cdot g(U)]}{d u_{i}}=f(U) \cdot \frac{d g(U)}{d u_{i}} \oplus g(U) \frac{d f(U)}{d u_{i}} \oplus \frac{d f(U)}{d u_{i}} \cdot \frac{d g(U)}{d u_{i}}  \tag{2}\\
& \frac{d[f(U)+g(U)]}{d u_{i}}=f^{\prime}(U) \cdot \frac{d g(U)}{d u_{i}} \oplus g^{\prime}(U) \frac{d f(U)}{d u_{i}} \oplus \frac{d f(U)}{d u_{i}} \cdot \frac{d g(U)}{d u_{i}}  \tag{3}\\
& \frac{d[f(U) \oplus g(U)]}{d u_{i}}=\frac{d f(U)}{d u_{i}} \oplus \frac{d g(U)}{d u_{i}} \tag{4}
\end{align*}
$$

The use of the identities listed in Table 1 reduces the amount of algebraic manipulation required in order to determine $d f / d u_{i}$. If one of the functions, say $g(U)$, is independent of the variable $u_{i}$, then $d g / d u_{i}=0$. When this situation exists, Equations (2) and (3) simplify as follows:

$$
\begin{align*}
& \frac{d[f(U) \cdot g(U)]}{d u_{i}}=g(U) \frac{d f(U)}{d u_{i}}  \tag{2a}\\
& \frac{d[f(U)+g(U)]}{d u_{i}}=g^{\prime}(U) \frac{d f(u)}{d u_{i}} \tag{3a}
\end{align*}
$$

In its original formulation, the Boolean difference approach could generate tests for stuck-at faults on primary input lines only. The concept of a chain rule to enable the computation of composite Boolean differences from the partial Boolean differences of the component functions was introduced by Marinos (1971). For example, the circuit of Figure 5 may be thought of as a composite of the functions $f$ and $g$, where $f=x_{1}=u_{1} u_{2}$ and $g=x_{3}=f+u_{3} u_{4}$. To generate a test for $x_{1}$ stuck-at-0, we solve

$$
x_{1} \frac{d x_{3}}{d x_{1}}=u_{1} u_{2} \frac{d\left(x_{1}+u_{3} u_{4}\right)}{d x_{1}}=u_{1} u_{2}\left(u_{3}^{\prime}+u_{4}^{\prime}\right)=1 .
$$

The tests are $(1,1,0, x)$ and $(1,1, x, 0)$, where $x$ represents a "don't care" value.

If each circuit element is considered to be a separate subcircuit, the method resembles the path sensitization procedure. A general form of the chain rule was derived by Chang, Reed, and Banes (1972). Their formula is closely related to the multiple path sensitization concept. Applications of the Boolean difference approach for fault detection in

Figure 5. Circuit Viewed as Composite Functions
both asynchronous and synchronous sequential machines exist (Prior and Bennetts, 1974; Hsiao and Chia, 1971).

The Boolean difference approach derives all possible tests which detect a given fault. Since the equation for the circuit is needed, the time and memory requirements for generation of the circuit equations may be excessive for large circuits. Computers are not known to be particularly efficient at manipulation of symbols and simplification of equations.

## Summary

The fundamental concepts involved in two basic approaches to automatic test generation have been presented. The path sensitization procedure introduced in Roth's D-algorithm (1966) and later modified for use in D-LASAR (Thomas, 1971) is performed by representing the behavior of a circuit by cubes. A path is traced through the circuit by intersecting the cubes according to the rules of the cube calculus. It was noted that in both instances, the behavioral information was adequately supplied to make the algorithm efficient; however, lack of adequate topological information in the cubical representation led to time consuming backtracking in the algorithms.

The Boolean Difference procedure was shown to be an elegant mathematical concept which generates all possible tests for stuck-type faults. However, since it requires the Boolean equation of the circuit, time and memory requirements for generating the equation for large circuits may be excessive.

## CHAPTER III

MODELING DIGITAL SYSTEMS

Introduction

Automatic test generation algorithms based upon a gate level circuit model can benefit from both topological and behavioral information. The efficiency of the algorithm depends, to alarge extent, on the mathematical formulation of this information. The mathematical model should be capable of simultaneously describing the gate level interconnection structure and the logical behavior of each individual gate in a concise mathematical representation suitable for easy storage in and manipulation by a computer.

In this chapter, a mathematical model of digital systems is introduced. The model represents a digital system as a set of discrete time Boolean equations expressed in matrix notation. The emphasis of this chapter is to illustrate how the model is formulated from a gate level circuit diagram and to illustrate the representation of behavioral information. The following chapter emphasizes the features of the model pertaining to the network topology and to the machine storage complexity of the model itself.

## Notation

A Boolean function is a function $f$ with domain $\{0,1\}^{n}=B^{n}$ and range $B=\{0,1\}$, where $n$ is an integer and $B^{n}$ represents the $n$-fold

Cartesian product of the set $B$ with itself. A set of $m$ Boolean functions $f_{1}, f_{2}, \ldots, f_{m}$, each of which maps $B^{n}$ into $B$, can be represented by a single function $f$ whose domain is $B^{n}$ and whose range is $B^{m}$.

There are exactly four Boolean functions from $B$ into $B$. These functions are:

Identity
Complement (NOT)
Constant Unit
Constant Zero

$$
\begin{aligned}
f_{i}(x) & =x \\
f_{c}(x) & =x^{\prime} \\
f_{u}(x) & =1 \\
f_{0}(x) & =0
\end{aligned}
$$

for $x \in B$. The notation can be simplified by dropping the $f$ and the parentheses from the functional notation.

| Identity | $i x=x$ |
| :--- | :--- |
| Complement (NOT) | $\mathrm{cx}=\mathrm{x}^{\prime}$ |
| Constant Unit | $\mathrm{ux}=1$ |
| Constant Zero | $\mathrm{ox}=0$. |

Two other very important functions are the Boolean AND and Boolean OR functions whose truth tables are exhibited in Table ll. These functions are used so frequently that a shorthand notation exists for them: $f_{O R}\left(x_{1}, x_{2}\right)=x_{1}+x_{2}, f_{\text {AND }}\left(x_{1}, x_{2}\right)=x_{1} \cdot x_{2}$. One canonical representation of a Boolean function is the disjunctive normal form (DNF) which is formed by composition of the AND, OR, and NOT functions. Because every Boolean function can be represented through functional composition of the three functions $A N D, O R$, and $N O T$, these three functions form a basis set for the set of all Boolean functions. Other basis sets exist, e.g., \{OR, NOT\} and \{AND, NOT\}. When the two functions AND and NOT are composed, the resulting composition function is called the NAND (NOT

AND) function. Similarly, the NOR (NOT OR) function arises from the composition of the OR and NOT functions. Each of these functions also forms a basis for the set of all Boolean functions.

TABLE 11
TRUTH TABLES FOR "AND" AND "OR' FUNCTIONS

| $x_{1}$ | $x_{2}$ | $f_{A N D}\left(x_{1}, x_{2}\right)=x_{1} \cdot x_{2}$ | $x_{1}$ | $x_{2}$ | $f_{O R}\left(x_{1}, x_{2}\right)=x_{1}+x_{2}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 0 | 0 | 1 | 1 |
| 1 | 0 | 0 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 | 1 | 1 |

Let $C=\{i, o, c, u\}$ be the set of functions from $B$ into $B$ and $F$ be the set of all $m \times n$ matrices whose entries are functions from the set $C$. The elements of $F$ are called transformations from $B^{n}$ into $B^{m}$. In particular for $U=\left(u_{1}, u_{2}, \ldots, u_{n}\right)^{\top} \varepsilon B^{n}$, we define the $m \times n$ transformation matrix $A$ operating on $U$ as

$$
A U=\left[\begin{array}{ccc}
a_{11} & \cdots & a_{1 n} \\
\cdot & & \cdot \\
\cdot & & \cdot \\
\cdot & & \cdot \\
a_{1 m} & \cdots & a_{m n}
\end{array}\right]\left[\begin{array}{c}
u_{1} \\
u_{2} \\
\vdots \\
u_{n}
\end{array}\right]=\left[\begin{array}{cccc}
a_{11} & u_{1}+a_{12} & u_{2}+\ldots+a_{1 n} & u_{n} \\
\cdot & \cdot & & \cdot \\
\cdot & \cdot & & \cdot \\
\cdot & \cdot & & \\
a_{m 1} & u_{1}+a_{m 2} & u_{2}+\ldots+a_{m n} & u_{n}
\end{array}\right]
$$

The set $F$ contains an $(n \times n)$ identity transformation $I_{n}=\left(a_{k j}\right)$, where $a_{k j}=i$ when $k=j$ and $a_{k j}=0$ when $k \neq j$. The identity transformation
maps every vector $X \in B^{n}$ into itself. The ( $m \times n$ ) zero transformation, $0_{m, n}=\left(a_{i j}\right)$, is the matrix, all of whose entries are ocC. The zero transformation maps every $X_{\varepsilon} B^{n}$ into an $m$-vector, all of whose elements are zero.

If $A, B \varepsilon F$ and $X, U \varepsilon B^{n}$ then $A X+B U \varepsilon B^{m}$, where addition is understood to be the Boolean OR operation on vectors in $B^{m}$.

A transformation $T \varepsilon F$ is, in general, nonlinear. This can be easily proven by exhibiting a counter example. Let $T: B^{3} \rightarrow B^{2}$ be the transformation $T\left(u_{1}, u_{2}, u_{3}\right)^{\top}=\left(c u_{1}, o\right)^{\top}$.

Then $T=\left[\begin{array}{lll}c & 0 & 0 \\ 0 & 0 & 0\end{array}\right]$ in matrix form. For $\alpha, \beta \in B$, $T(\alpha U+\beta V)=\left[\begin{array}{lll}c & 0 & 0 \\ 0 & 0 & 0\end{array}\right]\left[\begin{array}{c}\alpha u_{1}+\beta v_{1} \\ \alpha u_{2}+\beta v_{2} \\ \alpha u_{3}+\beta v_{3}\end{array}\right]=\left[\begin{array}{c}c\left(\alpha u_{1}+\beta v v_{1}\right) \\ 0\end{array}\right]=\left[\begin{array}{c}\left(c \alpha+c u_{1}\right)\left(c \beta+c v_{1}\right) \\ 0\end{array}\right]$ $\neq \alpha T U+\beta T V$.

Combinational Circuit Model

Logic circuits physically realize Boolean functions through composition of functions from the basis set \{AND, OR, NOT\}. The gate level logic diagram of a combinational circuit describes the interconnection of basic logic gates which represent the Boolean functions AND, OR, NOT, NAND, and NOR. Given a gate level logic diagram, we adopt the following line labeling convention: Primary inputs are labeled $u_{1}, u_{2}, \ldots, u_{n}$, and the internal lines are labeled $x_{j}$, where the subscript $j$ must be greater than $n$ and greater than the subscript of any line label on any path between the primary inputs and the line $x_{j}$. Figure 6 is a labeled

generic logic diagram where $f_{i}$ represents one of the Boolean functions AND, OR, NOT, NAND, or NOR.

The logic diagram can be thought of as a graph of the chain of Boolean function compositions. For example, in Figure 6

$$
\begin{aligned}
& x_{1}=i u_{1} \\
& x_{2}=i u_{2} \\
& x_{3}=i u_{3} \\
& x_{4}=i u_{4} \\
& x_{5}=f_{1}\left(x_{1}, x_{2}\right) \\
& x_{6}=f_{2}\left(x_{2}, x_{3}\right) \\
& x_{7}=f_{3}\left(x_{3}\right) \\
& x_{8}=f_{4}\left(x_{5}, x_{6}\right) \\
& x_{9}=f_{5}\left(x_{4}, x_{7}\right)
\end{aligned}
$$

where $x_{1}$ through $x_{4}$ represent data steps, and $x_{5}$ through $x_{9}$ represent computation steps. This is called a 9-step chain. (See Savage [1976] for a definition of k-step computation chains.)

If we restrict the logic diagram to contain only gates which represent the Boolean functions NAND, OR, and NOT, the computation chain takes on a linear-looking form. The circuit in Figure 7 contains only NAND, NOT, and $O R$ gates. The original circuit was an $A N D, O R$ circuit. The output lines of NOT gates inserted during modeling are not labeled. The computation chain of the modeled circuit is as follows:

$$
\left.\begin{array}{l}
x_{1}=i u_{1} \\
x_{2}=i u_{2} \\
x_{3}=i u_{3}
\end{array}\right\} \quad \text { DATA STEPS }
$$



$$
\left.\begin{array}{l}
x_{4}=c x_{1}+c x_{2} \\
x_{5}=c x_{2}+c x_{3} \\
x_{6}=c x_{4}+c x_{5}
\end{array}\right\} \quad \text { COMPUTATION STEPS }
$$

In matrix notation the set of equations is written:

$$
\begin{aligned}
& {\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5} \\
x_{6}
\end{array}\right]=\left[\begin{array}{llllll}
0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 \\
c & c & 0 & 0 & 0 & 0 \\
0 & c & c & 0 & 0 & 0 \\
0 & 0 & 0 & c & c & 0
\end{array}\right]\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5} \\
x_{6}
\end{array}\right]+\left[\begin{array}{lll}
i & 0 & 0 \\
0 & i & 0 \\
0 & 0 & i \\
0 & 0 & 0 \\
0 & 0 & 0 \\
0 & 0 & 0
\end{array}\right]\left[\begin{array}{l}
u_{1} \\
u_{2} \\
u_{3}
\end{array}\right]} \\
& {[y]=\left[\begin{array}{llllll}
0 & 0 & 0 & 0 & 0 & i
\end{array}\right] x}
\end{aligned}
$$

where the entries in the matrices are functions from the set $C=$ $\{i, o, c, u\}$ of Boolean functions of one variable.

In general, the equations describing the behavior of a digital combinational logic circuit with $n$ primary inputs $u_{1}, u_{2}, \ldots, u_{n} ; p$ logic gates of the type AND, OR, NOR, NAND, NOT, whose outputs are labeled $x_{n+1}, x_{n+2}, \ldots, x_{n+p}$; and m primary outputs $y_{1}, y_{2}, \ldots, y_{m}$ can be expressed in the form

$$
\begin{aligned}
& X=A X+B U \\
& Y=D X
\end{aligned}
$$

where $x=\left(x_{1}, x_{2}, \ldots, x_{n+p}\right)^{\top} \varepsilon B^{n+p}, u=\left(u_{1}, u_{2}, \ldots, u_{n}\right)^{\top} \varepsilon B^{n}$, and $Y=\left(y_{1}, y_{2}, \ldots, y_{m}\right)^{\top} \varepsilon B^{m}$. The matrix $A \varepsilon F$ is an $(n+p, n+p)$ matrix which can be partitioned into submatrices.

$$
A=\left[\begin{array}{c:c}
0_{n, n} & 0_{n, p} \\
\hdashline A & A^{p} p, p
\end{array}\right] .
$$

The matrix $B \varepsilon F$, a $(n+p, n)$ matrix, can also be partitioned into submatrices.

$$
B=\left[\begin{array}{l}
1_{n, n} \\
0 \\
p, n
\end{array}\right] .
$$

$D \varepsilon F$ is an ( $m, n+p$ ) matrix. Because of the labeling convention, the A matrix is lower triangular, as is the matrix $A_{2}$.

During modeling, all circuit gates are represented in terms of NAND, OR, and NOT gates to achieve the linear-looking equations. Three questions arise:

1. How difficult is it to model a circuit in terms of these gates only?
2. What relationship does the signal line in the model have to the actual gate level circuit description?
3. What effect does modeling with NAND, OR, and NOT gates have on test generation for stuck-at faults?

The first two questions will be addressed simultaneously. Figure 8 shows how easily each circuit element can be represented in terms of the NAND, OR, NOT gates. There is a one-to-one correspondence between the signal lines in the standard representation and the model representation since the output to inserted inverters are not labeled.

A test for the output of an AND (OR) gate stuck-at-1 is also a test for the output of a NAND (NOR) gate stuck-at-0. When an ATG algorithm tries to generate tests for all stuck-at-1 and stuck-at-0 faults in the


Figure 8. Model Representation of Logic Gates
circuit model, the test derived will also test for the stuck-at-faults in the original circuit. Knowledge of the fact that ANDs are modeled with NANDs followed by inverters and NORs as ORs followed by inverters, and knowledge of the above facts concerning the relationship between stuck-at faults in the modeled circuit and the actual circuit enables a straightforward fault location and diagnosis procedure.

Figure 9 illustrates the modeling process using an exclusive-OR (XOR) gate. Two ways to model it are shown. The matrix equation associated with each model appears on the right.

To further illustrate the modeling procedure for combinational circuits, figure 10 shows a gate level diagram of a circuit and the representation from which a transformation matrix can be written. The matrix equation is

$$
\begin{aligned}
& {\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5} \\
x_{6}
\end{array}\right]=\left[\begin{array}{llllll}
0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 \\
c & c & 0 & 0 & 0 & 0 \\
0 & i & i & 0 & 0 & 0 \\
0 & 0 & 0 & c & c & 0
\end{array}\right]\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5} \\
x_{6}
\end{array}\right]+\left[\begin{array}{lll}
i & 0 & 0 \\
0 & i & 0 \\
0 & 0 & i \\
0 & 0 & 0 \\
0 & 0 & 0 \\
0 & 0 & 0
\end{array}\right]\left[\begin{array}{l}
u_{1} \\
u_{2} \\
u_{3}
\end{array}\right]} \\
& {[y]=\left[\begin{array}{llllll}
0 & 0 & 0 & 0 & 0 & i
\end{array}\right] x}
\end{aligned}
$$

The modeling of all logic gates in terms of NAND, OR, and NOT gates is an intermediate step between the logic circuit described with AND, OR, NOT, NAND, NOR, and XOR gates and that proposed by Thomas (1971) of using only NAND gates. While the NAND gate model can also be represented in the matrix formulation, the complexity of modeling is slightly


Figure 9. Exclusive-OR (XOR) Representations


> (a) Gate Level Combinational Circuit Diagram

(b) Gate Level Transformation

Figure 10. Combinational Circuit Modeling
larger. Figure 11 shows the $O R$ gate and NOT (inverter) modeled as NAND gates. The matrix representations, however, have the same dimensions.

It is possible to use the idea of computation chains to model the combinational circuit and omit the data steps. When this is done, a smaller-dimensioned representation is obtained; however, it is not as useful in ATG as the one presented. For completeness, however, Figure 12 illustrates the labeling procedure and matrix representation for the same circuit as Figure 10. Note that the matrix operating on the $U$ vector in Figure 12 is the same as the submatrix $A_{1}$ in the representation for Figure 10.

Before introducing the sequential circuit model, one other interesting observation is made. It is possible to represent a Boolean function in the matrix representation, independent of a gate level diagram. For example, if

$$
f\left(u_{1}, u_{2}, u_{3}\right)=u_{1} u_{2} u_{3}^{\prime}+u_{2}^{\prime} u_{3}
$$

let

$$
\left.\begin{array}{l}
x_{1}=u_{1} \\
x_{2}=u_{2} \\
x_{3}=u_{3}
\end{array}\right\} \quad \text { DATA STEPS }
$$

and

$$
y=i x_{6}
$$

$x_{1}=u_{1} \longrightarrow x^{x_{2}} y \rightarrow u_{1} \rightarrow \underbrace{x_{2}} y$
$\left[\begin{array}{l}x_{1} \\ x_{2}\end{array}\right]=\left[\begin{array}{ll}0 & 0 \\ c & 0\end{array}\right]\left[\begin{array}{l}x_{1} \\ x_{2}\end{array}\right]+\left[\begin{array}{l}i \\ 0\end{array}\right]\left[\begin{array}{l}u_{1} \\ \end{array}\right]$
$\left[\begin{array}{l}y\end{array}\right]=\left[\begin{array}{ll}0 & i\end{array}\right]\left[\begin{array}{l}x_{1} \\ x_{2}\end{array}\right]$
$x_{1}=u_{1} \rightarrow+u_{2} \rightarrow u_{1}$

$$
\begin{aligned}
& {\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3}
\end{array}\right]=\left[\begin{array}{lll}
0 & 0 & 0 \\
0 & 0 & 0 \\
i & i & 0
\end{array}\right]} \\
& {[y]=\left[\begin{array}{lll}
0 & 0 & i
\end{array}\right]}
\end{aligned}
$$

$$
\begin{aligned}
& {\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3}
\end{array}\right]} \\
& {\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3}
\end{array}\right]}
\end{aligned}
$$

Figure 11. NOT and OR Gates Represented in Terms of NAND Gates


$$
\left.\begin{array}{l}
{\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3}
\end{array}\right]=\left[\begin{array}{lll}
0 & 0 & 0 \\
0 & 0 & 0 \\
c & c & 0
\end{array}\right]\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3}
\end{array}\right]+\left[\begin{array}{lll}
c & c & 0 \\
0 & i & i \\
0 & 0 & 0
\end{array}\right]=\left[\begin{array}{l}
u_{1} \\
0
\end{array} 0\right.} \\
i
\end{array}\right]\left[\begin{array}{l}
u_{2} \\
u_{1} \\
u_{3}
\end{array}\right]
$$

Figure 12. Compact Matrix Formulation

In matrix form

$$
\begin{aligned}
& {\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5} \\
x_{6}
\end{array}\right]=\left[\begin{array}{llllll}
0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 \\
c & c & i & 0 & 0 & 0 \\
0 & i & c & 0 & 0 & 0 \\
0 & 0 & 0 & c & c & 0
\end{array}\right]\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5} \\
x_{6}
\end{array}\right]+\left[\begin{array}{lll}
i & 0 & 0 \\
0 & i & 0 \\
0 & 0 & i \\
0 & 0 & 0 \\
0 & 0 & 0 \\
0 & 0 & 0
\end{array}\right]\left[\begin{array}{l}
u_{1} \\
u_{2} \\
u_{3}
\end{array}\right]} \\
& {[y]=\left[\begin{array}{llllll}
0 & 0 & 0 & 0 & 0 & i
\end{array}\right] x}
\end{aligned}
$$

## Sequential Circuit Model

The sequential circuit will be modeled as an iterative combinational array (Breuer and Friedman, 1976). The matrix formulation achieves a concise representation for this model. The delay symbol pictured in Figure 13 will be incorporated into the gate level diagram in feedback loops to denote the time frames (not to be confused with clock pulses in synchronous sequential circuits or with actual circuit delay).

The computation chain for the circuit of Figure $13 b$ is

$$
\begin{aligned}
& x_{1}(t)=u_{1}(t) \\
& x_{2}(t)=u_{2}(t) \\
& x_{3}(t)=c x_{1}(t)+c x_{4}(t-1) \\
& x_{4}(t)=c x_{2}(t)+c x_{3}(t-1)
\end{aligned}
$$

The computation chain is shown in matrix form on page 41. In general, a sequential circuit can be represented in the form

$$
\begin{aligned}
& X(t)=A X(t)+B U(t)+C X(t-1) \\
& Y(t)=D X(t)
\end{aligned}
$$


(a) Delay Symbol

(b) Delay Symbol in Feedback Loop

Figure 13. Sequential Circuit Modeling

$$
\begin{aligned}
& {\left[\begin{array}{l}
x_{1}(t) \\
x_{2}(t) \\
x_{3}(t) \\
x_{4}(t)
\end{array}\right]=\left[\begin{array}{llll}
0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 \\
c & 0 & 0 & 0 \\
0 & c & 0 & 0
\end{array}\right]\left[\begin{array}{l}
x_{1}(t) \\
x_{2}(t) \\
x_{3}(t) \\
x_{4}(t)
\end{array}\right]+\left[\begin{array}{ll}
i & 0 \\
0 & i \\
0 & 0 \\
0 & 0
\end{array}\right]\left[\begin{array}{l}
u_{1}(t) \\
u_{2}(t)
\end{array}\right]+\left[\begin{array}{llll}
0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 \\
0 & 0 & 0 & c \\
0 & 0 & c & 0
\end{array}\right]\left[\begin{array}{l}
x_{1}(t-1) \\
x_{2}(t-1) \\
x_{3}(t-1) \\
x_{4}(t-1)
\end{array}\right]} \\
& {\left[\begin{array}{l}
y_{1}(t) \\
y_{2}(t)
\end{array}\right]=\left[\begin{array}{llll}
0 & 0 & i & 0 \\
0 & 0 & 0 & i
\end{array}\right]\left[\begin{array}{l}
x_{1}(t) \\
x_{2}(t) \\
x_{3}(t) \\
x_{4}(t)
\end{array}\right]}
\end{aligned}
$$

where $A, B, C$, and $D \varepsilon F$, $t$ is an integer time step, $U(t) \varepsilon B^{n}, Y(t) \varepsilon B^{m}$. $A$ and $B$ can be partitioned as in the combinational case and the matrix C can be partitioned

$$
c=\left[\begin{array}{c:c}
0_{n, n} & 0_{n, p} \\
\hdashline c_{1}, n & c_{2}, p, p
\end{array}\right]
$$

Figure 14 is a labeled gate level diagram of a clocked D-flip flop. The matrix representation for this synchronous sequential flip flop is shown on page 44.

## Summary

Mathematical matrix representations which describe the behavior of digital systems have been derived. The gate level logic diagram is represented in terms of NAND, OR, and NOT gates and a $k$-step computation chain is formed. The coefficients of each variable in the computation chain is a Boolean function from the set $C=\{0, i, c, u\}$. Sequential circuits are represented as iterative combinational arrays and represented in the matrix format through the introductions of a delay element in each feedback loop. Mathematically, the delay is represented by an integer, $t$, which corresponds to the iteration number.


$$
\begin{aligned}
& {\left[\begin{array}{l}
x_{1}(t) \\
x_{2}(t) \\
x_{3}(t) \\
x_{4}(t) \\
x_{5}(t)
\end{array}\right]=\left[\begin{array}{lllll}
0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 \\
c & c & 0 & 0 & 0 \\
0 & i & 0 & 0 & 0 \\
0 & 0 & c & c & 0
\end{array}\right]\left[\begin{array}{l}
x_{1}(t) \\
x_{2}(t) \\
x_{3}(t) \\
x_{4}(t) \\
x_{5}(t)
\end{array}\right]+\left[\begin{array}{ll}
i & 0 \\
0 & i \\
0 & 0 \\
0 & 0 \\
0 & 0
\end{array}\right]\left[\begin{array}{l}
u_{1}(t) \\
u_{2}(t)
\end{array}\right]+\left[\begin{array}{lllll}
0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & c \\
0 & 0 & 0 & 0 & 0
\end{array}\right]\left[\begin{array}{l}
x_{1}(t-1) \\
x_{2}(t-1) \\
x_{3}(t-1) \\
x_{4}(t-1) \\
x_{5}(t-1)
\end{array}\right]} \\
& {\left[\begin{array}{l}
y_{1}(t) \\
y_{2}(t)
\end{array}\right]=\left[\begin{array}{lllll}
0 & 0 & 0 & 0 & i \\
0 & 0 & 0 & 0 & c
\end{array}\right]\left[\begin{array}{l}
x_{1}(t) \\
x_{2}(t) \\
x_{3}(t) \\
x_{4}(t) \\
x_{5}(t)
\end{array}\right]}
\end{aligned}
$$

## MODEL CHARACTERISTICS AND EXTENSIONS

## Introduction

The logical behavior of digital systems is a dominant feature of digital circuits when generating tests for logical faults. Because it is necessary in automatic test generation to derive an input to the circuit which allows one to observe a fault on an internal signal line at a primary output, most fault-dependent algorithms have taken the path sensitization approach. Locating and tracing specific paths through the circuit requires some topological information. Both the logic behavior and topological information must be presented in a concise, efficient manner that is amenable to computer storage and manipulation.

Characteristics of the matrix model of digital circuits as they relate to the topology of the system will be given in this chapter. Other features of the circuit contained in the matrix description will be pointed out, and the relationship between the size of the describing matrix and circuit size will be presented. The original model will be extended to include variables associated with each fork in a fanout path in the circuit so that complete coverage of single permanent stuck-at faults can be achieved.

## Combinational Circuit Topology

A combinational circuit can be thought of as a directed graph whose
vertices consist of the primary inputs and logic gates and whose edges are represented by the signal lines. A directed graph corresponding to Figure $10(a)$ is given in Figure 15. The adjacency matrix associated with a directed graph $G$ having $n$ vertices and no parallel edges is an $n \times n$ binary matrix $A_{G}=\left(a_{i j}\right)$ such that

$$
\begin{aligned}
a_{i j}= & 1 \text { if there is an edge directed from the ith vertex } \\
& \text { to the } j \text { th vertex, and } \\
= & 0 \text { otherwise }
\end{aligned}
$$

(Deo, 1974). The adjacency graph for Figure 15 is

$$
\left.\begin{array}{c}
A_{G}=\begin{array}{c}
u_{1} \\
u_{2} \\
u_{1} \\
u_{2} \\
u_{3} \\
G_{1} \\
G_{1} \\
G_{2} \\
G_{1}
\end{array}\left[\begin{array}{lllll}
G_{2} & G_{3} \\
0 & 0 & 0 & 1 & 0 \\
0 & 0 & 0 & 1 & 1
\end{array}\right] \\
0
\end{array}\left[\begin{array}{lllll}
0 & 0 & 0 & 1 & 0 \\
0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0
\end{array}\right] 1\right]
$$

It can be seen by inspection that the transpose of $A_{G}$ and the $A$ matrix for Figure 10 have corresponding entries. In particular, every nonzero entry in $A$ corresponds to a nonzero entry in the transpose of $A_{G}$. This direct correspondence indicates that the network connection (topological) information is contained in the $A$ matrix of the model. Since the network interconnection information is present in $A$, the fanin (fanout) of the individual vertices (primary inputs and logic gates) can be computed by counting the number of nonzero entries in the row (column) associated with that vertex.


In particular, define $r_{i}$ equal to the number of nonzero entries in row $i$ of the $A$ matrix and $k_{j}$ equal to the number of nonzero entries in column $j$ of the matrix $A$. Then $r_{i}$ is the fanin of the gate with output labeled $x_{i}$, and $k_{j}$ is the fanout of the gate with output labeled $x_{j}$ or of a primary input $u_{j}$. The vectors $R=\left(r_{i}\right)$ and $K=\left(k_{j}\right)^{\top}$ will be referred to as the fanin and fanout vectors, respectively.

The fanin vector for the network of Figure 15 is $R=(0,0,0,2,2,2)^{\top}$. The fanout vector is $K=(1,2,1,1,1,0)^{\top}$.

## Combinational Circuit Matrix Complexity

Define the complexity, $\gamma$, of a matrix to be the number of nonzero elements in the matrix. In the adjacency matrix of a graph, $G$, the $i n-$ teger $\gamma$ equals the number of edges in $G$. The matrix parameter $\gamma$ is related to the amount of computer storage necessary to represent the matrix.

For conciseness, the system of equations

$$
X=A X+B U
$$

will be rewritten as

$$
X=M\left[\begin{array}{c}
U \\
X_{p}
\end{array}\right]
$$

where

$$
M=\left[\begin{array}{c:c}
I_{n} & 0 \\
\hdashline A_{1} & A_{2}
\end{array}\right]
$$

and

$$
x_{p}=\left(x_{n+1}, x_{n+2}, \ldots, x_{p}\right)
$$

This formulation takes advantage of the fact that $x_{i}=u_{i}$ for $i=1,2$, ..., n. For example, for the circuit of Figure 10 ,

$$
M=\left[\begin{array}{llllll}
i & 0 & 0 & 0 & 0 & 0 \\
0 & i & 0 & 0 & 0 & 0 \\
0 & 0 & i & 0 & 0 & 0 \\
c & c & 0 & 0 & 0 & 0 \\
0 & i & i & 0 & 0 & 0 \\
0 & 0 & 0 & c & c & 0
\end{array}\right] .
$$

The matrix $M$ will be referred to as the defining matrix for the system since it contains both the behavioral and topological information. It can be easily seen that the number of nonzero elements in $M$

$$
\gamma=n+\sum_{n+1}^{n+p} r_{i}=n+\sum_{j=1}^{n+p} k_{j} .
$$

The lower limit of the first summation is $n+1$ because the first $n$ rows of A contain only the null element o. The complexity measure, $\gamma$, corresponds to the number of primary inputs plus the sum of all fanin (fanout) connections in the circuit including primary outputs. For the circuit of Figure $10, \gamma=3+6=9$. The upper limit on $\gamma$ is $\gamma_{\max }=n+\min$ $\left\{p \cdot\left(r_{i}\right)_{\text {max }},(n+p)\left(k_{j}\right)_{\text {max }}\right\}$.

A measure of the sparsity of a matrix is given by its density. The density is defined to be the number of nonnull elements divided by the total number of matrix elements. The density of $M$ is

$$
d=\frac{\gamma}{(n+p)^{2}} .
$$

The density of the defining matrix $M$ for Figure 10 is $d=9 / 36=0.25$.

To completely test a combinational circuit for single permanent stuck-type faults, fanout on primary input signals and at the output of internal gates must be considered. Figure 16, an example from Breuer and Friedman (1976), illustrates the necessity to differentiate between the different forks on a signal path. The input signal $u_{2}$ fans out to gates $G_{1}$ and $G_{2}$. This signal may appear normal at one gate and faulty on the other. If $u_{2}$ is stuck-at-1, then both a and bare also 1 and the output $y$ becomes $u_{2}+u_{3}$. However, the fault in which the input lead a to $G_{1}$ is stuck-at-1 but the signal b still corresponds to $u_{2}$ results in the output $y=u_{1}+u_{2} u_{3}$. Similarly, if the input lead b to $G_{2}$ is stuck-at-1 while signal a still corresponds to $u_{2}, y=u_{1} u_{2}+u_{3}$.

This situation can be included in the model by labeling each fork in a fanout path. With this expansion, note that $p$ is no longer equal to the number of gates in the circuit, but is equal to the number of gates plus the number of newly labeled forks. Figure 17 illustrates the labeling procedure for the circuit in Figure 16. The computation chain becomes

$$
\begin{aligned}
& x_{1}=u_{1} \\
& x_{2}=u_{2} \\
& x_{3}=u_{3} \\
& x_{4}=x_{2} \\
& x_{5}=x_{2} \\
& x_{6}=c x_{1}+c x_{4} \\
& x_{7}=c x_{3}+c x_{5} \\
& x_{8}=c x_{6}+c x_{7} .
\end{aligned}
$$




In matrix form
$\left[\begin{array}{l}x_{1} \\ x_{2} \\ x_{3} \\ x_{4} \\ x_{5} \\ x_{6} \\ x_{7} \\ x_{8}\end{array}\right]=\left[\begin{array}{llllllll}i & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & i & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & i & 0 & 0 & 0 & 0 & 0 \\ 0 & i & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & i & 0 & 0 & 0 & 0 & 0 & 0 \\ c & 0 & 0 & c & 0 & 0 & 0 & 0 \\ 0 & 0 & c & 0 & c & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & c & c & 0\end{array}\right]\left[\begin{array}{l}u_{1} \\ u_{2} \\ u_{3} \\ x_{4} \\ x_{5} \\ x_{6} \\ x_{7} \\ x_{8}\end{array}\right]$

$$
[y]=\left[\begin{array}{llllllll}
0 & 0 & 0 & 0 & 0 & 0 & 0 & i
\end{array}\right] \quad x
$$

The dimension of $M$ is increased by 2 rows and 2 columns, the density of $M$ is 0.17 compared to $d=0.25$ before the extension, and $\gamma=11$ compared to $\gamma=9$ prior to the extension. It is expected that when more details of the circuit are modeled, the complexity of the model will increase.

The fanout vector $K=(1,2,1,1,1,1,1,0)^{\top}$ indicates explicitly that $x_{2}=u_{2}$ is the line which forks. In general, when $k_{j}>1$, the defining matrix will contain $\sum_{j=1}^{n+p} k_{j}$, more elements than the nonextended matrix. The maximum increase in complexity, $\Delta_{\text {max }}$, due to extending the model is equal to $\left(k_{j}\right)_{\max }$ times the number of gates plus primary inputs. The maximum complexity of the extended model is equal to the maximum complexity of the unextended model plus $\Delta_{\text {max }}$. This quantity is linear in the number of gates plus primary inputs.
the delay symbols as vertices) is

$$
A_{G}=\left[\begin{array}{llll}
0 & 0 & 1 & 0 \\
0 & 0 & 0 & 1 \\
0 & 0 & 0 & 1 \\
0 & 0 & 1 & 0
\end{array}\right]
$$

In the model, topological (directed interconnections) information is contained in both $A$ and $C$. The entries in the transpose of $A_{G}$ correspond to entries in $A+C$, where addition in $C$ is defined by the table:

| + | 0 | $i$ | $c$ | $u$ |
| :---: | :---: | :---: | :---: | :---: |
| $o$ | $o$ | $i$ | $c$ | $u$ |
| $i$ | $i$ | $i$ | $u$ | $u$ |
| $c$ | $c$ | $u$ | $c$ | $u$ |
| $u$ | $u$ | $u$ | $u$ | $u$ |

and matrix addition in $F$ is defined as in ordinary matrix algebra, i.e., $A+B=\left(a_{i j}\right)+\left(b_{i j}\right)=\left(a_{i j}+b_{i j}\right)$.

In particular, $A+C$ for the model of figure 13 is given by

$$
A+C=\left[\begin{array}{llll}
0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 \\
c & 0 & 0 & c \\
0 & c & c & 0
\end{array}\right]
$$

For sequential circuits, the fanin (fanout) vectors are found by counting the number of nonzero elements in the rows (columns) of $A+C$. The fanin vector for the above example is $R=(0,0,2,2)^{\top}$ and the fanout vector is $K=(1,1,1,1)^{\top}$.
Sequential Circuit Matrix Complexity

The defining matrix for a sequential circuit is defined to be

$$
M=\left[\begin{array}{c:c:c}
A_{n} & 0 & 0 \\
\hdashline A_{1} & A_{2} & C_{2}
\end{array}\right]
$$

where the submatrices $A_{1}, A_{2}$, and $C_{2}$ are submatrices of $A$ and $C$. The general equation can now be expressed as

$$
X(t)=M\left[\begin{array}{c}
U \\
X_{p}(t) \\
X_{p}(t-1)
\end{array}\right]
$$

where $x_{p}=\left(x_{n+1}, x_{n+2}, \ldots, x_{n+p}\right)$.
For the circuit of Figure 14 ,

$$
M=\left[\begin{array}{cc:ccc:ccc}
i & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & i & 0 & 0 & 0 & 0 & 0 & 0 \\
\hdashline c & c & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & i & 0 & 0 & 0 & 0 & 0 & c \\
0 & 0 & c & c & 0 & 0 & 0 & 0
\end{array}\right]
$$

and the equation is written as

$$
\left[\begin{array}{l}
x_{1}(t) \\
x_{2}(t) \\
x_{3}(t) \\
x_{4}(t) \\
x_{5}(t)
\end{array}\right]=\left[\begin{array}{llllllll}
i & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & i & 0 & 0 & 0 & 0 & 0 & 0 \\
c & c & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 \\
0 & i & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & c & c & 0 & 0 & 0 & 0
\end{array}\right]\left[\begin{array}{l}
u_{1}(t) \\
u_{2}(t) \\
x_{3}(t) \\
x_{4}(t) \\
x_{5}(t) \\
x_{3}(t-1) \\
x_{4}(t-1) \\
x_{5}(t-1)
\end{array}\right]
$$

For the defining matrix, $M$, the complexity of the matrix is defined identically as for the combinational defining matrix. The complexity of $M$ above is $\gamma=2+6=8$. The density is again defined as the number of nonzero elements divided by the total number of elements in the matrix. In general, for a sequential circuit, $d=\frac{\gamma}{(n+p)(n+2 p)}$.

In situations where lines fan out in a sequential circuit, the model can be extended as in the combinational case.

## Summary

The matrix representation for both combinational and sequential circuits contains the network interconnection information such as node adjacency, fanin, and fanout. The number of elements in the defining matrix of a system corresponds to the number of primary inputs plus the sum of all fanin (fanout) connections in the circuit, including primary outputs and feedback lines in sequential circuits.

CHAPTER V

## A MATRIX APPROACH TO AUTOMATIC TEST GENERATION

## Introduction

In this chapter, the matrix model of digital systems forms the framework in which the path sensitization approach of Roth is carried out. Behavioral and topological features of the model enable tests to be generated for several faults at once. When choices arise as to line assignments during path sensitization, the model contains enough information to make the assignments intelligently, thus reducing the requirement for backtracking. Self-initializing test sequences for sequential circuits can be generated and untestable faults flagged.

The application of the model in the context of automatic test generation using the Boolean difference method is also exhibited. An algorithm for deriving Boolean equations for each internal line in terms of primary inputs is presented. The Boolean difference of sums of complemented and uncomplemented variables is very straightforward. Because the matrix model represents lines in this manner, differences are quickly and easilycalculated when needed, thus saving the computer storage space once necessary for storing the differences.

## Path Sensitization Using the Matrix Model

The matrix model introduced in Chapters $1 \| 1$ and IV represents each internal line in terms of the sum (OR) of complemented and/or uncomplemented
variables. The variables may be either primary inputs or internal lines. The flow of behavioral information proceeds through the matrix model from inputs to outputs by data steps followed by computation steps. Line justification and error propagation for the Boolean OR operation is reviewed again at this point for reference. If $x_{4}=x_{2}+x_{3}^{\prime}$, then $x_{4}=1$ can be justified by the assignment $x_{2}=1$ or $x_{3}=0$. To justify $x_{4}=0$, the assignment $x_{2}=0$ and $x_{3}=1$ is required. To propagate the fault $x_{2}=D$ to line $x_{4}$ requires that $x_{3}^{\prime}=0\left(x_{3}=1\right)$. To propagate the fault $x_{3}=D$ to line $x_{4}\left(x_{4}=D^{\prime}\right)$, it is necessary that $x_{2}=0$.

In general, to justify a 1 , at least one uncomplemented summand must be 1 , or at least one complemented variable in the sum must be 0 . To justify a 0 , all uncomplemented summands must be 0 and all complemented summands, 1. To propagate an error signal (D or $D^{\prime}$ ), each uncomplemented variable in the sum must be 0 and each complemented variable, 1.

The path sensitization approach outlined in Chapter 11 involved first deciding on a fault and fault site. The fault-free value of the faulty variable is immediately justified at a primary input and the error signal is then propagated to a primary output. The last step involves the consistent justification of line values assigned during the justification and propagation steps.

The manner in which this procedure is carried out within the matrix model can best be understood by illustration. Examples showing the basic path sensitization method for combinational circuits, multiple path sensitization, the undetectable fault case, and self-initialization
procedures for sequential circuits are presented. A flow diagram generalizing the procedure follows the illustrations.

The combinational circuit of Figure 18 has matrix representation:

$$
\left[\begin{array}{l}
x_{1}  \tag{5.1}\\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5} \\
x_{6} \\
x_{7} \\
x_{8} \\
x_{9} \\
x_{10} \\
x_{1}
\end{array}\right]=\left[\begin{array}{ccccccccccc}
i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
c & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & c & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 \\
c & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & c & 0 & c & 0 & c & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & c & 0 & 0 & 0 & c & c & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & c & c & 0
\end{array}\right]\left[\begin{array}{l}
u_{1} \\
u_{2} \\
u_{3} \\
x_{4} \\
x_{5} \\
x_{6} \\
x_{7} \\
x_{8} \\
x_{9} \\
x_{10} \\
x_{11}
\end{array}\right]
$$

A test will first be generated for line $x_{4}$ stuck-at-0. As in the D-algorithm, the letter D will indicate the value of a line that is 1 in a fault-free circuit, but has taken the value 0 due to the presence of a fault ( $D=1 / 0$ ).

On the right-hand side of Equation (5.1), replace $x_{4}$ by the value D. This substitution is labeled as Step 1 in Equation (5.2).

Column 4 indicates that line $x_{4}$ connects to line $x_{9}$ and the error propagation rules indicate that each of the other nonnull variables in row $x_{9}$ must take the value 1 . These values $\left(x_{2}=u_{2}=1, x_{6}=1\right.$, and $x_{9}=D^{\prime}$ ) are entered in the right-hand vector and labeled Step 2.

The error signal has been propagated to line $x_{9}$. Column 9 indicates that line $x_{9}$ connects to primary output $x_{11}$ and the error propagation rules indicate that the nonnull variables, $x_{10}$, in row 11 , take the value 1. These values $\left(x_{11}=D\right.$ and $\left.x_{10}=1\right)$ are entered in the right-

hand vector and labeled Step 3. Due to the nature of the propagation procedure, the variables $x_{9}$ and $x_{11}$ will not require justification and can be removed from the list of variables to be justified.

The justification procedure now begins. The signal $x_{4}=1$ (the fault-free value on the faulty signal line) is justified if $x_{1}=0$ or $x_{2}=0$. Since $x_{2}=1$ has been previously assigned, we choose $x_{1}=0$. This assignment is labeled Step 4.

To ensure consistency, the implications of this assignment are made immediately. Column 1 indicates that $x_{1}$ connects to $x_{4}$ and $x_{8}$. Since $x_{1}=0$ and the entry in row 8 , column 1 is $c$, then $x_{8}$ must equal 1 . This implication is entered as Step 5. The implication assignment of $x_{8}=1$ implies that $x_{8}$ has been justified (since $x_{1}=0$ ) ; thus $x_{8}$ can be removed from the list of variables which need to be justified.

The justification procedure is continued by justifying $x_{6}=1$. The justification rules indicate that $x_{5}=1$ (Step 6).

The implication of this assignment is made by investigating column 5 which leads to $x_{7}=1$ (Step 7). $x_{7}$ can now be removed from the list of variables requiring justification. Only $x_{10}$ and $x_{5}$ remain to be justified.

The value $x_{10}=1$ is now justified. The rules indicate that either $x_{3}=0, x_{7}=0$, or $x_{8}=0$. Since $x_{7}=x_{8}=1$ has already been assigned, the zero value is given to $x_{3}$ (Step 8). Implications of the assignment $x_{3}=0$ indicate that $x_{5}=1, x_{8}=1$, and $x_{10}=1$. It is noted that $x_{8}=x_{10}$ $=1$ is consistent with previous assignments, and $x_{5}$ is removed from the list requiring justification.

The test derivation is complete. The test $T=\left(u_{1}, u_{2}, u_{3}\right)=\left(x_{1}\right.$, $\left.x_{2}, x_{3}\right)=(0,1,0)$ is a test for $x_{4}=D\left(i . e ., x_{4}\right.$ stuck-at-0). In
addition, it will detect the faults $x_{9}=D^{\prime}$ and $x_{11}=D$.
Column No. $=1234567891011$ T

In the above example, we were "lucky" because in instances where choices had to be made, the values could be uniquely determined (Steps 4 and 8). The next example illustrates the procedure when choices must be made.

Figure 19 is a small combinational circuit whose matrix representation is given by Equation (5.3) (see page 63).

Derive a test for $x_{9}$ stuck-at-0 (Step 1 in Equation [5.4]). Propagate the fault $x_{9}=D$. Column 9 indicates that $x_{9}$ connects to $x_{12}$ and the fault is propagated if $x_{8}=1$ (Step 2). Propagate $x_{12}=D^{\prime}$. Column 12 indicates that $x_{12}$ connects to the primary output variable $x_{13}$ and the fault is propagated if $x_{10}=1$ and $x_{11}=0$ (Step 3).

The justification procedure begins by justifying $x_{9}=1$. This is true if $x_{1}=0$ or $x_{6}=0$. Which should we choose? Column 1 indicates that $x_{1}$ fans out to line $x_{10}$ as well as $x_{9}$. Check to see if $x_{1}=0$ would interfere with the value already assigned to $x_{10}$. It does not; in fact, it will justify $x_{10}=1$. Therefore, the assignment $x_{1}=0$ is

$$
\left[\begin{array}{l}
x_{1}  \tag{5.3}\\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5} \\
x_{6} \\
x_{7} \\
x_{8} \\
x_{9} \\
x_{10} \\
x_{11} \\
x_{12} \\
x_{13}
\end{array}\right]=\left[\begin{array}{lllllllllllll}
i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & c & 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 \\
c & 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
c & 0 & c & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & c & c & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 & 0 & c & c & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & c & i & c & 0
\end{array}\right]\left[\begin{array}{l}
u_{1} \\
u_{2} \\
u_{3} \\
u_{4} \\
u_{5} \\
u_{6} \\
u_{7} \\
x_{8} \\
x_{9} \\
x_{10} \\
x_{11} \\
x_{12} \\
x_{13}
\end{array}\right]
$$



Figure 19. Combinational Circuit
made. It turns out in this case that the assignment $x_{6}=0$ is also valid because column 6 indicates that $x_{6}$ also connects to $x_{10}$ as well as $x_{g}$, and the same argument would hold for assigning it the value 0 . Once a value that "works" is found, however, the search is abandoned. Therefore, we assign the value $x_{1}=0$ (Step 4) with no fear of conflicts later.

Next justify $x_{8}=1$. A choice between $x_{2}=0$ or $x_{7}=0$ exists. Column 2 indicates that $x_{2}$ only fans out to $x_{8}$ and its assignment will not affect any other variable. Hence, we make the assignment $x_{2}=0$ (Step 5).

Next justify $x_{11}=0$. We have no choice here. We must assign $x_{3}$ $=x_{4}=x_{5}=1($ Step 6).

Since no other unjustified values remain, the test is complete.
The unassigned inputs, $u_{6}$ and $u_{7}$, are treated as "don't care" variables. The test $\left(u_{1}, u_{2}, u_{3}, u_{4}, u_{5}, u_{6}, u_{7}\right)=(0,0,1,1,1, x, x)$ detects the faults $x_{9}$ and $x_{13}$ stuck-at-0 and $x_{12}$ stuck-at-1.

$$
\begin{aligned}
& \text { Column No. }=12345678910111213 \mathrm{~T}
\end{aligned}
$$

Fanout paths that reconverge are referred to as reconvengent fanout paths. Schneider (1967) showed, through example, that some faults on a reconvergent fanout path cannot be detected by single path sensitization but can be detected through multiple path sensitization. Armstrong (1966) showed that multiple path sensitization can, in some cases, prohibit the effect of a fault from propagating beyond the point of reconvergence. One case, in particular, where this situation can occur is when some reconverging fanout paths between a specified node and a specified node of reconvergence have different inversion parity. Armstrong defines the inversion parity of a reconvergent fanout path to be the number of inversions, modulo 2, along the path between the specified fanout node and the specified node of reconvergence.

This presents a dilemma. If only single path sensitization is performed, some faults may remain undetected and a trial-and-error exhaustion of all single paths must be done before discovering the need for multiple path sensitization. If a procedure involving only multiple path sensitization is followed, some faults may be untestable because of reconvergent complemented fanout.

Several approaches have been taken with regard to this problem by path sensitization algorithms. The D-algorithm is capable of either single or multiple path sensitization. However, multiple path sensitization is extremely time-consuming when done by the D-algorithm. Breuer (1981) asserts that the need for multiple path sensitization does not occur often enough to warrant the time expenditure when generating tests for large systems. D-LASAR can detect some, but not all, faults for which multiple path sensitization is required. In most cases, no attempt is made to detect those faults not found by the standard algorithm.

The Boolean difference algorithm, in its most general form, can detect faults requiring multiple path sensitization and is not hindered by reconvergent complemented fanout. This is due to the fact that the general Boolean difference formula covers each single path (first-order terms) and all possible multiple paths (higher-order terms). To speed up the algorithm, the higher-order terms may be omitted.

In general, the approach to be adopted in this thesis is to follow the single path procedure in order to avoid the problem associated with reconvergent complemented fanout. One advantage lost due to the single path assumption is that more faults can be detected at once if multiple paths are sensitized. For reference, however, the following example illustrates how multiple path sensitization can be accomplished using the matrix formulation.

Figure 20 is Schneider's example (1967). The fault $x_{6}$ stuck-at-1 requires multiple path sensitization. The matrix formulation of Schneider's circuit is given in Equation (5.5).
$\left[\begin{array}{l}x_{1} \\ x_{2} \\ x_{3} \\ x_{4} \\ x_{5} \\ x_{6} \\ x_{7} \\ x_{8} \\ x_{9} \\ x_{10} \\ x_{11} \\ x_{12}\end{array}\right]=\left[\begin{array}{llllllllllll}i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ i & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & i & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & i & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & i & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ i & 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & i & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & i & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & c & c & c & c & 0\end{array}\right]\left[\begin{array}{l}u_{1} \\ u_{2} \\ u_{3} \\ u_{4} \\ x_{5} \\ x_{6} \\ x_{7} \\ x_{8} \\ x_{9} \\ x_{10} \\ x_{11} \\ x_{12}\end{array}\right]$


Figure 20. Schneider's Example (Schneider, 1967)

The column on the right of Equation (5.6) shows the steps involved in double path sensitization.

$$
\begin{align*}
\text { Column No. } & \left.=1 \begin{array}{llllllllllll}
x_{1} \\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5} \\
x_{6} \\
x_{7} \\
x_{8} \\
x_{9} \\
x_{10} \\
x_{1} \\
x_{12}
\end{array}\right]=\left[\begin{array}{llllllllllllll}
i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
i & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & i & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & i & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & i & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
i & 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & i & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & i & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 & 0 & c & c & c & c & 0
\end{array}\right]\left[\begin{array}{l}
0 \\
0 \\
0 \\
0 \\
0 \\
D^{\prime} \\
0 \\
1 \\
1 \\
(4) \\
(2) \\
(2) \\
1 \\
1 \\
(1) \\
1 \\
D^{\prime}
\end{array}\right]
\end{align*}
$$

Because of the way a circuit is designed, some faults may not be testable. This is the case when redundancy is built into the circuit. The single fault model is not appropriate in this case because the circuit redundancy masks single faults.

Figure 21 (a) illustrates a circuit containing an undetectable fault. The value 0 on line $x_{4}$ can never be observed at a primary output. This means that a test cannot be generated for the fault $x_{5}$ stuck-at-1. Some faults may not be detectable because it is not possible to justify the line to a particular value. Figure $21(b)$ illustrates this situation in a very simple circuit. The line $x_{5}$ can never be set to the value 1 and hence can never be tested for the stuck-at-0 condition. Both circuits are nonminimal constructs, and each possesses reconvergent complemented fanout.

(a) Circuit With Unobservable 0 on Line $x_{4}$

(b) Circuit With Unjustifiable 1 on Line $x_{5}$

Figure 21. Circuits With Undetectable Faults

A test generation algorithm can waste a lot of time trying to generate a test for an undectable fault. The test algorithm needs to be able to determine, within a reasonable length of time, whether a fault is undetectable. The path sensitization approach of Roth (1966), implemented either in the $D$-algorithm or $D-L A S A R$, can determine when a fault is undetectable. When the matrix model is used in conjunction with path sensitization, undetectable faults can be similarly identified.

The steps involved in determining that the fault $x_{4}=D^{\prime}$ in Figure 20 (a) is not detectable are shown in Equation (5.7). It is determined in Step 5 that the value $D^{\prime}$ on line $x_{4}$ cannot be justified in a consistent manner with the values specified in the propagation phase. The fault-free value $x_{4}=0$ can never be achieved as long as $x_{3}=0$. If one attempts to propagate the error $x_{4}=D^{\prime}$ along the path through $x_{6}$ to $x_{8}$, the value of $x_{7}$ cannot be justified. Double path sensitization also fails because $x_{7}$ cannot be justified consistent with the assignments made during the propagation phase and during the justification of the fault-free value $x_{4}=0$.

$$
\text { Column No. }=12345678 \mathrm{~T} \text { Step }
$$

$$
\left[\begin{array}{l}
x_{1}  \tag{4}\\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5} \\
x_{6} \\
x_{7} \\
x_{8}
\end{array}\right]=\left[\begin{array}{llllllll}
i & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & i & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & i & 0 & 0 & 0 & 0 & 0 \\
0 & c & c & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & c & 0 & 0 & 0 & 0 \\
0 & c & 0 & c & 0 & 0 & 0 & 0 \\
0 & 0 & i & 0 & i & 0 & 0 & 0 \\
c & 0 & 0 & 0 & 0 & c & i & 0
\end{array}\right]\left[\begin{array}{l}
1 \\
0 \\
0 \\
0 \\
0 \\
1 \\
0
\end{array}\right]
$$

The iterative combinational model of sequential circuits formulated in matrix form provides a convenient tool for test generation using the
path sensitization approach. To illustrate the self-initialization procedure, a test will be generated for $x_{4}(t)$ stuck-at-0 in the circuit pictured in Figure 22.

The matrix formulation for the clocked $S-R$ flip-flop is given by Equation (5.8).

$$
\left[\begin{array}{l}
x_{1}(t)  \tag{5.8}\\
x_{2}(t) \\
x_{3}(t) \\
x_{4}(t) \\
x_{5}(t) \\
x_{6}(t) \\
x_{7}(t)
\end{array}\right]=\left[\begin{array}{lllllllll}
i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 \\
c & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & c & c & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & c & 0 & 0 & 0 & 0 & c \\
0 & 0 & 0 & 0 & c & 0 & 0 & c & 0
\end{array}\right]\left[\begin{array}{l}
S(t) \\
R(t) \\
C L K(t) \\
x_{4}(t) \\
x_{5}(t) \\
x_{6}(t) \\
x_{7}(t) \\
x_{6}(t-1) \\
x_{7}(t-1)
\end{array}\right]
$$

Test generation begins by assigning $x_{4}(t)=$. See Equation (5.9). Inspection of column 4 indicates that the fault can be propagated to primary output $x_{6}(t)$ if $x_{7}(t-1)=1$ (Step 2 ). To justify a $D$ value on line $x_{4}(t)$ requires either $x_{1}(t)=0$ or $x_{3}(t)=0$. Since $x_{1}(t)$ does not fanout, it is assigned the zero value (Step 3).

The value $x_{7}(t-1)$ is shifted into the $x_{7}$ position of the time $t-1$ vector (Step 4) and the $D$ value on $x_{4}(t-1)$ justified. Justification of $x_{7}(t-1)=1$ is performed in Step 5 by assigning $x_{5}(t-1)=0$. The value on $x_{5}(t-1)$ is justified in Step 6 by assigning $x_{2}(t-1)=x_{3}(t-1)=1$. The test sequence is complete. It is ( $0,1,1$ ) followed by $(0, x, x)$.

The flow diagram in Figure 23 indicates the general procedure for combinational circuit test generation using the matrix model. The vector $T$ in the flowchart corresponds to the vector on the right-hand side of the matrix equation $X=M[U X]^{\top}$. It is initially in an unknown state


$$
\begin{aligned}
& \text { Column No. }=123456 \text { 7-6-7 } T(t) \text { Step } T(t-1) \text { Step }
\end{aligned}
$$

> (3)
> (4)
> (6)
> (6)
> (1)
> (5.9)
> (5)
> (4)


Figure 23. Flow Diagram for Combinational Circuit Test Generation Using Single Path Sensitization and the Acken Matrix Model
with each entry denoted as $t_{k}=5$. When justifying $t_{k}\left(t_{k} \neq D\left(D^{\prime}\right)\right.$ or $t_{k} \neq 5$ ), choices may exist and should be handled in the manner described for the circuit of Figure 19.

## Boolean Difference Using the Matrix Model

The Boolean difference approach to ATG is essentially an equation manipulation procedure which can, in its most general form, generate all possible tests for stuck-at faults. An algorithm which uses the Boolean difference as a means to generate complete test sets for combinational logic circuits has been set forth by Yau and Tang (1971). This algorithm will be used to illustrate the ways in which the matrix formulation can be used in conjunction with Boolean difference.

Stated briefly, the steps of the algorithm include:

1. Number all lines and write the Boolean equation for each line $x_{j}$ and its complement $x_{j}^{\prime}$ in terms of the primary input variables. List them in Table A.
2. Find the Boolean difference of the logic function $f$, realized by the logic circuit, with respect to each fanout line using the definition of Boolean difference, i.e., compute $d f / d x_{j}=f\left(x_{1}, \ldots, x_{j-1}, 0\right.$, $\left.x_{j+1}, \ldots, x_{n}\right) \oplus f\left(x_{1}, \ldots, x_{j-1}, 1, x_{j+1}, \ldots, x_{n}\right)$, where $j$ ranges over all fanout lines.
3. Find the Boolean differences $d f / d x_{j}$, where $j$ starts from the largest line number (a primary output) to the smallest line number that is not a fanout line. List them in Table $B$.
4. From Tables $A$ and $B$, express $x_{j}\left(d f / d x_{j}\right)$ and $x_{j}^{\prime}\left(d f / d x_{j}\right), j=1$, $2, . . ., n$, in terms of the primary input variables. The set of terms
of $x_{j}\left(d f / d x_{j}\right)$ and $x_{j}^{\prime}\left(d f / d x_{j}\right)$ represent the complete test set of the single permanent stuck-at faults on line $j$.

The matrix formulation is particularly convenient in Steps 1 and 3. Step 1 in the Yau and Tang algorithm calls for numbering the lines and writing the logic equation for every line in terms of primary inputs. The following algorithm can be used to generate these equations using the matrix model.

First, partition the matrix $M$ as in Equation (5.10) and remove the data steps. See Equation (5.11).

$$
\begin{align*}
& {\left[\begin{array}{l}
x_{n} \\
x_{r}
\end{array}\right]=\left[\begin{array}{ll}
1 & 0 \\
A_{1} & A_{2}
\end{array}\right]\left[\begin{array}{l}
U \\
X_{r}
\end{array}\right]}  \tag{5.10}\\
& x_{r}=\left[\begin{array}{ll}
A_{1} & A_{2}
\end{array}\right]\left[\begin{array}{l}
U \\
X_{r}
\end{array}\right] \tag{5.11}
\end{align*}
$$

When expanded, Equation (5.11) can be written

$$
\begin{equation*}
X_{r}=A_{1} U+A_{2} X_{r} . \tag{5.12}
\end{equation*}
$$

The $A_{2}$ matrix is lower triangular because of the line numbering convention. The entries in the matrices $A_{1}$ and $A_{2}$ are Boolean functions of one variable from the set $C=\{0, i, c, u\}$.

The algorithm to generate the logic equations for the lines $x_{j}$ in the logic circuit, in terms of the primary inputs, proceeds as follows:

Step 1. Write the matrix equation leaving out the data steps as in Equation (5.12). Expand the right-hand side into a vector.

Step 2. Operate on the vector generated in Step 1, by $A_{2}$.
Step 3. Add the vector $A_{1} U$.

Step 4. Check to see if any entry in the vector generated by Step 3 contains any x-variables.

Yes--go to Step 2.
No--Stop.
This algorithm will be illustrated for the example of Figure 24 taken from Yau and Tang. The complete matrix equation is given in Equation (5.13).

$$
\left[\begin{array}{l}
x_{1}  \tag{5.13}\\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5} \\
x_{6} \\
x_{7} \\
x_{8} \\
x_{9} \\
x_{10} \\
x_{11} \\
x_{12} \\
x_{13} \\
x_{14} \\
x_{15} \\
x_{16}
\end{array}\right]=\left[\begin{array}{llllllllllllllll}
i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
c & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & c & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & c & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 & c & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & c & 0 & 0 & i & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & c & c & c & 0
\end{array}\right]\left[\begin{array}{l}
u_{1} \\
u_{2} \\
u_{3} \\
u_{4} \\
u_{5} \\
u_{6} \\
x_{7} \\
x_{8} \\
x_{9} \\
x_{10} \\
x_{11} \\
x_{12} \\
x_{13} \\
x_{14} \\
x_{15} \\
x_{16}
\end{array}\right]
$$

The reduced equation is given by Equation (5.14).

$\left[\begin{array}{l}x_{7} \\ x_{8} \\ x_{9} \\ x_{10} \\ x_{1} \\ x_{12} \\ x_{13} \\ x_{14} \\ x_{15} \\ x_{16}\end{array}\right]=\left[\begin{array}{llllll}c & c & 0 & 0 & 0 & 0 \\ 0 & 0 & c & c & 0 & 0 \\ 0 & 0 & 0 & 0 & c & c \\ 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0\end{array}\right]\left[\begin{array}{l}u_{1} \\ u_{2} \\ u_{3} \\ u_{4} \\ u_{5} \\ u_{6}\end{array}\right]+\left[\begin{array}{ccccccccc}0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ c & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 \\ 0 \\ 0 & 0 & c & 0 & 0 & i & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & c & c & c \\ 0\end{array}\right]\left[\begin{array}{l}x_{7} \\ x_{8} \\ x_{9} \\ x_{10} \\ x_{11} \\ x_{12} \\ x_{13} \\ x_{14} \\ x_{15} \\ x_{16}\end{array}\right]$

Computing the right-hand side of Equation (5.14) and writing the result in vector notation, we obtain

$$
x_{r}=\left[\begin{array}{l}
x_{7}  \tag{5.15}\\
x_{8} \\
x_{9} \\
x_{10} \\
x_{11} \\
x_{12} \\
x_{13} \\
x_{14} \\
x_{15} \\
x_{16}
\end{array}\right]=\left[\begin{array}{l}
c u_{1}+c u_{2} \\
c u_{3}+c u_{4} \\
c u_{5}+c u_{6} \\
c x_{8} \\
c x_{8} \\
c x_{8} \\
c x_{7}+x_{10} \\
c x_{11} \\
c x_{9}+x_{12} \\
c x_{13}+c x_{14}+c x_{15}
\end{array}\right]=\left[\begin{array}{l}
u_{1}^{\prime}+u_{2}^{\prime} \\
u_{3}^{\prime}+u_{4}^{\prime} \\
u_{5}^{\prime}+u_{6}^{\prime} \\
x_{8}^{\prime} \\
x_{8}^{\prime} \\
x_{8}^{\prime} \\
x_{7}^{\prime}+x_{10} \\
x_{11}^{\prime} \\
x_{9}^{\prime}+x_{12} \\
x_{13}^{\prime}+x_{14}^{\prime}+x_{15}^{\prime}
\end{array}\right]
$$

Operating by $A_{2}$ on the left of $X_{r}$, we obtain

$$
\left[\begin{array}{llllllllll}
0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0  \tag{5.16}\\
0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0
\end{array}\right)
$$

Add $A_{1} U$.

$$
\left[\begin{array}{l}
u_{1}^{\prime}+u_{2}^{\prime}  \tag{5.17}\\
u_{3}^{\prime}+u_{4}^{\prime} \\
u_{5}^{\prime}+u_{6}^{\prime} \\
0 \\
0 \\
0 \\
0 \\
0 \\
0 \\
0 \\
u_{3} u_{4} \\
u_{3} u_{4} \\
u_{3} u_{4} \\
u_{1} u_{2}+x_{8}^{\prime} \\
x_{8} \\
u_{5} u_{6}+x_{8}^{\prime} \\
x_{7} x_{10}^{\prime}+x_{11}+x_{9} x_{12}^{\prime}
\end{array}\right]\left[\begin{array}{l}
0 \\
u_{1}^{\prime}+u_{2}^{\prime} \\
u_{3}^{\prime}+u_{4}^{\prime} \\
u_{5}^{\prime}+u_{6}^{\prime} \\
u_{3} u_{4} \\
u_{3} u_{4} \\
u_{3} u_{4} \\
u_{1} u_{2}+x_{8}^{\prime} \\
x_{8} \\
u_{5} u_{6}+x_{8}^{\prime} \\
x_{7} x_{10}^{\prime}+x_{11}+x_{12}^{\prime}
\end{array}\right]
$$

Since $x_{j}$ appears on the right-hand side of Equation (5.17), another iteration is necessary. At the end of Step 3 in the third iteration, we obtain the vector

$$
\left[\begin{array}{l}
x_{7}  \tag{5.18}\\
x_{8} \\
x_{9} \\
x_{10} \\
x_{11} \\
x_{12} \\
x_{13} \\
x_{14} \\
x_{15} \\
x_{16}
\end{array}\right]=\left[\begin{array}{l}
u_{1}^{\prime}+u_{2}^{\prime} \\
u_{3}^{\prime}+u_{4}^{\prime} \\
u_{5}^{\prime}+u_{6}^{\prime} \\
u_{3} u_{4} \\
u_{3} u_{4} \\
u_{3} u_{4} \\
u_{1} u_{2}+u_{3} u_{4} \\
u_{3}^{\prime}+u_{4}^{\prime} \\
u_{5} u_{6}+u_{3} u_{4} \\
\left(u_{1}^{\prime}+u_{2}^{\prime}\right)\left(u_{3}^{\prime}+u_{4}^{\prime}\right)+u_{3} u_{4}+\left(u_{5}^{\prime}+u_{6}^{\prime}\right)\left(u_{3}^{\prime}+u_{4}^{\prime}\right)
\end{array}\right]
$$

which contains only primary input variables. This vector contains the Boolean equation for each internal line in terms of primary inputs.

In Step 3 of the Yau and Tang algorithm, the Boolean differences $d f / d x$ j must be computed. The index $j$ progresses from the largest line number to the smallest line number that is not a fanout line. These differences are easily calculated using the matrix model and the following lemmas.

Lemma 1 (Sellers, Hsiao, and Bearnson, 1968):

$$
\frac{d f}{d x_{i}}=\frac{d f}{d x_{i}^{!}}
$$

Lemma 2 (Chaing, Reed, and Banes, 1972): If

$$
f\left(x_{1}, x_{2}, \ldots, x_{n}\right)=x_{1}+x_{2}+\ldots+x_{n},
$$

then

$$
\frac{d f}{d x_{i}}=x_{1}^{\prime} \cdot x_{2}^{\prime} \cdots x_{i-1}^{\prime} \cdot x_{i+1}^{\prime} \cdots x_{n}^{\prime} \cdot
$$

If

$$
f\left(x_{1}, x_{2}, \ldots, x_{n}\right)=x_{1} x_{2} \cdots x_{n},
$$

then

$$
\frac{d f}{d x_{i}}=x_{1} \cdot x_{2} \cdots x_{i-1} \cdot x_{i+1} \cdots x_{n} .
$$

Since the matrix model expresses each line in terms of the sum of 'preceding" lines, Lemma 2 can be directly applied. For reference, the matrix equation for the circuit of Figure 24 is repeated. The data steps are again removed.
$\left[\begin{array}{l}x_{7} \\ x_{8} \\ x_{9} \\ x_{10} \\ x_{11} \\ x_{12} \\ x_{13} \\ x_{14} \\ x_{15} \\ x_{16}\end{array}\right]=\left[\begin{array}{lllllllllllllll}c & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & c & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & c & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & c & 0 & 0 & i & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & c & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & c & 0 & 0 & i & 0 & 0 & 0\end{array}\right]\left[\begin{array}{l}u_{1} \\ 0\end{array} 0\right.$

Beginning with $j=16$, we see from the matrix that $x_{16}=x_{13}^{1}+x_{14}^{1}$ $+x_{15}^{\prime}$. It follows from Lemmas 1 and 2 that

$$
\begin{aligned}
& \frac{d f}{d x_{16}}=\frac{d x_{16}^{1}}{d x_{16}}=1 \\
& \frac{d f}{d x_{15}}=\frac{d x_{16}^{\prime}}{d x_{15}}=x_{13} x_{14} \\
& \frac{d f}{d x_{14}}=\frac{d x_{16}^{1}}{d x_{14}}=x_{13} x_{15} \\
& \frac{d f}{d x_{13}}=\frac{d x_{16}^{1}}{d x_{13}}=x_{14} x_{15}
\end{aligned}
$$

By inspection of the matrix in Equation (13a), we have

$$
\begin{aligned}
& \frac{d x_{15}}{d x_{12}}=x_{9} \\
& \frac{d x_{15}}{d x_{9}}=x_{12}^{\prime}
\end{aligned}
$$

There is no need to compute these differences and store them in tabular form as the Yau and Tang algorithm suggest since they can be computed by inspection of the matrix.

Summary

In this chapter, the matrix model for digital systems forms the framework through which a path sensitization algorithm is carried out. Using this technique and structure, tests for single permanent stuck-at faults are generated for both combinational and sequential circuits. The model contains both behavioral and topological information which
enables error propagation and line value justification to be performed in a concise methodical manner.

An algorithm based upon the matrix model is introduced for deriving the Boolean equation of each internal line in terms of primary inputs. Boolean differences of the function with respect to each line can be computed directly by inspection of the defining matrix.

CONCLUSIONS AND RECOMMENDATIONS

## Conclusions

A mathematical model of digital systems formulated for use by automatic test generation algorithms has been described in this thesis. The general formulation and capabilities of the model are exhibited through nume rous examples.

Gate level automatic test generation algorithms can benefit from two types of circuit information, behavioral and topological. The matrix model relates the behavioral information through the data and computation steps of a k-step chain. The steps are written in a linearlooking form by using the basis functions $O R$ and NOT. Gate level circuit diagrams are transformed into this basis by using only NAND, OR, and NOT gates. The resulting matrix equation, in addition to containing behavioral information, contains the same topological information held in the adjacency matrix of the logic gate-level circuit diagram. The correlation of the topological information to the gate level logic diagram is valuable in the path sensitization approach because it contains information about the various paths from inputs to outputs. Fanin (fanout) information is also available for each gate.

The number of nonnull elements in the defining matrix of the model is equal to the number of primary inputs plus the sum of all fanin (fanout) connections in the logic circuit description. The linear storage
complexity of the model indicates the probable ease of extension to the modeling of very large circuits.

Examples were given which illustrate the use of the matrix model as a structure in which the path sensitization approach to automatic test generation and the Boolean difference approach can be carried out.

The concise matrix formulation of digital systems will offer considerable potential for use in a variety of digital systems analysis problems. Several topics for further research will be discussed in the next section.

## Recommendations for Further Research

Within the analytical framework established by this thesis, several additional areas of research arise for the application of the matrix model to digital systems analysis. The problems are, for the most part, associated with the efficient utilization of the topological information contained in the defining matrix to address problems associated with automatic test generation.

The ATG algorithms based upon the approaches of Roth (1966) and Sellers, Hsiao, and Bearnson (1968) utilize the topological information of the matrix model implicitly in test generation. Explicit utilization of this information to determine in advance which faults will require multiple path sensitization or to locate paths which contain reconvergent complemented fanout could increase the computation time efficiency of the algorithms in generating tests for all possible stuck-type faults.

One possible approach to identifying paths through a network having particular properties is to determine the pattern of a submatrix with the desired property. Next, introduce various row and column interchange
operations on the defining matrix which will result in forming the pattern in a submatrix when such a pattern exists.

Consider a circuit which realizes the function $f_{\alpha}$ in the presence of a given fault $\alpha$, and the function $f$ in the fault-free instance. If $f_{\alpha} \oplus f=0$, then the fault $\alpha$ is said to be undetectable and the circuit is said to be redundant with respect to the fault $\alpha$. When a circuit is known to be redundant with respect to a stuck-type fault, certain circuit simplification rules can be applied to condition the circuit for automatic test generation (see Breuer and Friedman, 1976). In general, there is no simple way to determine when redundancy in combinational circuits exist other than proving that no test exists for some fault or faults. The method of proof is to try to generate a test and ultimately show that none exists. A great amount of computation may be required for this method. It is desirable to determine the redundancy prior to test generation.

The circuit in Figure 25 illustrates an extremely simple redundant circuit. The matrix equations for this circuit are

$$
\begin{aligned}
& {\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5}
\end{array}\right]=\left[\begin{array}{lllll}
0 & 0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 & 0 \\
c & c & 0 & 0 & 0 \\
c & c & 0 & 0 & 0 \\
0 & 0 & i & i & 0
\end{array}\right]\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5}
\end{array}\right]+\left[\begin{array}{ll}
i & 0 \\
0 & i \\
0 & 0 \\
0 & 0 \\
0 & 0
\end{array}\right]\left[\begin{array}{l}
u_{1} \\
u_{2}
\end{array}\right]} \\
& {[y]=\left[\begin{array}{lllll}
0 & 0 & 0 & 0 & i
\end{array}\right] .}
\end{aligned}
$$

Note that rows 3 and 4 in the $A$-matrix are identical, indicating a redundancy. The redundancy can be eliminated from the circuit by deleting the row and column associated with $x_{3}$ (or $x_{4}$ ). The resulting matrix equations are


$$
\begin{aligned}
& {\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{4} \\
x_{5}
\end{array}\right]=\left[\begin{array}{llll}
0 & 0 & 0 & 0 \\
0 & 0 & 0 & 0 \\
c & c & 0 & 0 \\
0 & 0 & i & 0
\end{array}\right]\left[\begin{array}{l}
x_{1} \\
x_{2} \\
x_{4} \\
x_{5}
\end{array}\right]+\left[\begin{array}{ll}
i & 0 \\
0 & i \\
0 & 0 \\
0 & 0
\end{array}\right]\left[\begin{array}{l}
u_{1} \\
u_{2}
\end{array}\right]} \\
& {[y]=\left[\begin{array}{llll}
0 & 0 & 0 & i
\end{array}\right] .}
\end{aligned}
$$

Not all redundancies are this obvious, but this simple example seems to indicate that certain row and column operations could be defined which transform the A-matrix into one containing two or more identical rows (columns), thus indicating redundancies.

The third area in which the matrix model for digital systems has potential application is that of testability analysis. Testability analysis deals with the determination of measures which describe how easily the DUT can be tested. The measures can describe either the intrinsic or extrinsic testability of the device. Intrinsic testability measures consider the circuit behavior and topology alone and do not depend upon stimulus/response considerations. They are computed during the early design phase to provide an indication of how difficultit will be to generate test vectors either manually or automatically. Extrinsic testability measures are associated with a particular test. After the test has been generated, either manually or automatically, it is graded to determine the percent of faults detected and/or located. This percentage is the extrinsic testability measure and is generally computed by a fault simulator which generates statistics. Extrinsic testability measures can also be computed during the design phase

Goldstein (1979) defined some intrinsic testability measures of controllability and observability. The controllability of a combinational node (e.g., AND, OR, NOR, NAND gates or primary input nodes) is
a measure of the minimum number of combinational node assignments in the circuit required to justify a zero or a one value on the node. The observability measure of a combinational node is related to both the distance between the node and a primary output and the difficulty of propagating the logical value on the node to a primary output. Sequential observability/controllability measures are similarly defined.

As in ATG, these intrinsic testability measures depend, to some extent, upon knowledge of the behavior of individual gates in the circuit and upon the interconnection of those gates (circuit topology). Since the matrix model contains this information in a concise formulation, it can perhaps be used as a structure for testability analysis. The specifics of the utilization of the model would depend upon the particular testability analysis procedure.

One way, in particular, that the model could be utilized in computing the observability measure is in the computation of the distance between a node and a primary output. The entries in the matrix, $A$, for combinational circuits correspond to the entries in the transposed adjacency matrix of the associated logic diagram. Hence, an entry $a_{i j}$ in the matrix $\left(A^{\top}\right)^{r}\left(A^{\top}\right.$ multiplied by itself r-times) is related to the number of different paths of length $r$ between the $i$ th and $j$ th nodes (Deo, 1974).

## A SELECTED BIBLIOGRAPHY

Abramovici, Miron. "Fault Diagnosis in Digital Circuits Based on EffectCause Analysis." (Unpub. Ph.D. dissertation, University of Southern California Electronic Sciences Laboratory, 1980.)

Agarwal, V. K., and G. M. Masson. "Recursive Coverage Projection of Test Sets." IEEE Trans. on Computers, C-28, 11 (1979), 865-870.

Akers, S. B. "On the Theory of Boolean Functions." SIAM J. of Applied Mathematics, 7 (1959), 487-498.

Akers, S. B. "A Logic System for Fault Test Generation." IEEE Trans. on Computers, $\mathbf{C - 2 5 , 6}$ (1976), 620-630.

Armstrong, D. B. "On Finding a Nearly Minimal Set of Fault Detection Tests for Combinational Logic Nets." IEEE Transactions on Computers (1966), 66-73.

Batni, Ramachendra P., and C. R. Kime. "A Module-Level Testing Approach for Combinational Networks." LEEE Trans. On Computers, C-25, 6 (1976), 594-604.

Bearnson, L. W. "Arithmetic Error Detection in Digital Computers." (Unpub. M.S. thesis, Syracuse University, 1965.)

Bearnson, L. W., and C. C. Carroll. "On the Design of Minimum Length Fault Tests for Combinational Circuits." IEEE Trans. on Computers, 20 (1971), 1353-1356.

Bennetts, R. G., D. C. Brittle, A. C. Prior, and J. L. Washington. "A Modular Approach to Test Sequence Generation for Large Digital Networks." Digital Processes, 1 (1975), 3-24.

Bennetts, R. G. "Algebraic Models for Clocked Flip-Flops." Electronic Engineering (1978), 60-62.

Bouricius, W. G., E. P. Hsieh, G. R. Ptuzolu, J. P. Roth, P. R. Schneider, and C. J. Tan. "Algorithms for Detection of Faults in Logic Circuits." IEEE Trans. on Computers, $C-20,11$ (1977), 1258-1264.

Breuer, M. A. "A Random and an Algorithmic Technique for Fault Detection Test Generation for Sequential Circuits." IEEE Trans. on Computers (1971), 1364-1370.

Breuer, M. A. "Testing for Intermittent Faults in Digital Circuits." IEEE Trans. on Computers, C-22, 3 (1973), 241-246.

Breuer, Melvin A. "Modeling Circuits for Test Generation." Digest of Papers. International Symposium on Fault Tolerant Computing, 1974, $\overline{3 / 13-3 / 18}$.

Breuer, Melvin A. "The Effects of Races, Delays, and Delay Faults on Test Generation." IEEE Trans. on Computers, C-23, 10 (1974), 10781092.

Breuer, Melvin A., and R. L. Harrison. "Procedures for Eliminating Static and Dynamic Hazards in Test Generation." IEEE Trans. on Computers, C-23, 19 (1974), 1069-1078.

Breuer, M. A., and A. D. Friedman. Diagnosis and Reliable Design of Digital Systems. New York: Computer Science Press, Inc., 1976.

Breuer, M. A., and A. D. Friedman. "Functional Level Primitives in Test Generation." IEEE Trans. on Computers, C-29, 3 (1980), 223-235.

Breuer, M. A. "Test Generation." (Presentation at Aerospace Symposium on Testing and Verification of Large Scale Integrated Circuits, Los Angeles, California, June, 1981.)

Brittle, D. C. "Notation Describing the Fault-Related Behavior of Logic Modules." Electronics Letters, 10-7 (1974), 215-216.

Brittle, David Charles. "Test Sequence Generation for Large Sequential Networks." (Unpub. Ph.D. dissertation, University of Southampton, England, 1976.)

Carroll, B. D., H. G. Shah, and D. M. Jones. "An Examination of Algebraic Test Generation Methods for Multiple Faults." IEEE Trans. on Computers, 23 (1974), 743-745.

Chappell, Stephen Gilbert. "Automatic Test Generation for Asynchronous Digital Circuits." Microfilm copy. (Unpub. Ph.D. dissertation, Library, Northwestern University, 1973.)

Chiang, A. C., I. S. Reed, and A. V. Banes. "Path Sensitization, Partial Boolean Difference, and Automated Fault Diagnosis." IEEE Trans. on Computers, C-21 (1972), 189-194.

Chiang, A. C. L., and Rick McCaskill. "Two New Approaches Simplify Testing of Microprocessors." Electronics, 49-2 (1976), 100-105.

Clegg, F. W. "Use of SPOOFs for Faulty Logic Network Analysis." IEEE International Symposium on Fault. Tolerant Computing (1972), 143147.

Deo, M. Graph Theory With Applications to Engineering and Computer Science. Englewood Cliffs, N.J.: Prentice-Hall, Inc., 1974.

Eichelberger, E. B., and T. W. Williams. "A Logic Design Structure for LSI Testability." Proc. 14th DAC, 1977.

Eldred, Richard D. "Test Routines Based on Symbolic Logic Statements." JACM, 6-1 (1959), 33-36.

Friedman, A. D., and P. R. Menon. Fault Detection in Digital Circuits. Englewood Cliffs, N.J.: Prentice-Hall, Inc., 1971.

Fujiwara, H., and K. Kinoshita. "On the Computational Complexity of System Diagnosis." IEEE Trans. on Computers, C-27, 10 (1978), 881885.

Galiay, J., Y. Crouzet, and M. Vergniault. "Physical Versus Logical Fault Models in MOS LSI Circuits, Impact on Their Testability." Digest of Papers. International Symposium on Fault Tolerant Computing, 1979, 195-202.

Goldstein, Lawrence H. Computational Complexity/Confidence Level Tradeoffs in LSI Testing. Report No. SAND77-2068. Albuquerque, N.M.: Sandia National Laboratories, 1978.

Goldstein, L. H. "Controllability/Observability Analysis of Digital Circuits." IEEE Trans. Circuits \& Systems, CAS-26, 9 (1979), 685693.

Harper, L. H., W. N. Hsieh, and J. E. Savage. "A Class of Boolean Functions With Linear Combinational Complexity." Theor. Comp. Science, 1-2 (1975), 161-183.

Hayes, J. P. "The Fanout Structure of Switching Functions." J. Assoc. Comput. Mach., 22 (1975), 551-571.

Hayes, John P. "Path Complexity of Logic Networks." IEEE Trans. on Computers, $\mathrm{C}-27,5$ (1978), 459-462.

Hsiao, M. Y., F. F. Sellers, and D. K. Chia. 'Fundamentals of Boolean Difference for Test Pattern Generation." Proc. 4th Annual Princeton Conference on Information Sciences and Systems, 1970, 50-54.

Hsiao, M. Y., and D. K. Chia. "Boolean Difference for Fault Detection in Asynchronous Sequential Machines." IEEE Trans. on Computers, C-21 (1971), 1356-1361.

Hsieh, E. P., R. A. Rasmussen, L. J. Vidunas, and W. T. Davis. "Delay Test Generation." Proc. 14th Design Automation Conference, 1977, 486-491.

Ibarra, O. H., and S. K. Sahni. "Polynomially Complete Fault Detection Problems." IEEE Trans. on Computers, c-24, 3 (1975), 242-249.

Kodandapani, K. L, and S. C. Seth. "On Combinational Networks With Restricted Fan-Out." IEEE Trans. on Computers, C-27, 4 (1978), 309138.

Kovijanic, P. G. "Testability Analysis." Proc. IEEE 1979 Semiconductor Test Conference, 1979, 310-316.

Ku, Chia-Tai, and G. M. Masson. "The Boolean Difference and MultipleFault Analysis." IEEE Trans. on Computers, C-24, 7 (1975), 691695.

Kuhl, J. G., and S. M. Reddy. "On the Detection of Terminal Stuck Faults." IEEE Trans. on Computers, C-27, 5 (1978), 467-469.

Latino, Carl D., and J. G. Bredeson. "The Cell Method--A New Approach to Multiple Stuck-at-Fault Test Generation." International Journal of Electronics, 46-5 (1979), 465-482.

Lofti, Z. M., and A. J. Tosser. "Inhibited Expressions of Boolean Differences." International Journal of Electronics, 43-1 (1980), 5764.

MacDonald, F "LSI Changes Basic Test Rules and Strategies." Electronics Test (1978), 59-60.

Mano, M. M. Computer System Architecture. Englewood Cliffs, N.J. Prentice-Hall, Inc., 1976.

Marinos, P. N. "Derivation of Minimal Complete Sets of Test-Input Sequences Using Boolean Differences." LEEE Trans. on Computers, C-20 (1971), 25-32.

Muehldorf, E. I. "Designing LSI Logic for Testability." Digest of Papers. Semiconductor Test Symposium, 1976, 45-49.

Muth, Peter. "A Nine-Valued Circuit Model for Test Generation." IEEE Trans. on Computers, C-25, 6 (1976), 630-636.

Nanda, N. L., and R. G. Bennetts. "Reconvergence Phenomenon in Synchronous Sequential Circuits." Electronics Letters, 16-8 (1980), 303304.

Pomeroy, Bruce A. "Automatic Stimulus Generation for Digital Testing." Wescon Tech. Papers, W. Elect. Show \& Conv., 19 (1975), 1-6.

Powell, Theodore J. A Module Diagnostic Procedure for Combinational Logic. Final Report AD688-743. Urbana: lllinois Univ. Urbana Coordinated Sci. Lab., 1969.

Prior, A. C., and R. G. Bennetts. "Application of the Boolean-Difference Technique to Sequential Logic." Electronics Letters, 10, 23 (1974), 486-488.

Rai, Suresh, and K. K. Aggarwal. "An Efficient Method for Reliability Evaluation of a General Network." IEEE Trans. Reliability, R-27, 3 (1978), 206-211.

Ramanoorthy, C. V., and W. Mayeda. "Computer Diagnosis Using the Blocking Gate Approach." IEEE Trans. on Computers, C-20 (1971), 12941300.

Reed, I. S. "Boolean Difference Calculus and Fault Finding." SIAM Journal of Applied Math., 24 (1973), 134-143.

Roth, J. Paul. "Diagnosis of Automata Failures: A Calculus and a Method." IBM Journal of Research \& Development, 10 (1966), 278281.

Savage, John E. The Complexity of Computing. New York: John Wiley $\varepsilon$ Sons, 1976.

Savir, J. "Syndrome-Testable Design of Combinational Circuits." IEEE Trans. on Computers, $C-29,6$ (1980), 442-451.

Schneider, R. R. "On the Necessity to Examine D-Chains in Diagnostic Test Generation." IBM Journal of Research \& Development, 11 (1967), 114.

Sellers, F. F., M. Y. Hsiao, and C. L. Bearnson. "Analyzing Errors With the Boolean Difference." LEEE Trans. on Computers, C-17 (1968), 676-683.

Si, S. C. "Dynamic Testing of Redundant Logic Networks." IEEE Trans. on Computers, $\mathrm{C}-27,9$ (1978), 828-832.

Snethen, Thomas J. "Simulator-Oriented Fault Test Generator." 14th Design Automation Conference Proc., New Orleans, LA. (1977), 88-93.

Suresh, R., and K. K. Aggarwal. "A Computer Method for Fault Detection in Combinational Circuits." Int. J. Electronics, 47-3 (1979), 247251.

Thayse, A., and Marc Davio. "Boolean Differential Calculus and Its Application to Switching Theory." IEEE Trans. on Computers, C-22, 4 (1973), 409-420.

Thomas, J. J. "Automated Diagnostic Test Programs for Digital Networks." Computer Design (1971), 63-67,

Williams, T. W.. and K. P. Parker. "Testing Logic Networks and Designing for Testability." Computer (1979), 9-21.

Wolfgang, J. Paul. "A 2.5N-Lower Bound on the Combinational Complexity of Boolean Functions." Proc. 7th Annual ACM Symposium on Theory of Computing (1975), 27-36.

Yau, S. S., and Y. S. Tang. "An Efficient Algorithm for Generating Complete Test Sets for Combinational Logic Circuits." IEEE Trans. on Computers, C-20 (1971), 1245-1251.

${ }^{2}$<br>Charlotte Couch Acken<br>Doctor of Philosophy

Candidate for the Degree of

Thesis: A MATRIX MODEL OF DIGITAL SYSTEMS AND ITS APPLICATION TO AUTOMATIC TEST GENERATION

Major Field: Electrical Engineering
Biographical:
Personal Data: Born in Harrison, Arkansas, August 10, 1947, the daughter of Mr. and Mrs. William H. Couch.

Education: Graduated from Bruno High School, Bruno, Arkansas, in May, 1964; received the Associate of Science degree from the College of the School of the Ozarks, Point Lookout, Missouri, in May, 1966; received the Bachelor of Science degree in Mathematics from the University of Arkansas, Fayetteville, Arkansas, in January, 1969; received the Master of Science degree in Mathematics from the University of Arkansas, Fayetteville, Arkansas, in January, 1971; received the Master of Science degree in Electrical Engineering from Oklahoma State University, Stillwater, Oklahoma, in July, 1977; completed requirements for the Doctor of Philosophy degree at Oklahoma State University, in May, 1982.

Professional Experience: Instructor of Mathematics, Mathematics Department, University of Arkansas at Monticello, Monticello, Arkansas, 1970-1976; Member of Technical Staff, Sandia National Laboratories, Albuquerque, New Mexico, 1978 to present.

Professional Organizations: Member of Pi Mu Epsilon, Eta Kappa Nu, and Phi Kappa Phi Honor Society; former faculty member of the Mathematics Association of America.

