University of Nebraska - Lincoln

DigitalCommons@University of Nebraska - Lincoln
CSE Journal Articles

Computer Science and Engineering, Department
of

1990

A Statistical Theory of Digital Circuit Testability
Sharad C. Seth
University of Nebraska-Lincoln, seth@cse.unl.edu

Vishwani D. Agrawal
AT&T Bell Labs, Murray Hill, NJ

Hassan Farhat
University of Nebraska at Omaha

Follow this and additional works at: https://digitalcommons.unl.edu/csearticles
Part of the Computer Sciences Commons

Seth, Sharad C.; Agrawal, Vishwani D.; and Farhat, Hassan, "A Statistical Theory of Digital Circuit
Testability" (1990). CSE Journal Articles. 32.
https://digitalcommons.unl.edu/csearticles/32

This Article is brought to you for free and open access by the Computer Science and Engineering, Department of at
DigitalCommons@University of Nebraska - Lincoln. It has been accepted for inclusion in CSE Journal Articles by an
authorized administrator of DigitalCommons@University of Nebraska - Lincoln.

5 82

IEEE TRANSACTIONS ON COMPUTERS, VOL. 39, NO. 4, APRIL 1990

latency modeling,” in Proc. IEEE EASCON Conf., Aug. 1983, pp
299-306.
[16] D. Lomelino and R. Iyer, “Error propagation in a digital avionic processor: A simulation-based study,” NASA CR-176501, Univ. of Illinois, 1986.
[17] Z. Segall, J. Barton, D. Vrsalovic, D. Siewiorek, R. Dancey, and
A. Robinson, “Fault injection based automatic testing: Practice and
examples,” in Proc. 8th AIAA/IEEE Digital Avion. Syst. Conf.,
Oct. 1988.

RANDOM
COVERAGE

v

-

VECTORS

Fig. I .

Fault coverage.

A Statistical Theory of Digital Circuit Testability
SHARAD C. SETH, VISHWANI D. AGRAWAL,
HASSAN FARHAT

AND

Abstmct-When test vectors are applied to a circuit, the fault coverage increases. The rate of increase, however, could be circuit dependent.
A relation between the average fault coverage and circuit testability is
developed in this paper. The statistical formulation allows computation of coverage for deterministic and random vectors. We discuss the
following applications of this analysis: determination of circuit testability from fault simulation, coverage prediction from testability analysis,
prediction of test length, and test generation by fault sampling.

NUMBER

OF
FAULTS

A N D CIRCUIT
TESTABILITY
11. FAULTCOVERAGE

We will first define two quantities that are relevant to fault analysis
and then establish a relation between them.
Detection Probability: The detection probability of a fault is
the probability of detecting the fault by a random vector. Detection
probabilities of faults in a circuit can be represented by a distribution
PW:
p ( x )d x = Fraction of detectable faults with probability
of detection between x and x

+dx.

Manuscript received July 7, 1989; revised November 6, 1989.
S. C. Seth is with the Department of Computer Science and Engineering,
University of Nebraska, Lincoln, NE 68588.
V. D. Agrawal is with AT&T Bell Laboratories, Murray Hill, NJ 07974.
H. Farhat is with the Department of Mathematics, University of Nebraska,
Omaha, NE 68182.
IEEE Log Number 8933880.

1.o

0.5

0

DETECTION PROBABILITV

Zndex Terms- Fault coverage estimation, probabilistic testability, random pattern testability, statistical sampling, testability measures.

I. INTRODUCTION
Fig. 1 shows the nature of results obtained from fault simulation.
It is speculated that the fault coverage of random vectors follows
an exponential law [l]. There is no general agreement on how the
coverage of deterministic vectors might be represented. Fig. 2 shows
the distribution of faults in a circuit according to their detection
probabilities [2]. Such a distribution is presumably useful in assessing
the testability of a circuit. However, in the absence of an explicit
relationship between the probabilistic testability and fault coverage,
designers often find it difficult to use testability data to estimate the
size of the required test vector set or the fault coverage of a given
vector set. The specific problem solved in this paper is to find a
relationship between probabilistic testability and fault coverage.
Applications of the analysis presented in this paper are 1) assessing
circuit testability from fault simulation, 2) extrapolation of partial
fault simulation results where full fault simulation is very expensive,
3) finding the size of test sets for random and deterministic vectors,
and 4) fault sampling for test generation.

