Design of automata theory of cubical complexes with applications to diagnosis and algorithmic description by Roth, J. P.
61S16
suot^ieoT-[ddv
ssenxsng
jo
86SOT UOS^BA\. "f
sauit[OT3]A[ sssmsng
HXOH
U
*d T
01
HXIM saxaiawoD i?DignD 10 XHOSHI
10 HSISaa (88£Oet-HD-VS?N),
jo
sap
https://ntrs.nasa.gov/search.jsp?R=19730005474 2020-03-23T06:06:02+00:00Z
'J
Ig
o
rit
h
m
«i
a
1
•o
5
e
ou.
W»
X>
'i&
a
0
28
U)
jf
4
o
44
1
44
44
U
o
og
•s
x
a§
•S
*•
&
VI
•§
4)
g
jj
O
T3I
o
•d
tfi
• H
I
&
•H
<rt
•O
•S,
o
l/>
•H
.g
I/)
3
<s
ato
tu
4^
V
V)
2
3
V)
Vt
X
B
o
VI
a
£
O
£
4)
oo
co
£
4J
CO
Vt
44
U
•3
4)
•s
•o
a
g
1
1
4>
••s
1
0
VI
4)
44
O
4)
X
44
r^t
44
*3
3
B
X
•a
Q
vt
•8
CO
•8
t 
c
e
rt
a
in
 
fe
<
3
O
vt
1
44
44
CO
&
..-4
V)
-8
•1-1
U
x<?
ro
n
o
i
•g
1a
•s
vt
S
CO
D.
CO
44
rt
C
4)
X
44
V
X
O
n
S*
u
X
44
44
x
44
o
VI
4)
c
!
•H
2
rt
§
.5
je
ne
ra
te
s
1
44
I
V)
3
41
X
£
-
O
V)
5-
4}
•S
44
1
i/i
e
0
«j
*j
3
c
.H
jp
lif
ie
d
c
ir
c
u
it
,
 
s
in
•-*
.5
bo
O
V
x44
o
4)
•o
•o
4)
• H
<4-t
**H
(X*
B
•H
VI
VI
• H
44
<2
V)
44
VI
V
44
V
44
d
'i
• H
&
44
VI
O44
X
44
VI
5
0
rt
xTJ
43
Q*
c
44
44
O
4)
V)d
4)
Vt
4)
d
•H
»••
Sc
JB
e
 
r
e
a
li
s
ti
c
 
c
hi
rt
d
w
•H
0
4>
X
d
•H
«
44
rt
d
4)
V)
4)
CX
4)
O
rt
•o1
1
N
n
x
T3
i
lo
ca
te
 
ra
c
e
s
x
•H
i
O
44
re
3
S
VI
s
"
g
44
3
O
•ad
•H
O
44
4)
"2
O
£
:h
e
 
pr
im
ar
y
p
a
tt
e
rn
s
 
to
 
t
0
4)
U
g
cr
4>
VI
re
•H
CO
4)d
&
d
•5
i
VI
4>
44
U
X
44
£
a
n
d 
a
n
o
th
e
r
be
 
di
sc
ar
de
d
44
§
x44
4>
2
rt
x
44
3
U
(4-1
O
VI
.s
4)
<+_
O
H
• H
V)
X
44
to
a
ilu
re
.
u
4)
X
44
O
s
«2
V)
rt
4)
i-
o
u
o
44fr
93
44
a
:"
 
h
a
rb
or
s
 
