An analytical approach to the partial scan problem by Kunzmann, Arno & Wunderlich, Hans-Joachim
JOURNAL OF ELECTRONIC TESTING: Theory and Applications, 1, 163-174 (1990) 
© 1990 KJuwer Academic Publishers, Boston . Manufactured in The Netherlands. 
An Analytical Approach to the Partial Scan Problem 
ARNO KUNZMANN AND HANS-JOACHIM W UNDERLICH 
insriruu of Compuu r lksign and Faufr Toferanu. rnj~rsiry of Knrlsrohe. P.O &x 6980. D-7500 Knru ruhe F.R. Germany 
Roceived July 24, 1989. Revised January 16, 1990. 
Abstract. The scan design is Ihe most widely used technique used to ensure the testability of sequential circuits. 
In this an icle it is shown that testability is still guaranteed, even if only a smaU part of the flipflops is integrated 
into a scan path. An algorithm is presented for selecting a minimal number of flipflops , which must be directly 
accessible. The direct accessibility ensures that , for each fa ult , the necessary test sequence is bounded linearly 
in the circuit size. Since the underly ing problem is NP-complete, efficient heuristics are implemented to compute 
suboptimaJ solutions. Moreover, a new aJgorithm is presenled to map a sequential circuit into a minimal comb ina· 
tional one, such that test pattern generation for both circuit representations is equivalent aDd the fast combinationaJ 
ATPG methods can be appUed. For aJl benchmark circuits investigated, this approach results in a significant reduction 
of the hardware overhead. and additionally a complete fault coverage is still obtained. Amazingly the overall test 
application time decreases in comparison with a complete scan path, since the width of the shifted patterns is 
shorter. and the number of patterns increase only to a small extent. 
Key words: design fOT testability, panial scan path , sequential test generation. 
1. Introduction 
In 1973, Angell and Williams proposed the scan path in 
order to facilitate test generation for sequential circuits 
[3]. In lfJ77. Eichelberger and Williams established a 
system of rules called Lcvc1·Scnsitive Scan-Design 
(lSSD), resulting in higher flexibility of the design and 
less hardware overhead [91. But the costs of a scan path 
are still up 10 20% additional s ilicon area [4]; and some 
investigations show significant savings if only a part 
of the flipflops is integrated into an incomplete or paniaJ 
scan path . 
The partial scan design does flot lead to combina· 
tional test generation and test application , only the se· 
quential depth of the circuit is reduced . Moreover, the 
costs of wiring of an incomplete scan path do not directly 
depend on the number of scan elements. For this reason 
a partial scan approach is only ~rthwhile if the number 
of scan e lements can be kept below 50% of all flipflops 
[34] . Similar results are obtained in [21] . 
TrischIer proposed the selection of scannable e le-
ments based on testability measures [35], for instance 
SCOAP [15]. He uses a general-purpose sequential test 
pattern generator for the resulting network of reduced 
sequentiaJ depth. But this approach has two main 
drawbacks: 
I . For the modified sequential network, the use of a 
general ATPG does not guarantee a complete fault 
coverage. 
2. In general, the heuristics for selecting the scannable 
flipflops do not result in a minimaJ number. 
T he first drawback is avoided by the approach pre· 
sented in [I and 2]. Here the selection of the scan 
elements and the generation of the test patterns are inte· 
grated into one aJgorithm. The PODEM algorithm [14] 
tries to generate lest patterns fo r me combinational part 
of the circuit; flipflops arc selected that should be acces· 
sible in order to control the inputs of the combinational 
pan. But the number of selected flipflops wiU become 
rather large. Both drawbacks can be avoided by an ap-
proach based on the state transition graph as presented 
in [271 . where circuit design and test generation are in· 
tegrated. This approach is especially applicable for 
logic synthesis. But. in geneml, the circuit structure 
is given and not the state transition graph. Generating 
this graph fo r arbitrary networks can become imprac--
ticable duc to time and storage limits. 
164 Kunzmann and ltUnderlich 
In the presented work, both disadvantages areavoided 
without any serious time and stOrage restrictions. We 
establi sh some necessary restrictions on the circuit 
structure to ensure that the test length fur each fault 
is linearly bounded by the circuit size. We present a 
new algorithm selecting a minimal set of scan elements 
in order to satisfy these restrictions. Since the selection 
problem is NP-complete, the exact solution optionally 
is weakened by some heuristics. Based on the selection 
of thc scan elements, a new ATPG-algorithm is devel-
oped, which is specially suited for these modified cir-
cuits and succeeds in complete coverage of the medun-
dant faults . 
This article is an extension of the work reported in 
[23] ; similar ideas have been presented in [6] and [13] . 
In section 2 we describe the necessary design restric-
tions for our approach , introduce the used. graph-
theoretical circuit representations, and discuss the fault 
model. Afte r these preliminaries, section 3 points out 
the relation between circuit structure and test length. 
The necessary restrictions are established; these must 
be satisfied by an incomplete scan path in order to 
bound the test length and the test effort . 
Section 4 presents an algorithm for selecting the 
scannable elements, and section 5 explains the corre-
sponding ATPG-algorithm for the modified network. 
A fler a discussion of the necessary and sufficient test 
lengths and also of the test application time, the results 
of severaJ benchmark circuits arc presented in section 7. 
2. Circuit Representation and Fault Modeling 
We assume that the sequential circuits are described 
at gate level, and that the following restrictions are 
fulfilled: 
• The circuit is purely synchronous. 
• The system operation is controlled by a one-phase 
clock. 
• Only D-flipflops are used. 
• The D-flipflops can be completed. according to the . 
rules of either level-sensitive or edge-triggered scan 
design (LSSD, ETSD). 
• Shifting is controlled by an additional clock, or the 
system clock for the non~scannable flipflops can be 
blocked. 
The extensions to multiple clocks are omiued in 
order to simplify the notations. More complex storage 
elements (e.g., T-, RS-, and IK-flipflops) can be used, 
if these components are modeled by D-flipflops and 
some combinational logic. 
We model sequential circuits by a directed graph, 
caUed data-flow graph, where the vertexes or nodes cor-
respond to primary inputs, primary outputs, and to the 
outputs of the gates and fliptlops. There is a directed 
edge between node v and w, if v is input of a cOffiJxment 
with output w. For the example circuit of figure 1 the 
corresponding data-flow graph is given in figure 2. 
Here the data-flow graph G = (V, E) consists of the 
nodes s W~ {EI, ... , £5, Ki, ... , K8, Kil, Kl2 , POl, 
P02, P03} and the corresponding edges. 
In the next section, it is shown that the topology of 
the storage elements in particular determines the test 
length. This topology is described by the so~called 
S(torage element)-graph. Figure 3 shows the p~graph 
corresponding to the data-flow graph of figure 2. 
The nodes V of the S-graph Gs : == (V, E) are the 
tcrminals and the outputs of flipflops. There is an edge 
(v, w) E E in the S-graph, if there is a path from node 
v to node w in the data-flow graph, whieh does not con-
tain any storage element. 
The presented. approach is valid for a very general 
fault model, including the classical stuck-at fault model, 
combinational faults, and most of the bridging faults . 
El------------f--:l 
E2--:=----CJ<lLJonl.JiliJ 
El 
E4 1'03 
E5 +--+---===1---.1 
CilCh JJ~JJJJJ4JJJJJ~JJJJ~ 
Ag. I. Example circuit. 
An Analytical Approach to the Partial Scan Problem 165 
Fig. 2. DalO-flow graph. 
PO 
E3l----r 
~ 
Fig. 3. S-graph . 
Thc only restrictions are, that no sequential behavior 
is induced for instance by stuck-open fa ults, and that 
the topology of the S-graph is not altered by shorts. 
3. The S-Graph and Test Lengths 
By the definition of our fault model, the correct circu it 
and all faulty circuits are mapped onto the same S-graph. 
Since all faulty changes of the func..1ions of the combina-
tional components are admissible, we have to impose 
some restrictions on the topology of the S-graph, in 
order to ensure thai the test lengths are linearly bounded. 
Duc to observation I and observation 2 below, a neces-
sary condition is that the S-grdph contains no cycles 
(i .e., feedback loops wi thin the gate-level netli st). 
Observation 1. If the S-graph of a sequential circuit 
contains cycles, the initiali7.ation sequence of some 
stales can increase exponentially wi th the number of 
flipflops. 
A simple example of this observation is a linear feed-
back shift register (LFSR) of length fl , which might 
have an initialization sequence of length 2n - l. But 
even a single cycle can lead to a drastic increase in test 
size: 
Obsenation 2. There are S-graphs containing a single 
cycle, where the initialization sequence of some states 
increases quadratically with the number of flipflops. 
Such a circuit is shown in figure 4. 
166 Kunvnann and %nderlich 
Acyclic Shift Register 
oflength n (SR 1) ,r 
& 
Cyclic Shift Register 
oflength n (SR 2) 
Fig. 4. Sequential circuit with a single cycle. 
Fig. 5. S-graph of the circuit of Fig. 4. 
In order to fill the register SR2 completely by "1," 
O(n2} clocks are required. As illustrated by figure 5, 
the S-graph contains exactly one cycle only. The actual 
length of the transition sequence is determined by the 
data-flow graph, and there are circuits with short test 
sequences, though the S-graph contains some cycles. 
But since the data-flow graph is affected. by each fault, 
we have to assume the worst-case, and we demand that 
the S-graph of a sequential circuit is cycle-free. This 
condition requires that almost all the flipflops of coun-
ters or control parts must be integrated into a partial 
scan path. This drawback is not too severe, if these tlip-
flops are only a small subset of a total set of flipflops, 
as we will demonstrate by the analyzed bendunark cir-
cuits. On the other hand , it is well known, for exam-
ple, that large counters are hard to test and they should 
be directly accessible anyway_ 
Adding a storage element to an incomplete scan path 
corresponds to the removal of a node from the S-graph 
as described in definition 4.1 below. In the next section, 
we discuss how to determine and to remove a minimal 
set of nodes in order to get an S-graph without cycles. 
In section 5, it is shown that these conditions are 
not only necessary, but also sufficient, to test a sequen-
tial circuit with test pattern sequences of linear bounded 
length. 
4. The Selection of Scan Elements 
In order to describe the algorithms selecting scan 
elements, some graph theoretic notations are necessary. 
Let G:= (V, E) be a finite, directed graph with nodes 
V and edges E C V2. We use the following notations. 
A sequence eh ... , eq of nodes (vertexes) is a 
path, if (e;, ei+l) E E for i = 1, ... q - L The length 
few) of a path w is the number of directed edges. An 
elementary path is a path where each node occurs only 
once; and a cycle is path where the first node and the 
last node are identical. An elementary cycle is a cycle, 
where no node occurs twice, with the exception of the 
first and last node. 
Let G = (V, E) be a graph, and v E Va node. p(v, G) 
C V is the set of all predecessors of v in G, s(v, G) 
c V is the set of aU successors, pd(v, G) is the set of 
all direct predecessors, and sd(v, G} is the set of all 
direct successors of v in G. A node v of the graph G 
is initial (final), if p(v, G} = tjJ (s(v, G) = q,}. By this 
definition, all initial nodes correspond to primary 
inputs. 
Definition 4.1. Let G = (V, E) be an S-graph of a se-
quential circuit. A cut of a node v E V is a map of G 
into a new graph G' = (V', E,) where 
An Analytical Approach to the Partial Scan Problem 167 
V' ~ {p;) u {P, ) U v\{v), with new p; " p, e V 
E' ~ {(P;, w) I wE sd(v, G)) U 
{(w, Po) I w E pd(v, G)) U 
E\{(x,y) I x ~ vVy ~ v) 
If two nodes are Cllt, then the resulting graph G' 
is independent of the order in which the cuts are per~ 
formed. Thus for each W C V, we can cut all nodes 
of W, and we denote the resulting graph by Gw = (V w, 
Ew)· 
The problem of selecting a minimal number of scan 
elements can now be stated as follows: 
(AC): For an S-graph G = (V, E), find a 
set W C Y of minimal cardinality 
such that Gw = (VW, Ew) is acyclic. 
(AC) is an NP-complete problem, sometimes called 
Feedback Node Problem [20]. For this reason, besides 
the exact algorithms some heuristics are necessary in 
order to obtain at least good, suboptimal solutions. Let 
ZG be the set of all elementary cycles of G. For each 
cycle z E ZG' we defme n(z) := {v E V I v E z} the 
set of all nodes of z. Now we can divide the scan selec-
tion problem into two subproblems (see figu re 6): 
i) For the S-graph G = (V, EJ. detennine the set of 
all elementary cycles ZG. 
til Set H ~ U n(z). 
taG 
Find a set W C H of minimal cardinality, such that 
Vz E ZG: W n n(z) "# 0. 
Both subproblcms are standard-problems of graph-
theory, and mere are well-known solutions. For c:xample, 
algorithms to solve subproblem (i) are presented in [8, 
32, 33, 36]. In the presented approach, an algorithm 
has been implemented based on [19J . In the worst case, 
the cardinality IZGI may increase exponentially in the 
PROCEDURE sca"-.Seiection; 
SET W: = 0, Gw = (V,E); 
REPEAT 
size of V. Also subproblem (ii) has a very high complex-
ity, since it is a formulation of the Hitting Set Problem, 
which is also known to be NP-complete [12 , 20]. 
The implemented algorithms are based on methods 
described in [7] , but in combination with subproblem 
(ii) additional heuristics are used. These heuristics are 
divide-and-conquer methods, where the problem size 
is bounded by a constant C E IN. 
This procedure can also be used for probabilistic 
optimization, since the elementary cycles are selected 
randomly. Even a single pass provides gcxxl results; and 
for the results reported in section 7, this procedure has 
been called only once. 
In the next section we show that for circuits repre-
sented by an at.)'clic S-graph test patterns can be gener-
ated very efficiently. 
5. Test Pattern Generation 
For general synchronous circuits, Roth introduced the 
notation of time-frames [29] . For each time step, a copy 
of the combinational part of the circuit is generated, 
and the number of time steps corresponds to the length 
of the lest sequence (figure 7). 
It is known that for circuits described by an acyclic 
p~graph the necessary number of time-frames is bounded 
by the number of storage elements [10]. In this section 
it is shown that only a small part of the combinational 
circuit must be copied at each time step. This results 
in a rather small combinational representation of the 
sequential circuit. It should be noted , that only a linear 
number of time~frames is needed in order 10 identify 
all redundancies. This includes combinational redun-
dancies and redundancies due to unreachable states. 
Finally, the test pattern generation algorithm for this 
select a set of elementary cycles Z of Gw at random with f~f ::!':Oc; 
SET H I ~ r O(l); 
~bZo 
Solve the hitting problem for H, i.e. find minimal W*CH such that 
VzEZ: t*nnEzF~M. 
SET W: :=WUW*; 
UNTIL Ow is acyclic 
END sca"-.sclection; 
Fig. 6 Selection of scan-elements. 
168 Kunzmnnn alld H1Inderlich 
rr==ZH~ Combi-
national 
=01 ~ circuit 
DOE OI Data Input. (primary) 
DO Data Output (primary) 
Z+ State 
z:- Z- Data Output of the register 
~ h 
rr=.l 
.'" f ~ 
Initial 
state 
~ all~ Z1+-:: 
~ Copy 1 
~ 
=0111;: Z2+:; 0021:: 
• Copy 2 
= DI2 c:: Zk+J:: oml:: 
Copyk 
=Ork Zn+:; DO;:: 
Copyn 
=D1n Zn- --::-
Final 
State 
Fig. 7. Time fram~s. 
combinational representation is sketched, and the trans-
formation of the combinational test patterns into se-
quences is discussed . 
5.1. Test Lengths Jor Acylic S-Graphs 
In order to describe our sol utions exactly, some more 
graph-theoretical definitions arc required: 
Definition 5.1. Let G = (V, E) be an acyclic graph, 
let v E Vbe a node. The value rf(1I): = max {f(w) I 
w is a path in G with final point v} is called forward-
rank, and rb(v) := max {f(w) I w is a path in G with 
initial point v} is called backward-rank. 
DefmitioD S.2. Let G = (V, E) be an acyclic graph. 
The rank of G is defined by 
mnk(G) ,= max {<fey») = max {,bey)). 
v{V v{V 
lei G = (V, E) be an acyclic S-graph with '.:lnt(O) 
= r. A time·frdJ11e at time t is a subset of nodes VI 
C V. V r contains all the primary outputs and all the 
nodes that are connected with a primary output via a 
path of combinational elements. The time-frames are 
ordered by V H = {v I v E pd(w) , wE V r}. 
Obviously the nodes of Vr have defined values, if 
the nodes of Vl-l have defined values. Hence we can 
use this notations for state-back-tracing, and if we find 
a time-frame V S , s < I, containing only initial nodes, 
then an uppcrbound (t - s)ofa testsequencc is derived. 
A test sequence of a sequential circuit must drive 
the faulty and the fault-free circuit into a stale s or Sf' 
where the responses to the same pattern are differenl. 
Hence the maximal test length is given by the maximal 
required Slate transition sequence. In a fonnal way, we 
can state the following theorem, which was also ob-
served in [10, 18]: 
Theorem 5.3. Let G "'" (V, E) be an, acyclic S-graph 
with rank(G) = r. For each flipflop v, there is an initial-
izing sequence of at most length r, if there is such a 
sequence at all. 
Proof. Let rb(v) =- k ::s r, and start with V' =- {v} . 
The theorem is proved if VO = "or VO contains initial 
nodes only. Set 
An Analytical Approach to the P'drtial Scan Problem 169 
m(l) : ~ rna, {rf(u»), i ~ 0, ... , r. 
"'-
By definition 5.1 we have me!) = m(i - 1) + I, if Vi 
contains storage nodes. Since mer) !f r we have m(O) 
~l QE.D 
In order to get a test sequence. we have not only 
to set a single flipflop, but we have to assign an entire 
state. This is possible by the following corollary: 
Corollary SA. Let G = (V. E) be an acyclic S-graph 
with rank(G) = r. Each admissible state can be reached 
within r steps. 
Proof. Let Sj .. ,Sk be the flipflops of the circuit. let 
f(SI> ... , Sk) be a boolean function, which is true, if 
and only if the desired state is reached. Let SHI be a 
new flipflop , and add circuitry such that Sk+l = f(SI> 
... , Sk)' Then the new S-graph has rank r + 1, and 
Sk+J can be set within r + 1 steps by theorem 5.3. 
Thus the desired state can be reached within r steps. 
Q.E.D. 
Up to now we have proved that the test lengths are 
linearly bounded. Now we will describe how to derive 
the test sequences. 
5.2. Equivalent Combinational Circuits 
For a sequential circuit C with an acyclic S-graph G : = 
(V, E), we are generating an equivalent combinational 
circuit C of size O(r(G) . Ie!). such thai a test pattern 
of C corresponds to a test sequence of C. Moreover, 
C should be minimized. For this reason we extend our 
notion of time-frames to data-flow graphs. 
Let Gs : = (VS, Es) be an acyclic S-graph, and 
GD := (VD. ED) be its data flow graph. 
Let Vi be a time-frame of the S-graph. In the data-
flow graph, Vi is defined by 
Vi : = Vi U {v E sew, GD) ! W E Vi 
aDd there is a combinational path from w to v} . 
If one node occurs in several time-frames. it must 
be copied sufficiently often. Moreover the flipflops are 
modeled as pseudo-boolean functions in the weU-known 
way. 
The equ ivalent combinational ci rcuit C is repre-
sented by the graph Gc := (Ve, Ed where 
Vc : ~ U {(v, i) I v , V;) 
Os isr 
and 
.1 e2 e3 
• 
fig. 8 Sequential circuit and data·flow graph. 
Ec : ~ {((v, I), (w, j) I (v, w) 'ED 
A (i .:= j - 1 A w is a flipflop»}. 
Instead of the fonnal description of this straightfor-
ward method, an example is given. Figure 8 shows a 
sequential circuit and its data flow graph. The marked 
nodes of the data-flow graph correspond to flipflops. 
We bave the fullowiug lilllc-frdllles: 
V' ~ {a, kS), 
V' ~ {k4, k3, kL, e3, eL) Dnd 
V' ~ {k2, kL, eL, e2 ). 
The resulting equivalent combinational network is 
shown in figure 9. Test patterns, generated for the com-
binational representation with 4 inputs, have to be trans~ 
formed to pattern .sequences of length 2 as represented 
in table 1. 
5. 3. Test Pattern Generation 
A target fault may affect a gate, wh ich is represented 
in multiple timc-frames. In this case me fdult is copied, 
and test generation must be done for a combinational 
network with multiple faults. 
For this purpose the algorithm SPROUT-9V (Signal 
Probability Using Test Pattern Generator, 9-valued 
logic) has been implemented. Thc tool is described in 
170 Kunzmann and Wunderlich 
e1/1 e110 eVO e3l1 
aJ2 
nit : node! 
time step 
Fig. 9. Equivalent combinational netWOrk. 
7Ilble 1. Test pattern transfornlation . 
Test pattern 
Test pattern sequences 
el / l etlO e2/0 d/l 
" 
,2 ,) 
0 
-
0 
0 0 0 0 
0 0 
detail in [22], and we are only sketching its main fea-
tures. h is based on the nine-valued algebra proposed 
in [28] , in order to guarantee the generation of test pat-
terns for any detectable fault , if the computing time is 
not limited. The algorithm is an enumeration algorithm 
controlled by estimations of signal probabilities derived 
by PRarEST r37, 38]. Additional heuristics accelerate 
the TPG in a similar way as used in fAN [11} or 
SOCRATES xP~I 31J. 
6. Test Application lime 
The test application time is determined by both the 
length of the scan path and the number of pattern se-
quences. The shifting time is shortened by using a partial 
scan path, and it turns out that the number of patterns 
does not increase as fast a<; the number of scan elements 
decreascs. Thus the overaU test application time is 
reduced. 
In many cases it is possible to develop an overlay 
scheme for the tcst sequences. That is, new patterns 
can be applied at a time when parts of the circuit arc 
still deaJing with fonner sequences. Most widely this 
pattern compaction can be used for pipeline structures. 
Here, after a certain start-up time, an overlay techrtique 
can be used and at each time step a new pattern can 
be applied. Figure 10 shows the S-graph for pipeline 
circuits. 
Fig . Ia S-graph for a pipeline structure. 
An Analytical Approach to the Partial Scan Problem 171 
Fig. /I. Equidistant graphs. 
A complete overlay of test patterns is also obtainable 
for more general structures than pipeline circuits. An 
acyclic S-graph G = (V, £) is called equidistant, if for 
two arbitrary nodes u, v E V, all paths with initial point 
u and final point v have the same length . Figure 11 
shows two examples. 
Definition 6.1. Let G = (V, E) be an acyclic graph. 
An asymmetric recollvergency between u, v E V is a 
set of nodes ReV, such that 
i) there are paths PI> and P2 from u to v with ((P1) ¢ 
f(P,). 
ii) PI n Pl = {u , v}. 
iii) R = (p, U p,)\{u, v}. 
An acyclic graph is equidistant if there are no asym-
metric reconvergencies. It can be generated by adding 
a few more elements to the partial scan path. 
An asymmetric reconvergency R is solved if at least 
one node of R is removed by adding the corresponding 
storage element to the scan path. Searching a minimal 
set solving all asymmetric reconvergencies is aD NP-
complete problem (see also [24]). Thus we are using 
heuristics, and we have to solve the same subproblems 
as presented in section 3: 
i) Create all .as),mmelfic reeonvergencics RG. 
ii) Set K := U R. 
o~ov 
Find a set We K of minimal cardinality, such that 
V R ERe: W n R ¢ 0. 
Of course, the shorter test lengths for equidistant S-
graphs are at the expense of somewhat longer scan paths. 
7. Results and AppUcations 
The presented algorithms are implemented and inte-
grated into a tool system called INSPIRATION (Ineom-
plete Scan Path Integration) . Figure 12 summarizes the 
architecture of this system. 
The approach can also be extended to a test by 
weighted random patterns (WRP). For a design with 
a complete scan path , the application of weighted ran-
dom patterns has been discussed in {25] . A partial 
scan path requires the compmation of time-dependent 
weights as discussed in [39]. 
Several sequential circuits have been analyzed by 
INSPIRATION as described in [24J . Here, we discuss 
three examples. The rust one is the operation unit of 
the signal processor (SP) proposed in [5J. The second 
example is a multiplier (MU) presented in [16], and we 
discuss a processor to accelerate PROLOG-programs 
(PP) fI7]. Table 2 shows the relevant data of the exam-
ple circuits including the transistor count. 
'Rlble 2. Circuit characteristics. 
SP 
MU 
pp 
lnput~ Outputs 
83 
43 
36 
55 
26 
73 
Gates Flipflops 
1,675 
993 
1,428 
239 
183 
136 
Transistors 
2t,776 
14,652 
17,242 
Both discussed test strategies have been investigated: 
If the main objective is to reduce the hardware over-
head , one has to generate acyclic S-graphs, and if the 
objective is to reduce test lengths, one has to generate 
acyclic equidistant S-graphs. Table 3 gives the percent-
age of f1ipflops which has to be integrated into a scan-
path in order to generate a complete scan path (CS), 
equidistant S-graphs (EQ), and acyclic S-graphs (AC). 
7llble 3. Percentage of scan path elements. 
SP 
MU 
pp 
AC 
17.2% 
39.3% 
20.6% 
EQ 
38.5% 
39.3% 
44.1 % 
CS 
100% 
100% 
100% 
172 Kunmumll and Wunderlich 
___ data flow 
generation 
fault 
generation 
scan path ..... ------, 
integration 
gerlera.tfl( In of an 
equivalent combinational 
circuit 
test program 
generation 
fig. 12. Test system INSPIRATION. 
For the general partiaJ scan approach , only 17.2% 
and 20.6% of the flipflops must have the scan path capa-
bility. The multiplier (MU) has a structure, where gen-
erating an acyclic S-graph automatically provides an 
equidistant S-graph, too. The execution time for the 
sample circuits to determine the scan fJipflops has 
always been less than 100 seconds (SUN 3/50). 
It has already been mentioned that the test pattern 
generator must take advantage of the different scan tcch-
Diques like acyclie or equidistant S-graphs. General pur-
pose ATPG programs are not able to do so, as proved 
by table 4. The different circuit structures have been 
given to the program LASAR2000 [26], where the scan 
clements have been modeled as pseudo-primary inputs 
and outputs. Fault coverages obtained after 3600 
seconds computing time are listed in table 3. 
For the combinational parts of the circuits, the new 
tcst generator SPROUT-W succeeded in identifying all 
An Analytical Approach to the P'J. rtial Scan Problem 173 
Tobie 4. Fault cC/'lerage I7f LASAR aftcr 3600 seconds. 
AC EQ CS Unmodified circuit 
SP 13.2% 27.9% 80.7 % 8.7 % 
MU 40.9% 40.9% 98.9% 9.8 % 
PP 47.9% 63.2 % 93.0% 11.2% 
redundancies. The number and percentage of redundant 
mults are listed in table 5. These fdults have been removed 
from the fau lt list. By the presented approach, it is also 
possible to idcntify sequentially redundant faul ts requir-
ing unreachable states. Different sets of states can be 
reached by an (AC)- and an (EQ)-dcsign, and both sets 
contain the stales reached during system operation. 
Table 6 g.ives the overall number of redundancies, 
7hble 5. Nwnbcr and percentage of combination ally redundant faults. 
Number of combinationally 
redundant faults Percentage 
SP 4 0.1% 
MU 0 0% 
PP 188 7% 
Table 6: Total number of redundancies. 
Total number of 
redundancies Percentage 
AC EQ CS AC EQ cs 
SP 4 4 4 0.1% 0. 1% 0.1% 
MU 10 10 0 0.4 11i 0.4% 0.0% 
PP 692 SI2 188 25.6% 18.4'l. 7.0 % 
For the remaining fau lts, test patterns have been gen-
erated . The fault covemge with respect to all detectable 
faults and the necessary computing time are given in 
table 7. The time is measured on a workstation SUN 
3/50. 
Table 7. Fault coverage and cornpUling lime for different scan tech-
niques by SPROUT-9\'. 
AC EQ CS 
CO\·crage TImc CoYerage Timc Coverage Timc 
SP 99.8 % 1,099 sec: 99.8 % 1,411 see 100% 238 sec 
MU 100.0% 176 sec 100.0% 176 sec 100% S8= 
PP 100.0% 1,101 sec 100.0% 1,060 sec 100% 513 sec 
The rank of the S-graphs is in the range betwcen 
6 10 8. Compared with the size of the combinational 
part of the sequential circuits, the size of the combina-
tional representations of the modified sample circuits 
grows in worst case only by 15 %. 
Up to now, the examples show that complete fa ult 
coverage is obta inablc by scan paths contai ning only 
20%-45% of all fl ipflops. lable 8 indicates the neces-
sary test application times. We distinguish the nu mber 
of shifting clocks (SH) and the number of system clocks 
(SY) fo r thc different designs. 
Table 8 Shifting clocks (SH) and systcm clocks (SY) for a complete 
test. 
AC EQ CS 
SH SY SH SY SH SY 
SP t 4 ,SSS 
'" 
5, 152 
" 
17 ,208 71 
MU 6,696 92 6,696 92 16,653 90 
PP 33,124 1182 12 ,660 210 38,760 2" 
The test lengths for equidistant S-gmphs (EQ) are 
only a third of the test lengths for the more general 
acyclic graph (AC). On the other hand an acyclic graph 
needs only a half of the scan elements. This trade-off 
must be solved by the designer. Surprisingly, for al1 
circuits the largest teSI time is needed. using a complete 
scan path . 
Conclusions 
An efficient method has been proposed 10 scle(:l a 
minimal set of flip flops, which must be integmted into 
a scan path in order to guarantee testabili ty. For the 
modifi ed. circuits, an ATPG-algorithm has been devel-
oped, providing complete fau lt coverage with respect 
to all irredundant faults. The proposed design and test 
method leads to lower hardware overhead and to shorter 
test times, thus reducing Ihe overal1 test costs. 
References 
I. V.D. Agrawal, K. Cheng, D.O. Johnson, and T. Lin, "A complcte 
solution 10 the partial scan problem," Proc:. IEE£ lruem. Tts/ 
Con! , pp. 44-51, September 1987. 
2. V.D. Agl3\\a1 , K.-T. Cheng, D.O. Johnson, and T. Lin, "Design. 
ing circuits with partial scan, IEEE lHsi8" &; Test Ccmput. 6 
(2) : 8- 15, 1988. 
3. M.l.Y. Williams and J.B. Angell, ··Enhancing Icstabj]jty of large 
scale integrated circuits via lest poiNyl~ nnd additional logic," IEEE 
Trans. Compul. C-22 (I), 1973. 
4. R.G. Bennetts, Design ofTeSlablt lbgic CifCllilS, Addison-Wesley, 
London, J984 . 
174 Kunznumn and Uimderlich 
5. J.1. LeBlanc, " LOCST: A built~in self-tcst te<:hnique;' TEEE 
Design & Tim Cmnpu/. 1 (4): 45- 52, 1984. 
6. K. Cheng and V.D. Agraw.d, ':An economical sean des ign for 
sequential logic tesl generation," Proc. 191h In/em. S)mp. rollI/-
Tolerant UJmplI/., pp. 28-35. June 1989. 
7. N. Christofides and S. Korman, ''A romputational survey of meth-
ods fo r the sct <:overing problem, Monagement Science 21 (5): 
591- 599, 1975. 
8. A. Ehrenfeueht, L. Fosdi<:k, and L. Osterwcil , "An algorithm 
for finding the elementary circuits of a directed grapb," Tech. 
Rep. CU·CS-024-23, Dept. of Computer Science, Univers.ity of 
Colorado, Boulder, 1973. 
9 . E.B. Eichelberger and T.w. Wllliams, ' 'A logic dcsign structure 
fur LSI testability," Proc. 14/h ACMIlEEE Design AulOm. Conf, 
pp. 462-468, 1!177. 
10. A.D. Friedman and P.R. MellOD, Theory and Design qfSwitching 
Circuits, Computer Science Press, Rockville, MD, IW5. 
II. H. Fujiwara and T. Shimono, "On the acceleration oftcst genera-
lion algori~" Proc. 13lh Intem. S)mp. fimf1-7bleranJ Complll., 
pp. 98-105, 1983. 
12. M.R. Garey and D.S. Johnson, Computf!rS and Intmctability: 
A Guide 1C the Theory of NP-compkteness, W.H. Freeman, San 
Francisco, 1979. 
13. R. Gupta, R. Gupta, and M.A. Breuer, "8A.LLAST: A methodol-
ogy for panial scan design," Proc. 19th Intern. S)'lIIp. roult-
Tolerrmt Compll/. , pp. 118-125, 1989. 
14. P. Goel , ' "An implicit enumeration algorithm to generate IeSfl; 
for combinational logic circuits," IEEE Trons. CompUJ. C-30 (3): 
215-222 , 1981. 
15. L.H. Goldstein, "Controllability/obscrvability analysis of digital 
circuit~I" lEE£ Trans. Circuit.~ and Systemr CAS-26 (9): 685-
693, 1979. 
16. P. Gutberlet, "Enlwwf cines schnellen Matrizen-MuJtipliziercrs," 
Siudienarbeit Fakuhiitlnfonnutik, Univel"Sitiit Karlsruhe, 1988. 
17.0. Haberl, " Entwurf und Implementierung e ines PROLOG-
mreproze.~sors als St:mdani1.ellen-Chip mit dem bntwurfp~FDptem 
VENUS," Diplom.arbeit an der FaJru1tii\ Infonnalik, Universiliit 
Karlsruhe, 1986. 
18. 1. Hanmanis, "Loop-free structure of sequential machines," Infor-
mation (lIId Control (5): 25-43, 1962. 
19. D.B. Johnson, "Finding all the elementary circuits of a directed 
graph," SIAM J. Comput. 4 (I): 77-84, 1975. 
20. R. M. Karp, "Reducibility among combinatorial problems," In 
R.E. Miller and 1.w. Thatcher (ros.), Complexity o/Computer, 
Computations, Plenum Press, New Yorl:: , pp. 85-103, 1m. 
21. A. Kunzmann, Verbesserung der Testbarkeit von Schaltwerken 
dureh die Integration eines unvollstandigen Priifpfades," Interner 
Berieht 251ffl, Universitit Karlsruhe, Fakultit rur Informalik, 
Okl(lber 191i7. 
22. A. Kununann, "Produktionstcsl mit detenninlstisch bestimmten 
Tcstmustem: der Thstmlll>'lergenerator SPROlIT,"' [ntemer Berieht 
2611i7. Universitiit Karlsruhe, Fakultiit rur l nformatik. Oktober 
191i7. 
23. A. Kunzmann, ProdukiiOllstes/ S}1iChroru!r Scfulltwerke au/ der 
Basis mn Pipeline-Stukturen, G I·JahrcSlagung, Hamburg, 1988. 
24. A. Kunzmann, "Test syn<:hroner Schaltwerke auf des Basis 
panieller Priifpfade," VDl-Verlag , Fimschriu-Ber;chte 10 (117), 
Dusseldorf, 1989. 
25. A. Kunzmann and H.-J. Wunderlich, "Design automation of ran-
dom testable circuits," 11th Europl!un Solid Statl! Circuits Conf 
(ESSCIRC), pp. 277-285, 1985. 
26. ETA USAR Users Guide, Vers. 4.7, November 1985. 
27. H.T. Ma et al., ''An incomplete scan design approach to test gen-
eration for sequential ma<:hines," Proc. III/em. Test Conf , pp. 
730-734, 1988. 
28. P. Mutb, ':A nine·vaIued circuit model for lC8t generation," IEEE 
TrollS. UJmp. C-25 (6); 630- 636, 1976.. 
29. J.P. Roth , "Sequential test generation," Technical Disclosure 
Bull. , mM, January 1978. 
30. M.H. Sehulz and E. Auth, "SOCRATES: Advanced automatic 
test pattern generation and redundancy identification Icchniques," 
Proc. 18th Intern. Symp. Fault·tolerant UJmput., pp. 30-35, 
Thkyo, 1988. 
31. M.H. 5<;hulz, E. Trisch1er, and T.M. Sarfert, "SOCRATES: A 
highly efficient automatic lest pattern generation system," hoc. 
Intern. Test Conf, 1987. 
32. R. Tatjan, "Enumeration of the elementary cin:uits of a directed 
graph," SIAM J. Comput. 2 (3): 211-216, 1973. 
33. J.e. TIeman, D~n efficient seard1 algorithm to find the elementary 
eircuii~ of a graph," Comm. ACM, 13, pp. n2-726, 1970. 
34. E. Trischler, "Testability analys is and incomplete scan path," 
Proc. lmern. Conf Computer-Aided De,rign S, pp. 38-39, 1983. 
35. E. Triscbler, '1ncomplcre scan path with an automatic test genen:t-
lion methodOlogy," Proc. Intern. Test Conf, pp. 153-162, 1984. 
36. H. Weinblatt , ''A new $Catch algorithm fur finding the simple 
cycles of a finite directed graph," 1. Assoc. Comput. Mach .• 19: 
43-56, 1972. 
37. H.-J. Wunderlich, "PROfEST: A tool for probabi listic testability 
analysis," Proc. 22th Design Autom. Conf, pp. 204-211 , 1985. 
38. H.-J. Wunderlich, "On computing optimized input probabilities 
fOr random tests," Proc. 24th iksign AU1om. Cml/., pp. 382-389, 
1987. 
39. H.-J. Vl'lmderlich, ' 'The design of random-testable sequential cir~ 
cuits," Proc. 19th Intern. Symp. Rmlr-1blemnt Comput., pp. 
110-111, 1989. 
Arno B. Kunzmann received the diploma degree and the Dr. reT. 
nat. (Ph.D.) degree in romputer science from the University of 
Karlsruhe, in 1982 and 1989, respectively. 
Since 1983 he has been with the Institut for Computer Design 
and Fault Tolerance at the University of Karlsruhe, cxcept the years 
1985 and 1986, when he v.urked at the Computer Science Rt:scareh 
Cenler Karlsruhe (FZI). During the first five years, his research was 
roncentrated on the design and synthesis of integrated drcuits. His 
current activities in research arc concentnlted on design fortestability 
methods and algorithms for deterministic test pattern generation. 
Hans-Joachiul Wunderlich received the diploma degree in mathe-
matics from the University of Freiburg, F.R . Germany, in 1981, and 
the Dr. rer. nat. (ph. D.) degree from the University of Karlsruhe 
in 1986 
In 1982, he was a consultant at the Fraunhofer-Institutc of indus-
trial Engineering, Stuttgart, where he v.urked in the field of operations 
research. In 1983, he joined the Institute of Computer Design and 
Fault Th1erance, University of Karlsruhe, where he has been the head 
of a re.<;earch group on automation of drcuit des ign and teSting since 
1986. His rc.;carch interests include oomputer-aided design for testa-
bil ity, lest generation, and digital simulation. 