L
IC,

Fig. 2. A typical testability analysis result.
Since x represents probability, p ( x ) is nonzero (and positive) only
for values of x between 0 and 1. Also,
i ’ p ( x )d x

=

1.

Notice that p ( x ) is the distribution of only the detectable faults.
The distribution p ( x ) for a circuit can be determined in several
different ways. Testability analyses like PREDICT [3] and COP [4]
determine fault detection probabilities to various degrees of accuracy.
General sequential circuits can be analyzed through true-value simulation with random vectors [5]. In Section 111, we present a method
of estimating p ( x ) from fault simulation.
Fault Coverage: Fault coverage is the percentage (or fraction) of
faults covered by test vectors. Generally, this coverage is over the
set of all single stuck-at faults after it has been reduced by fault
collapsing. To remove ambiguity, we will use a slightly modified
definition. Most large circuits contain some redundant faults. By
definition, these faults cannot be detected by any test. The percentage
of such faults is small but finite, usually less than 5%. We define
coverage as
Fault Coverage =

detected faults
total faults - redundant faults.

(1)

An alternative definition of fault coverage is sometimes used in which
the number of redundant faults is added to detected faults instead
of subtracting from the total faults [6], [7]. Even though finding
all redundant faults may be very difficult, our method provides an
estimation of fault coverage as defined by (1).
Fault Coverage of Random Vectors: Since there are p ( x ) d x
faults with detection probability x , the mean coverage among these
faults by a random vector is x p ( x )d x . Suppose we apply a sequence
of random vectors to the circuit. The mean coverage by the first
vector is

0 1990 IEEE
IEEE Transactions on Computers,
Volume: 39 , Issue: 4, pp. 582-586.
doi: 10.1109/12.54854

0018-9340/90/0400-0582$01.OO

YI=~ ‘ X p O d X .

583

IEEE TRANSACTIONS ON COMPUTERS, VOL. 39, NO. 4, APRIL 1990

Actual coverage by a random vector may differ from the mean by a
random quantity. However, the variance will be small for almost all
circuits (this follows from the central limit theorem in statistics).
After removing the faults detected by the first vector, the distribution
of detection probabilities of the remaining faults can be shown to be
( 1 - x ) p ( x ) .Thus, the coverage of two vectors is
y2 = y l

+

l

~ ( - xl) p ( x ) d x

=

l

~ [+ ( l1 - x ) ] ~ ( x ) ~ x .

Similarly, the coverage of n vectors is

+ (1

y, = l ' x [ l

=1

-

-x

)

+(1

- x)*

+ . ..+( 1

- x ) " - ' ] p ( x )d x

l'(1

-x)"p(x)dx = 1 -I(n).

(2)

where Z(n) is the integral in the last equation. If we consider n as a
continuous variable and define new variables, w = -In( 1 - x ) and
t = n 1 then we have

+

where 1 << n < Y . This approximation is valid for large number of
vectors; however, the number of vectors should not be nearly as
large as the number of faults. Notice, that y , attains the value 1.0
at some definite value of n rather than increasing asymptotically as
in the random vector case.
111. DETERMINATION
OF p ( x ) AND I(n)

Suppose we simulate a set of n, faults with fault dropping. That
is, a fault is dropped from further consideration by the fault simulator as soon as it is detected. The fault set may contain all the
faults or just a randomly selected subset of the faults in the circuit.
With each simulated fault a random-first-detection (RFD) variable is
associated. It is used to store the vector number at which the fault
was first detected randomly by a test vector. Faults which are never
randomly detected will have the RFD value undefined (or 0 if initialized that way). Since random detection is required, the RFD value
of a fault targeted for deterministic test generation is not affected
by the generated vector. During test generation, any fault found to
be redundant is removed from the sample fault list. Let a fault f
be randomly-first-detected at vector number i. Then, using Bayes
theorem [ 8 ] ,f has the conditional detection probability distribution