.
o
te
n
ti
a
l 
te
s
t
P-
•s
i
X
44
'a
x
ud
4)
D
O*
4)
£
4)
X
44
V)
4)
4)
h
U
•H
1
•d
O
W.
6
V)
4>
V)
O
rt
Q
TJ
U
&
ifl
•8
O
•§
X
4>
I/I
4)
£
C
•H
Vt
4)
U
2
o
o
VI
•8
4)
X
!
3
tJ
o.
rt
V)
•H
B
44
U
4»
VI
VI
•H
X
44
C
•H
"O
4)
•H
h
U
Vt
•8
§
O
6
fu
rt
h
e
rm
o
re
,
c
ti
o
n
;
1
X
4)
N
£
CO
O
44
4)
2"
VI
(A
8.
44
•H
•s
•H
i
.S
•s
44
•H
U
•H
44
§
o*
4)
V)
4)
V)
4)
X
44
O44
1§
4)
B
X
44
• H
6
rt
0)
x
44
5
§
D.
a
VI
•H
O
•g
V)
(4-1
•H
g
3
3
<*4
*
<8
44
V)
4)
44
rt
4)
44
3
&
1
"3
i
yj
Ot
rt
44
VI
X
VI
4)
**
• T»
0
Ji
"5I
o
1
44
Vt
0
VI
•S
•^H
VI
O&
rt
X
0
1.
u
x
o
+41
fc; U Pb x S
< 01 2
u. o. 8
o Z j
>-» J Z
Ul < <
UU UQ — i/j
68
u.5
o o
H H
vi U rt c
wjr o v ^ c <u "Oc w + j * 4 ( - - o T 3 J = 5 5 n
•^ — V, £ E 4-
o B *-> o o ' a x n —
—• *- X VI 4-1 44
O .C -H — O v, — "O -
4 ) U O £ 3 - ^ o i 4 J ^ t
^ o ^ ^ vi f« g v. cj re vi •«
44 4-1 (fl 3 . C U D * - '
**•* w w A: 44 -c
x d 4) •*-* x ^ *d t * -4 4 C X V I *-*-• c d n o
.« .« O * tJ CM jC; C W, r-
a v i x d d * — ' i - - O v .
•O-o .^ - • ^ w o o o c
0 ) O £ V 1 * - i O *J O V V )
u o d u — > u r t x 4>"-
O O J O C O I - O O E O . - ' - '
c >. rt d o w u:iu *-> j^ o c •— • v-i E d
4 J d X M O 3 j j -^
.a g u 44 c •- .0— v. q
x -H vi -^ 3 v; *— c c:
d > o ^ > e a > a o x
O O ( X 3 4 ) O M — ' U U U
oo o l*-1 *4 -C *— ' ra v f~
*4 — x a — u- c b —
« V, d ofl t/j -•-> «-H 44
> o n o - « - ^ r t r e cd - c x ^ - p M r e — « * - i 3
vi S .c u •- •— -i — rt y
• r * U 4 - * C C 3 O C - r t 6 ^
^ 0 ^ * 2 ° E
• * .. S rt vi o ^r c o
H V 1 J = " " U U O c l JO 6 4 - 1 w r e o - — O ' " * o
f— JD o cx>rt CL -^ i-. u t*-*( O O O O f i tT — i O C
0 C O
•^ x vi
i 3 " -0
w
 o ^  iJ
x o u
"^?^
o • 3
> d 0 c
O — ' U
O "T3 U •—
•^ O fn 3
J D. 0 -«
T3 0 —
v- e
U VJ VI 44
0 rt c
o •*? S -^
> ft)
; 3 .M (J
o o o
t- O V.
O vj O
-3 rt rt x
0 — 3 wfc« <u o re
D. 2 43 X
O O CJ
i/i x) n o
•-• O C VI
i s §.<!§
- *J ^ -H 4-» E
— •- 4) 6 X O 0) w
ll°I|l|I-|le
« o o o c a c C 3 - 2 S ' S i 5
O — C *J X B X
c 4 > o r e 4 4 . H i / i v t
t. .« 0£ U -r« M X CO 44 Vt
0 h — *j .g t- O X — -^
rt4) 42 •-* G & . O V J ^
J2 — 44 O V * 4 V j Z ' ' - < O
"
-
^. > — * - - 3 H - ^
C O jl ^ • CX O
44 **- .M E X r-l fj -r4 - OU > *-> 4J ^ ~* X 44
£ «J c — i l< 3 X O - HVi— 3O CLV) B — ' 44
X 4 J • d i ' - - d ( 4 ^ 4 3 «44 *j a vi o — o •- c f l u
3 X * < H - * * 4 4 3 E OO J O
^ E - - ^ 4 4 n 3 C 44 •• * d M*
^i O O • •-•< S cfl — « -^ <J
y *j oj o E w ' * > t *S
^-,v> — * >. *j 41 O §
O r M - « — i r e O - - | T 3 * H 4 i
T) O U — « B U
— S 5i'd ™* S <*-• w w ^
rere'-' i- ' fOo " i to
.•^o^ i *£ « • ° § ^ W
O- u c U rfr>< 4 - i u Q >
> - < H O > C l O vi vt B U
£
O 44
u U
rt rtM u •
o u ajj a o
.sis(Q
a ti u
O 4) 44
•H -O W
« B -H
rH 9 d
3 -H
o. - So 44 -n
* u «?(X O
CL <U44 a u
4» 3 rt
*•» w a.
v>41
 v
X X *O
"" g
X X
43 *4 CO
Vl 44
re x 3
ct oo rt
o d
O M O
• H O Wd o
TJ X •<4) u
^ 4) «H
O H rt
U
 tw °
