This paper considers the design of an efficient, robustly testable CMOS Totally Self-Checking (TSC) Checker for fc-out-of-2fc codes. Most existing implementations use primitive gates and assume the single stuck-at fault model. The self-testing property has been found to fail for CMOS TSC checkers under the stuck-open fault model especially due to timing skews and arbitrary delays in the circuit. A new four level design using CMOS primitive gates (NAND, NOR, INVERTERS) is presented, which retains its properties under the stuck-open fault model. Additionally this method offers an impressive reduction (> 70%) in gate count, gate inputs and test set size when compared to the existing method. This implementation is easily realizable and is based on Anderson's techniqueflj. A thorough comparative study has been made on the proposed implementation and Kundu's[8] implementation and the results indicate that the proposed one is better than Kundu's[8] in all respects for fc-out-of-2fc codes.
2.2.2
inadequate [9] , Kundu and Reddy [8] have proposed a four-level realization of robust CMOS TSC checkers for fc-out-of-2fc, fc-out-of-2Jb + 1, k + l-out-of-2fc + 1 and k + l-out-of-2fc + 1 codes. However, a robustly testable complex gate realization of TSC checker is yet to be reported. The main contribution of this paper is the design of a four level robustly testable CMOS TSC implementation based on Anderson's technique for fc-out-of-2Jb codes. This offers considerable savings (> 70%) in gate count, gate inputs and test set size over the existing method.
Notations and Definitions
This section summarizes the notations and definitions used in this paper. The notation used by Kundu and Reddy [8] and Anderson and Metzefl] will also be followed here. A few of the notations are as follows:
A: set of all valid m-out-of-2m code words, vertex: binary word, n-vertex: binary word with n ones. /, g: outputs of the TSC checker. f\'. subset of A such that /i=l and g\=0 for any input from f. g\: subset of A such that /i=0 and g\=l for any input from g. < Ti,Tj >: two pattern Stuck-open fault test.
TI : initializing input for the stuck-open fault test. Tj : test input for the stuck-open fault. T(k a > *) : majority function which is true if the number of ones in the vertex k a is greater than t.
Definition 1 A circuit is self testing if for every fault from the fault set, the circuit produces a noncode output for at least one code input.
Definition 2 A circuit is fault secure if for every fault from the fault set, the circuit never produces an incorrect code output for every code input.
Definition 3 A circuit is totally self checking if it is both self testing and fault secure.
Definition 4 A binary n-tuple is said to 1-cover (0-cover) another binary n-tuple if the former has ones (zeros) in every position the latter has ones (zeros).
Definition 5 A vertex X is a true vertex of a function F iff F(X)=1.
Definition 6 A true vertex V p of a function F is called a minimal true vertex iff there does not exist another true vertex Y of the function, Y ^ V p such that V p 1-covers Y.
Definition 7 A 0-cofactor (1-cofactor) of order n of a product term of uncomplemented variables is obtained by substituting n zeros (ones) for n ones (zeros) in the product.
2nd NASA SERC Symposium on VLSI Design 1990
2.2.3
If a minimal true vertex V p has n literals and if a 1 at position k of V p is changed to a 0 to obtain a 0-cofactor of V p it is denoted by Definition 8 A 0-cofactor (1-cof actor) is a false (true) vertex.
Definition 9 A hazard is defined as the appearance of an undesired logic value (transient) at the output of a circuit which is produced due to one or more changes at the inputs of the circuit.
TSC Checkers
Smith [13] and Anderson and Metzefl] have proposed the following conventions for TSC checkers;
1. All invalid code words of weight less than m are mapped to the checker outputs: / = 9 = 0.
2. All invalid code words of weight greater than m are mapped to the checker outputs:
3. All valid code words of weight equal to m are mapped to the checker outputs: / = 1, g = 0 or / = 0, g = 1.
Let F be a minimal sum of products expression realized by a two level NAND-NAND logic network N, where the first level gates correspond to the minterms of F. Then we have the following properties.
Property 1: If a minimal true vertex V p is input to N, then the output of the circuit and the outputs of all first level NAND's except the gate covering V p are 1.
Property 2: // V p (k), a 0-cofactor, is input to N, then the outputs of all first level gates are 1 and that of the second level gate is 0.
Property 3: // a two pattern input sequence < V p , V p (k) > or < V p (k), V p > is applied to N, then only one input to any gate changes. Furthermore, the outputs of all first level gates except the one covering V p are 1 (hazard-free) for both inputs in the two pattern sequence.
Property 4: // a two pattern input sequence consisting of two 0-cofactors of different orders is presented to N, such that one 0-cofactor covers the other, then the output of every first level NAND gate and the second level NAND gate is 1 (hazard-free) and 0 (hazard-free) respectively for both inputs in the two pattern sequence.
Property 5: If a two pattern input sequence consisting of a true vertex and a 1-cofactor or two 1-cofactors of different orders, such that one 1-covers the other is applied to N, then there exists a gate whose inputs are all 1's for both inputs in the two pattern sequence implying that the output of the second level NAND it always 1 (hazard-free) for both the inputs.
Kundu's Technique
This technique yields a four level implementation which is robustly testable. Here the kout-of-2& code is partitioned into subsets f\ and g\ according to Smith's Criterion [13] . The checker outputs / and g are then expanded with respect to an input variable x,-, chosen arbitrarily such that, / = *ifn + fn
where f lit / 2 ,-, / lt -, / 3t -are functions of the variable z, through x n excluding z,-. The functions /it> /2», and /i,-, /2i« are realized by NAND-NAND and NOR-NOR circuits respectively. This design is hard to realize for large values of k and also necessitates the use of a large number of gates with very high fan-in.
Anderson's Technique
To design a fc-out-of-2fc TSC, the 2k input bits are first divided into two groups of equal length (n a = n& = fc). The checker output functions / and g are realized as follows:
where A; a and k b will refer to the number of 1's occurring in each group. This technique was limited to two level realization using AND and OR gates and was developed under the stuck-at fault assumption. Under the extended fault model the self-testing property, which is a necessary condition for a circuit to retain its TSC properties, is difficult to satisfy for TSC CMOS circuits. In fact, it was shown by Manthani and Reddy [10] that a two level realization of Anderson and Metze's TSC checker[l] is not robustly testable. We now proceed to present a four level CMOS gate implementation based on this technique.
CMOS Checker Implementation
First we present a robustly testable CMOS checker design using primitive gates. Proof: Consider the expressions for / and g:
..... if k is even.
Each of the different implementations of / and g when k is even or odd will be considered separately for proving the circuit's robustness during testing. Chandramouli 
Realization of g when k is even
Consider the realization of g with k even. Each majority function, T(k a > i) |i^i,fc and T(k b > t) |,-#1>fc , is realized by two levels of NAND gates. The third level NAND gate realizes T(k a > i)T(kt > k -i) and the fourth level NAND gate realizes g. To simplify the proof, the whole circuit is partitioned into a finite number of subcircuits and then each one of these subcircuits is shown to be robustly testable.
Circuit corresponding to any T(k a > i)T(ki, > k -i) Consider an arbitrary lead y of any first level NAND gate corresponding to T(k a > i). Each first level NAND corresponds to a true vertex of the unate function T(k a > i). Select a two pattern test < V pt V p (y) >. The test vector V p is chosen such that all the i leads of the gate are 1's during 7\ implying that the weight of n 0 is t and that of nj, is k -i. V p (y) applies a zero to the input y while all other inputs of this gate remain at 1, so that the weights of n 0 and n& are i -1 and k -1 + 1 respectively. According to Property 3, the second level NAND gate is sensitized robustly (all the sensitized leads remain at one during TI and Tj). Since V p and V p (y) are 0-cofactors of the majority functions T(k a > p) | p >;+2> all the other inputs feeding the fourth level NAND are 1 during the test sequence < V p , V p (y) > and are hazard-free. Also the output of the second level NAND, T(k\, > k -t), is 1 and is hazard-free. Hence, < Vp, V p (y) > is a robust test for ISOP on the lead y. Similarly the reverse sequence < V p (y),V p > forms a robust test for OSOP fault corresponding to the lead y. In a similar manner, it can be shown that any input/output stuck-open fault corresponding to the first level NAND gates of the majority functions T(k\, > k -i) can be robustly tested.
Circuit corresponding to T(fc& > k) term
The term T(k(, > fc) corresponds to a single k input NAND from which an arbitrary lead u is selected. The test pattern < Vp, Vp(u) > is then applied. The test vectors are such that weights of n 0 are 0 and 1 and that of nj, are k and k-1 during TI and T 2 respectively. Since the weight of n a is never greater than 1, during the test sequence the outputs of all second level NANDs corresponding to T(k a > p) | p >j are 0 and hence the outputs 2nd NASA SERC Symposium on VLSI Design 1990 2.2.7 of all third level NAND's are 1 (hazard-free). Also the output of the gate corresponding to T(k a > k) is a 1 (hazard-free) during the test sequence. Since no transients occur in the circuit, the test pattern < V p , V p (u) > is a robust ISOP test for the lead u. Similarly, < V p (u), V p > is a robust OSOP fault test corresponding to lead u. On the same lines, it can be shown that the input gate implementing T(k a > k) is also robustly testable.
Realization of g when k is odd
This implementation is similar to the implementation of g when k is even. As usual, the terms T(k a > k) and T(k at T(k b > i) | i#1 are realized by NAND gates except T(k b > 1) which is realized by a k input NOR gate.
Circuits corresponding to any T(k a > i)T(kb > k -i) |^j, and T(k{, > k)\k^i
The arguments when k is even are also valid here. Hence, these circuits can be robustly tested.
Circuit corresponding to T(kb > 1)
Consider an arbitrary lead m of the NOR gate corresponding to T(fcj, > 1). A two pattern test < U t , U,(m) > is selected such that U t applies 0 to all k leads of the NOR gate such that weight of n& is 0 and U t (m) applies a 1 to the lead under question and 0 to the rest of the leads. Since the weight of n& is 0 and 1 in Ii and Tj respectively, the output of all second level NAND gates corresponding to all T(kb > p) \ p >j is always 0. Hence the outputs of all third level NAND gates except the one corresponding to the NOR gate under consideration are 1 (hazard-free) during the test sequence. Also the output of the NAND gate corresponding to T(kb > k) is 1. Hence, the test sequences < U t (m), U t > do not suffer from test invalidation. So, the circuit is robustly testable.
Realization of f when k is odd
This case is similar to that of g when k is odd. Hence using arguments similar to the one where k is odd in the realization of 0, it can be shown that the circuit is robustly testable.
Realization of f when k is even
The majority functions T(fc 0 > 1) and T(kt > > 1) are implemented by NOR gates while the other majority functions are implemented by two level NAND logic.
Circuit corresponding to any T(k a > i)T(kb > k -i) |i^i,fc_i
The arguments corresponding to the case when k is even in the realization of g are valid here. Hence this circuit is robustly testable.
Circuit corresponding to T(kb > 1)
The arguments corresponding to the realization of g when k is odd are valid here. Hence this circuit is robustly testable.
Circuit corresponding to T(k a > 1)
2.2.8
Using arguments similar to the case of T(fc& > 1), it can be easily shown that this circuit is robustly testable. QED.
The following example will demonstrate the design of the proposed TSC checker.
Example 1 Design a CMOS TSC checker for a S-out-of -6 code using Procedure 1
The six input bits are partitioned into two groups: AI = (01,02,03) and A^ = (04,05,00) where o^oj,. . . ,a* represent the input code bits. The expressions for / and g are given by:- The majority functions T(k a > 1) and T(Jbfc > 1) in the realizations of / and g respectively are implemented using NOR logic while the remaining majority functions are implemented using NAND logic as shown in Figures 1 and 2 . This four level implementation can be robustly tested using the guidelines presented in [3] .
Comparisons
As mentioned before, there is only one method [8] currently available, for the design of robustly testable CMOS TSC checkers wherein the cases of fc-out-of-2fc, k -l-out-of-2fc + 1, k + l-out-of-2fc + 1 and fc-out-of-2fc + 1 codes have been covered. The proposed method covers the case of k-out-of-2k codes. A comprehensive study of the number of gates used by our method and Kundu's method [8] has been made and general relations have been established which are shown in Tables 1 through 4 . Table 5 illustrates the comparison between the proposed and Kundu's met hod [8] for k=2, 3, 4, 5 and 6. The comparisons have been made with respect to gate inputs and test vector pairs. Figures 3 and 4 illustrate the percentage savings in test vector pairs and gate inputs respectively with increasing values of k. These graphs show an almost exponential nature with about 32 % and 60 % savings in gate inputs and test vector pairs for even the trivial case of k -2 and increases to well over 90 % for cases k > 6. The tremendous increase in gate inputs is not only a result of increased number of gates but also gates with high fan-in index. For a typical case of 5-out-of-10 code TSC checker, Kundu and Reddy's method [8] uses 258 gates with four gates having a fan-in of over 60. On the contrary, the proposed design uses 102 gates with 3 gates involving a maximum fan-in of 10.
Testing of the circuits as designed in [8] is complex and offers fewer choices of test vectors for testing a stuck-open fault, where as the proposed one is easily testable and offers more choices of test vectors for testing the same fault. Also, the probability that a fault is tested sooner is high. Assuming a random occurrence of test vectors, the probability 2nd NASA SERC Symposium on VLSI Design 1990 2.2.9
distribution that the circuit is tested is multinomial in nature . It can be easily shown that the probability of the proposed realization being tested completely in a shorter period of time is considerably more compared to Kundu and Reddy's realization [8] . Also, the waiting time is considerably less.
The proposed design is very simple and has been acknowledged by various researchers in this field. The partition of all valid code words into f\ and / 2 as described in [8] is a bit tedious for larger values of k. Additionally converting fa, fa into the product of sums form from the sum of products form is highly cumbersome and laborious for larger values of k (> 4) . No such Boolean simplification is needed for our realization. Also, the proposed design is very simple and is based on Anderson and Metze's technique[l], the simplicity of which has been acknowledged by various researchers in this field.
As opposed to our method, the amount of fan-in of the second level NOR and NAND gates in Kundu's method [8] is considerable and increases dramatically with k. Furthermore, the proposed method offers a large reduction in chip area because of the considerably fewer number of gates and gate inputs.
Conclusions
In this paper we have considered the problem of designing robustly testable CMOS TSC checkers for k-out-oi-2k codes. The robust testability criterion under the extended fault model has been achieved by following a four level implementation rather than the regular two level implementation. A comparison between the proposed method and the presently available met hod [8] has been carried out and results tabulated. Savings of over 90 % in the number of gate inputs and test vector pairs have been achieved for even simple cases (k=6). The savings in the number of gate inputs and test vector pairs appear to be exponentially increasing reaching over 90 % for even small values of k (k > 6). The proposed design not only offers considerable savings in gates, test vectors, chip area, etc. as compared to the presently available method, but it also offers the benefit of simplicity of design.
Gate inputs
Test vector pairs Kundu 