F ( [ )= l m e - ' " P ( w ) d w
where F ( t ) = 1 - yg-' and P ( o ) = p(1 - e - w ) . The last equation
represents the Laplace transform. If we consider the number of vectors analogous to time (number of vectors is, in fact, proportional to
the testing time) and the detection probability distribution analogous
to frequency, then the above analysis expresses a transform relation
as is often used in the filter theory. Future investigations may reveal
new applications in the present context.
Fault Coverage of Deterministic Vectors: We assume the deterministic vectors to have the following properties.
1 ) Every vector detects at least one new fault that was not covered
by the previous vectors.
2 ) Every vector may also detect some previously undetected faults
depending on their detection probabilities.
For sequential circuits, the same properties are applicable to vector
sequences. For a combinational circuit with a total of Y faults, the
coverage by the first deterministic vector is
yl =

f +(1

-

k)

l'xp(x)dx.

Here, the first term is the fault coverage by the first vector, the
second term is the coverage of the single target fault for which the
second vector is derived, and the third term is the additional random
coverage by the second vector. Proceeding recursively, we obtain y ,
in the following form:

+

;[ +Z(n)
-

1

-

1'

1 -(;,"'"

~ W d x . ] (3)

The right-hand side contains three parts. The first part, 1 - I(n), is
the random detection as given by (2). The second part, n / Y , is the
deterministic coverage by n vectors. The remaining part represents
the reduction in the random coverage as faults are continuously being
removed from the fault population for the purpose of deterministic
vector generation. Equation (3) is valid o d y for those values of n
for which y ,
l .O. We use the following approximation:

<

y,

RZ

x(l -x)'-'q(x)

1

i

1

x(1

=

1 , 2,...,N

-x)'-'q(x)d x

where N is the number of test vectors. The probability density q ( x )
in the above expression represents the a priori detection probability
distribution of faults. For simplicity, we assume that before the detection data become available, the detection probability of a fault can
be anywhere between 0 and 1. Thus, q ( x ) = 1 for 0 5 x 5 1 , and
q ( x ) = 0, otherwise. This gives
p i ( x ) = i(i

+ l)x(l -x)~-'

0 <x

5 1.

(5)

With each vector number i we have an associated w ;representing the
number of faults whose RFD value is i. Further,
N

WO

2 n,

-

c w r
i= I

The first term on the right-hand side is the coverage due to the
fault for which this vector was generated and the second term is the
random coverage from the remaining faults.
Similarly, the coverage by the first two vectors is

y , = 1 -Z(n)

Pi(X) =

1 -I(n)

+Y

is the count of all the faults in the sample whose RFD value is not
defined. Here n, is the number of faults in the fault sample and
N is the number of test vectors. A fault chosen as a target for test
generation but not detected by any other vector will be included in
this count. Every fault included in the W O count has the property that
it was not randomly detected by any of the N vectors and thus will
have the Bayesian detection probability distribution

After evaluating the integral, using the uniform a priori distribution
for q ( x ) , we get
~ O ( X=
)

(N

+ 1)(1 -

x ) ~

0

< X

5 1.

(6)

Equations (5) and (6) allow the determination of the complete detection probability distribution as follows:
N

1
P(X) = k C w i p i ( x ) .

(7)

r=O

Since this estimate is a sum of N + 1 random variables, for a reasonable accuracv. the number N of vectors should be large.
Evaluation i f I@): The integral I ( n ) , defined in (:),
can be
(4) easily evaluated if we substitute the above expression for p ( x ) . On

5 84

IEEE TRANSACTIONSON COMPUTERS, VOL. 39, NO. 4, APRIL 1990

TABLE I
COMPUTED
FAULT
COVERAGE
FOR C7552

PW
8.0

r
1.

I

6.0 C

Vector
Number
5

Random
Coverage

60.8%
81 .I%
89.4%
93.4%
94.9%

0.2

0.0

0.4

0.6

0.8

1.o

X

Fig. 3. Experimentally determined p ( x ) .
1.0

r

0.01

10

100

1000

n

Fig. 4. Experimentally determined Z(n)
simplification, the following result is obtained:

Z(n) =

i ( i + 1)w;
KC(n+ i ) ( n ti + 1)'

wo(N+l)
1
n,(n + N + 1) +