0 *O -S
(X 44
•4 Z
C 3
W -H X
4O 44 44
« G «-(
X
T
h
is
 
w
o
rk
C
a
lif
o
rn
ia
NA
S 
7
-1
00
,
w
*-<* 41
r* u
S PJ S
»M t-\ O
•**• c/t
- /^ ^-t 4)
CO nH 3
Diagnosible Design Form may !>• described with reference to the
figure below. The basic configuration consists of a bank of latches
!
- call them registers - Rl which arejgated at time Tl. This Rl feeds
acyclic logic U (hence combinational logic) which is followed by a
bank of registers R2 gated at tine T2. Feedback is allowed from R2
to Rl. R2 In turn is followed by a section of acyclic logic L2, followed
by registers R3 gated at time T3 with feedback allowed from R3 to R2
i
or Rl. The difference T2 - Tl is chosen large enough so that all
i
changes in the acyclic logic have taken place fross ~l gating Rl before
T2 is activated etc. Thus all races'hazards are, by design, eliminated.
Our only remaining task is to show that the D-algorithm slightly
modified may be easily adapted to computing tests (a deterministic test)
i
for a given testable failure Fl. Ini the first place, it may be noted that
I
the obvious place to cut the feedback loops is from one bank of registers
i
to another, thus there is no complicated choice which must be made.
iiii
It was stated that it could be guaranteed that the D-algorithm
would compute a "deterministic" test for a given failure if one existed.
By deterministic is meant that the tests, in general of sequences of
I
input patterns, do not depend upon the signal in the feedback loops
(state variables) at the time of application of the tests. One would
i
have also to compute "D-sequences" and "singular cube sequences" for the
latches, a trivial one-shot computation, and make sure that only such tests
were used in the generation of a test.
The D-algorithra for the DOF will be termed DALGS.
Section 2. Heuristics for DALC
The computation for a "covering" ensenble for tests for very
large circuits (say the order of 10,000 devices) become significant.
The following two heuristics are offered with the purpose of reducing
the computation. The first step in the procedure to compute an ensemble
of tests to detect any failure of a given category in a logic design
is to select a failure out of this given category. The first heuristic
is a method for malting such a selection. The procedure starts as follows:
a failure for a primary input for the circuit is first chosen (we do
not have a criterion for selecting among the primary input failures).
One then uses the D-algorithm (or some variant or equivalent thereof)
to compute 'L test for this failure. One then uses TESTDETECT to ascertain
all failures detected by this test (in general a sequence of input patterns).
One would wish to maximize the number of failures detected by a given
test for this tends towards minimizing the total number of tests computed
and hence minimizing the total computation. Thinking of the D-algorithm
in terms of the D-chains developed in generating the tests, for a failure
originating in the primary input (a PDCF) this chain drives through the
entire logic and it can be shown that any line on this D-chain will be
tested in one mode or another by this particular test being generated:
for this choice the D-chain tends to be as large as possible since
it is generated for a prinary input. Next one selects some primary input
failure not yet tested if such exists, and repeats the same procedure.
If no such primary input failure untested by the tests computed to date
exists, one next selects a device fed by primary inputs and goes through
the same procedure etc., until an ensemble of tests has been computed which
covers all failures of the category agreed upon in advance.
• It is estimated that the number of tests required by this mode
of computation as opposed to the "counter strategy" of starting with
the primary output failures and proceeding backwards to the primary input
failures would be about 1 to 2.
The second strategy is a simple one which in complicated control
circuits might be extremely helpful. For some of these circuits a sequence
of reset input patterns is originally applied in order to render the
design into a known and desired £tate. The strategy followed is thus
to first apply the sequence of reset inputs which is known, and then to
derive the D-chain emanating from the failing device in the usual way:
this imposes a constraint on the development of the D-chain. It is
likely that the D-algorithm even with this constraint will compute a test
if it exists for the failure. Indeed it may be that it is necessary
to apply the reset input sequence before one is able to get a test; the
D-algorithm would not know this in advance and thus might take a great
deal of tine in generating the test if indeed it had enough computation
time so to do. It is expected that this short-cut will substantially
speed up computation tine. The exact algorithm would then be followed
by this and used only if the heuristic did not yield a test.
I
Section 3. Cyclic TESTDETECT I
In the computation of an ensemble of tests to detect any failure
of a given category in a logic design the procedure is usually as follows:
(1) select a failure from a given (category of failures and compute a
I
test for it (e.g. by the D-algorithn) (2) use a simulator to determine
i
all failures of the given category! which are detected by this test.
j
This procedure is continued until a te.st ensemble has been obtained
which detects all the prescribed failures (or one has reached a certain
i
aodicua of completeness or "coverage", say 85*).
|
The bulk of computation time is in the simulation, perhaps
by a ratio of at least 100 to 1. j
TESTDETECT was developed U| a~"l-pass" simulator to determine
all failures detected by a given test. It was designed originally for
acyclic (combinational) logic. It|had not been seen how to the generalize
I
TESTDETECT to the general cyclic circuit case. A study of the Diagnosible
i
Design Form, however, shows that i f ' the logic design is clocked by a
clock having at least two phases then it is rather simple to extend
I
TESTDETECT to cover DDF-logic.
In order to describe cyclic TESTDETECT we will first reviewi
how it works for acyclic logic. Assume that we have a test consisting
of a single wave of patterns applied to the primary inputs of the circuit.
First one computes the signal on each line (device) in the logic design.
Let us now look at the primary output. If a given output has a "0" assigned
to it for this input pattern, then clearly it is tested for stuck-at-1.
Likewise if it has a 1, then it is tested for stuck-at-0. Assume that
a given primary output is a 2-input OR with inputs 1 and 0 respectively.
It is clear that the line with input 1 is tested for stuck at 0 whereas
the input with value 0 will not be tested by this input pattern. We
proceed in this way from the primary outputs ascertaining whether or
not the line (device) is detected in its failure by this test, passing
through the entire circuit to the primary input. This is thus a 1-
pass-type of simulator. TESTDETECT for the acyclic case has been programed
in APL and run extensively. (Roth, Bouricius & Schneider, 1967)
TESTDETECT takes the order of n steps for a piece of logic having
n devices. A simulator requires n steps: for each failure one must
determine the signal on each line of the circuit: n failures multiplied
by n devices equals n .
Now we will outline the procedure for the case of the cyclic
circuit and use the figure 2 as an illustration. Initially we assume
that all lines have a signal which is unknown - let this condition by
represented by the symbol x. In th« case of cyclic logic the test
will in general be a sequence. Assune that we apply the first input
pattern to the primary inputs with all other lines being x. In general.
some lines will be determined immediately by this primary input pattern.
On the other hand there will be sone for which this is not the case,
for example, suppose that a given line is the output of an OR with two
inputs, one having the value x and other, the value 0. Figure 2 shows a
cyclic circuit (the registers required for DDF are omitted for simplicity).
Figure 3 shows cyclic TESTDETECT operating for the first input pattern
tl. Figure 4 shows it for the second t2.
The general procedure is as follows:
(1) The resulting signal 1 or 0, on each line if determined by tl
is computed; if not determined, it is assigned to value x. Clearly
the input pattern can test no line assigned x.
(2) One then reasons backwards from the primary Output lines (here
only line 10): if the test pattern causes a signal a, a - 0 or 1, on the
PO line, then clearly this line is tested for the failure stuck-at-a.
(3) Having determined failure detection for the PO lines, we next
examine the lines 1 feeding PO blocks (lines). If the PO block is an
OR or NOR then t is tested only if the signals on all other inputs to the
block is 0; if an AND or a NAND, then all other lines feeding the block
oust be 1. If such a line is testable then it is tested for T if t induces
* signal a on 1.
(4) This procedure is pushed level by level. If a line fans out to
more than one block then one must, as with acyclic TESTDETECT, proceed
forward from the line to the point(s) of reconvergence. Nevertheless
the process is very rapid.
(5) Having made the determination for the signals 1, 0 or x which
the first input pattern causes, plus the ensemble of failures detected
by tl, one similarly applies the second input pattern t2 to determine,
together with the signals established on the feedback loops by tl, the
signals induced on the lines, together with as above, the failure detected
by t2-preceeded-by-tl.
(6) One continues similarly through the entire given sequence of test
patterns, tl, t2,..., to determine all failures detected by this test.
410'
e
10
-*»
CYCLIC
X
f / ei
eu
i ' > i/i
n.
L*-
VA.
0
/
u. l
f6
7
U.
— ^ /i 8o
oi
PJ
L- *
— *•
Y
 {
0
tiw
to
O
'*r ^
B -^
$kc(~a,t-o
5
v