,=I

Again, the accuracy of this estimate will improve as the number N
of vectors is increased. Once w , 's have been obtained from fault
simulation, I(n) can be computed from the above equation.
IV. APPLICATIONS
We discuss four applications of the analysis presented above.
Testability Assessment: The function p ( x ) (or the function Z(n)
derived from it), represents the testability of the circuit. It can be
determined by a topological analysis of the circuit [3], [4], in which
case it represents testability by random vectors. However, a determination from fault coverage data will include the characteristics of test
vectors also. In the earlier stages of a design, such an assessment of
testability can be useful. Designers often write functional vectors for
design verification. Since these vectors are not written for specific
fault targets they can be regarded as random and used to determine
p ( x ) . Large values of p ( x ) near x = 0 will signal a testing problem.
In our model for deterministic test generation, we assumed that
a test generated for a fault will behave like a random vector for
other faults. Under the assumption, it is possible to estimate the
functions p ( x ) and Z(n) even during the standard (deterministic) test
generation process as described in the last section. Figs. 3 and 4
show the results for three ISCAS circuits [2].
The p ( x ) data in Fig. 3 were obtained in each case while generating tests for a sample of faults. Note that the random pattern
testability exhibited in this figure is dependent not only on the circuit
but also on the random pattern characteristics of the derived test vec-

Deterministic
Coverage
60.9%
81.4%
90.1%
94.8%
96.7%

1

tors. As a simple measure of testability, we may use the area under
the curve for detectabilities (x values) less than a certain threshold
value, say, 0.1. Under the criterion, C6288 is significantly more
testable than the other two circuits. Among the other two circuits,
C2670 is slightly more testable than C7552. Similar conclusions can
be drawn from the data for Z(n) shown in Fig. 4. These results are
in agreement with the amount of test generation effort necessary for
the three circuits.
Fault Coverage Determination: Once the functions p ( x ) and
Z(n) have been determined, the fault coverage can be estimated for
any length of the vector set. Equation (2) is used for random vectors,
and (4) for deterministic vectors.
As an example, we will consider the evaluation of fault coverage
for the C7552 circuit using the data presented in Figs. 3 and 4. Table
I summarizes the random and deterministic coverages predicted for
this circuit.
Test Length: For any given fault coverage the required length of
vector set can be easily predicted from (4). Such a prediction would
be useful in planning of testing for a complex VLSI device.
As an example, from the Z(n) data for C2670 shown in Fig. 4, (4)
would predict a deterministic test length between 80 and 90 vectors
for a 95% fault coverage. We generated 113 vectors for this circuit using a Podem-based automatic test pattern generation program.
From the fault simulator data, the coverage values of the first 80 and
90 vectors were determined to be 90.4% and 92.0'36, respectively.
This circuit is known to have 4.5% redundant faults [9] which must
be subtracted from the total faults according to our definition [see
(l)] of fault coverage. The modified values of the fault coverage,
94.2%and 96.3%, indeed span the 95% fault coverage for which we
made the prediction.
Test Generation: The total cost of automatic test genration has
two easily identified parts: the costs of test generation and fault simulation, respectively. The cost here refers to the use of computing
resources (CPU time, memory, etc.). The fault simulation cost often
predominates if the circuit is very large and/or is sequential. As an
example, we provide the data on sequential test generation for a chip
with 4856 faults. A random sample of lo00 faults was chosen for test
generation. A sequence of 842 test vectors was generated and found
to cover 98.2% of the faults in the sample. In a separate run, the
fault coverage of the same sequence of test vectors was determined
to be 82% over the whole fault population. The run times for this
experiment on a VAX8650 computer were as follows:
Test Generation: 64 062 s
Fault Simulation:
Sample: 86 585 s
All faults: 462 234 s.
Reducing the relative cost of fault simulation in the test generation
process is the primary motivation in the proposed approach.
Based on the analysis given earlier we propose a sampling method
for test generation. In this method, vectors are generated using a random sample of faults. The analysis provides the size of the sampled
fault set that will be required for any given fault coverage. Also, the
coverage of the generated vectors over the entire fault population is
estimated without simulating all the faults.
Let Y be total number of faults in the circuit of which a fraction
s is randomly chosen for test generation. After n vectors have been
generated the total fault coverage is given by

f ( n ) = s f s + ( 1 - s ) [ i -Z(n)l

(9)

585

IEEE TRANSACTIONS ON COMPUTERS, VOL. 39, NO. 4, APRIL 1990

TEST

Sample
Size

500

TABLE I1
GENERATION
BY FAULT
SAMPLING

Circuit Name +
Total Faults +
Vectors +
Adjusted sample size +
Sample Cov. (%) +
Estimated Cov. (%) +
Measured Cov. (70)+

C2670
2747
65
488
100.0
:4.0

1 1

C6288
7744
34
500
100.0
97.0
98.4

C7552
7550
77
496
100.0
93.3
-

698
45
Remove detectedfaunsfrom faun list
I

978

1485

0

Fault Sim. CPU Sec. --f
Vectors +
Sample Cov. (%) +
Estimated Cov. (%) +
Measured Cov. f%) +
Test gen. CPU Sec: +
Fault Sim. CPU Sec. +

142
100.0
95.9
95.6
2855
78

Begin Pass 2

only the additionalfaults in the fault list

Fig. 5 .

Test generation by fault sampling.

where f s is the coverage of n vectors in the sample. Thus, s f s is
the deterministic coverage contributed by the sampled faults and the
second term gives the random coverage over the unsampled faults.
Without loss of generality, in the following, we assume f s = 1 . That
is, we will generate vectors to detect all faults in the sample. Suppose
the number of these vectors is N.Then (9) reduces to
f ( N )= 1

-

+

Z ( N ) sZ(N).

Our proposed test-generation-by-fault-sampling is a two-pass procedure as shown in Fig. 5 . Notice that this procedure differs from
that described in another paper [6] where the faults were simulated
without dropping the detected faults. We start Pass 1 with a random
sample of 500 faults for test generation and assessment of testability
as described in Section 111. The size 500 of this initial sample is
purely arbitrary and is chosen for convenience as it is neither too
large nor too small. If a fault is determined to be redundant it is
removed from the sample. When the sample is exhausted, the detection data (RFD variables of the sampled faults) are used to determine
the counts w, ’s for p ( x ) and Z ( N ) computation. Then (10) is used
to estimate the total fault coverage of the generated vectors. If the
estimated fault coverage exceeds the desired coverage, say C, the
test generation process can stop, otherwise, we carry out Pass 2 of
test generation on a larger fault sample.
Let s’ be the required sample size and assume that it is exhausted
by generation of N’vectors. Making the appropriate substitutions in
(lo), we must have

c = 1 -I(”) + s’Z(N’).

(11)

In addition, rewriting (4) when a sample s’Y of faults is completely
covered by N’vectors, we have

N’= s’YZ(N’).

(12)

The 65 vectors were estimated to cover 94% of all the faults in the
circuit. We chose 95% as the target fault coverage and determined
the requisite sample size to be 35% (961 faults). We added an additional 500 randomly chosen faults to the original sample. Before
restarting the test generation process we needed to simulate the 65
already generated vectors on these additional faults. In the second
test-generation pass, an additional 3 1 test vectors were generated to
cover a total of 978 faults in the enlarged sample; the remaining
faults were determined to be redundant by the test generator. The
estimated coverage of the 96 generated vectors was determined to
be 96.4% according to (10). In a separate fault simulation run carried out for verification of results, the actual fault coverage of these
vectors was determined to be 97.2% (this includes 4.5% redundant
faults). Similar experiments were carried out for two other ISCAS
circuits: C6288 and C7552. The results are summarized in Table 11.

v. CONCLUSION
Briefly, the contributions of our work can be summarized as follows:
1) A statistical relationship is developed between circuit testability
and fault coverage.
2) A method is presented to estimate circuit testability from fault
simulation data collected in the normal course of test generation. The
testability, so estimated, takes account of both the circuit topology
and the characteristics of test vectors.
3) Applications of interest to test engineers include fault coverage
prediction for random and deterministic vectors, test length prediction for a desired fault coverage, and test generation by fault sampling.
4) Several case studies verify the usefulness and precision of the
proposed model.
We have presented a method of testability assessment through fault
simulation with fault dropping. This is more economical compared
to our earlier method of testability assessment which requires fault
simulation without fault dropping [6]. As we pointed out, for a fault
in a sequential circuit the test is not just a vector but is a sequence of
vectors. The random vector coverage formula can still be applied to
sequential circuits. However, the deterministic coverage part needs
modification and will require further investigation.

For any required fault coverage C, (11) and (12) can be solved
ACKNOWLEDGMENT
numerically for s’ by eliminating N’.
We
are
indebted
to
Dr.
K.-T. Cheng of AT&T Bell Laboratories
We illustrate the procedure for the C2670 circuit which has a fault
population of 2747 single stuck type faults. A random sample of 500 for the data on sequential test generation reported in Section IV.
faults was chosen for test generation. Of these, 12 faults were deterREFERENCES
mined to be redundant by the test generator. The remaining 488-fault
sample was exhausted by 65 test vectors. The p ( x ) and Z(n) testabil- [ I ] T. W. Williams, “Test length in self-testing environment,” IEEE Design Test Cornput., vol. 2 , pp. 59-63, Apr. 1985.
ity functions were obtained from this run as described in Section 111.

5 86

IEEE TRANSACTIONS ON COMPUTERS, VOL. 39, NO. 4, APRIL 1990

I21 V. D. Agrawal, S . C. Seth, and C. C. Chuang, “Probabilistically
guided test generation,” in Proc. I n t . Symp. Circuit Syst. (ISCAS),

Kyoto, Japan, June 1985, pp. 687-690.
[31 S. C. Seth, L. Pan, and V. D. Agrawal, “PREDICT-Probabilistic
estimation of digital circuit testability,” in Fault-Tolerant Cornput.
Symp. (FTCS-15)Dig. Papers, June 1985, pp. 220-225, also FTCS16 Dig., pp. 318-323.
F. Brglez, “On testability analysis of combinational networks,” in
Proc. I n t . Symp. Circuit Syst., May 1984, pp. 221-225.
S. K. Jain and V. D. Agrawal, “Statistical fault analysis,” IEEE Design Test Cornput., vol. 2, pp. 38-44, Feb. 1985.
V . D. Agrawal, H . Farhat, and S. Seth, “Test generation by fault
sampling,” in P m . Inf. Conf. Cornput. Design (ICCD-88),Rye
Brook, NY, Oct. 1988, pp. 58-61.
[71 S. C. Seth, V. D. Agrawal, and H . Farhat, “A theory of testability
with applications to fault coverage analysis,” in Proc. 1st Euro. Test
Conf., Paris, France, Apr. 1989, pp. 139-143.
[81 A. Papoulis, Probability, Random Variables, and Stochastic Processes. New York: McGraw-Hill, 1965, sect. 4.4.
[91 M. H . Schulz and E. Auth, “Advanced automatic test pattern generation and redundancy identification techniques,” in 18th Int. Syrnp.
Fault-Tolerant Comput. (FTCS-18)Dig. Papers, Tokyo, Japan, June
1988, pp. 30-35.

Aliasing Probability for Multiple Input Signature Analyzer
DHIRAJ K. PRADHAN, SANDEEP K. GUPTA,
MARK G. KARPOVSKY

AND

Abstract-Formulation of closed form expressions for computing
MISR aliasing probability exactly had remained an unsolved problem.
This paper presents single and multiple MISR aliasing probability expressions for arbitrary test lengths. A framework, based on algebraic codes,
is developed for the analysis and synthesis of MISR-based test response
compressors for BIST. This framework is used to develop closed form
expressions for aliasing probability of MISR for arbitrary test length
(so far only hounds have been formulated). A new error model, based
on q-ary symmetric channel, is proposed using more realistic assumptions. Results are presented that provide the weight distributions for
q-ary codes ( q = 2m, where the circuit under test has m outputs).
These results are used to compute the aliasing probability for the MISR
compression technique for arbitrary test lengths. This result is extended
to compression using two different MISR’s. It is shown that significant
improvements can be obtained by using two signature analyzers instead
of one. This paper makes a contribution to coding theory as well. It
provides the weight distribution of a class of codes of arbitrary length.
Also formulated is an expression bounding from above the probability of
undetected error for these codes. The distance-3 Reed-Solomon codes
over G F ( 2 m )become a special case of our results.

Index Terms- Algebraic codes, aliasing probability, BIST, BIT, error
model, MISR, Reed-Solomon codes, shift register, weight distribution.

Manuscript received July 6, 1989; revised December 5 , 1989. This work
was supported by NSF Grants MIP8902014 and MIP8813748.
D. K. Pradhan and S . K. Gupta are with the Department of Electrical and
Computer Engineering, University of Massachusetts, Arnherst, MA 01003.
M. G. Karpovsky is with the College of Engineering, Boston University,
Boston, MA 02215.
IEEE Log Number 8933881.

I. INTRODUCTION
The multiple input signature register compression (MISR) is the
primary technique used in signature analysis. The outputs of the
circuit under test (CUT) are connected to the inputs of the MISR
while the test patterns are applied to the CUT. The final contents of
the MISR are compared to that expected for a fault-free circuit to
determine whether the CUT is faulty.
Deriving closed form expressions for computing MISR aliasing
probability exactly for arbitrary test length had remained an unsolved problem. The chief contribution of this paper is to provide
precisely such an expression. The results obtained from earlier investigations for the single input LFSR [2] are extended to multiple
input MISR using the relationship between coding theory and shiftregister theory. Specifically, we formulate expressions for estimating
the aliasing probability for MISR using a more realistic error model
by relating the analysis of an MISR to the analysis of q-ary codes
where q = 2” for an m-output CUT. Also presented are aliasing
probability expressions for multiple MISR’s.
Also, this paper makes two new contributions to coding theory.
First, a counting technique is developed for computing the weight
distribution of a certain class of codes of arbitrary length which
are not necessarily maximum distance separable (MDS) [8]. (Weight
distributions for MDS codes are known.) Also, the probability of
undetected error for this class of codes is bounded from above.
(Certain known results for MDS codes [ 181 become special cases of
our results.)
In summary, proposed here is a new approach for estimating aliasing probability for MISR compression. In the paper, we present aliasing probability expressions for m output circuits for any arbitrary test
sequence of length n. We also present a multiple-MISR compression
technique which reduces aliasing.
The paper is organized into three major sections. Section I1
presents the basic framework of the analysis of MISR techniques
using coding theory. The analysis of MISR techniques is then presented in Section 111. In this section, both single and multiple MISR
schemes are analyzed. Finally, we conclude in Section IV.
11. CODING
THEORY
FRAMEWORK

Below we present a coding theory framework [lo] for analysis and
synthesis of MISR compressors. It is shown that for an m output circuit, the design and analysis of MISR-based compression techniques
can be formulated using algebraic coding theory of q-ary error correcting codes ( q = 2”).
A . Algebraic Codes
Let c be an n-tuple ( C , - , C ~ - ~‘ . . c o ) where ci E G F ( q ) . Let
c(x)= C , - ~ X “ - ’
. . c I x +CO be the polynomial representation
of the n-tuple.
In the following discussion, the vector and polynomial representations shall be used interchangeably. All polynomial representations
and operations will be assumed to be over G F ( q ) where q = 2”.
Thus, all additions and multiplications in this section will be assumed
6 = -6; therefore, the terms of
to be over GF(2“). In this field
the polynomials can be represented as only positive terms.
Definition I : The generator polynomial g ( x ) of a code C is that
polynomial g ( x ) which divides every codeword polynomial in C .
The degree of g ( x ) is equal to n - k where n is the length of the
code and k is the number of information symbols.
Two key observations should be made here. First, when g ( x ) divides x” - 1, only then does the code become a cyclic code of length
n . On the other hand, when g ( x ) does not divide x” - 1, then the
code is not cyclic. The results derived here are applicable to cyclic
and noncyclic codes.
In the following, the Galois field elements 0 = (0, 0) and 1 =
(0, 1 ) are denoted by boldface to distinguish from the binan 0, 1.
Example I : Consider a cyclic (3, 2, Reed-Solomon cdde over

+ +

0018-9340/90/0400-0586$01.oO 0 1990 IEEE

+

