On TSC Checkers for $m$-out-of-$n$ Codes

V. V. Dimakopoulos, G. Sourtziotis, A. Paschalis, and D. Nikolos

Abstract—Paschalis et al. in [12] have given a structured method to design TSC $m$-out-of-$2m$ code checkers suitable for VLSI implementation. In this correspondence we give sufficient conditions so that the method given in [12] can be used to design checkers for classes of $m$-out-of-$n$ codes with $n \neq 2m$.

Index Terms—Fault detection, fault tolerance, MOS transistor implementation, $m$-out-of-$n$ code, totally self-checking checkers.

I. INTRODUCTION

The codes considered here are the well known $m$-out-of-$n$ codes which are useful in detecting unidirectional errors, a type of errors occurring frequently in VLSI MOS circuits. A code word of such a code has exactly $m$ 1s and $n - m$ 0s. In designing highly reliable systems, the totally self-checking (TSC) checkers play an important role as they are capable of detecting faults in the functional circuits they check, as well as faults in themselves. The concept of TSC checkers was introduced in [1] and formalized in [2] as follows:

DEFINITION 1. A circuit is self-testing for a set of faults $F$ if, for every fault in $F$, the circuit produces a noncode output for at least one code input.

DEFINITION 2. A circuit is fault secure for a set of faults $F$, if for every fault in $F$, the circuit never produces an incorrect code output for all code inputs.

DEFINITION 3. A circuit is code disjoint if, during fault-free operation, code inputs map into code outputs and noncode inputs map into noncode outputs.

DEFINITION 4. A circuit is a TSC checker if at the same time it is self-testing, fault secure and code disjoint.

Under the assumption of the stuck-at fault model, a number of TSC checker design methods have been reported for the general case of $m$-out-of-$n$ codes [2], [5], [6], [7], [8], [9]. The methods given in [2], [5], [6], [8], [9] are fully unstructured and thus they are not suitable for VLSI implementation. "Without the introduction of some structure, i.e., hierarchy and regularity, the problem of VLSI system design would be unmanageable" [14]. Efstathiou and Halatsis [7] have given a modular method to design TSC checkers for $m$-out-of-$n$ codes, however a large number of different modules are used and the implementation cost is excessively large [10]. Other structured methodologies to design TSC $m$-out-of-$n$ code checkers are not known from the open literature.

Structured methods to design TSC $m$-out-of-$2m$ code checkers have been given in [3], [4], [12], [13]. The TSC checkers designed by the methods given in [3], [4], [13] have a cellular form while the TSC checker designed in [12] has the form of a binary tree. The root is a TSC two-rail checker while any one of the leaves is a weight generator. The TSC two-rail checker can be implemented as a tree of two-variable TSC two-rail code checkers [15]. Any one of the weight
The key observation is that the CHA is identical to NHA, so that substituting CHAs for NHA's (and vice versa), at appropriate places, has the effect of adding the desired number \( p \) at the output of the adder tree.

### III. The Proposed TSC \( m \)-Out-of-\( n \) Code Checkers

Consider an adder tree \( T \), as those used in \([11],[16]\), that operates as an \( 1 \)s count generator. \( T \) has \( K > 1 \) inputs and \( k \) outputs \( a_{k-1}, a_{k-2}, \ldots, a_0 \), where \( k = \lceil \log_2(K+1) \rceil \), that is, \( 2^{k-1} \leq K \leq 2^k - 1 \). Each of the adders in \( T \) receives inputs of the same weight \( 2^w \) and produces an output \( S \) of weight \( 2^w \) and an output \( C \) of weight \( 2^{w+1} \), for \( w = 0, 1, \ldots, k-2 \). The output \( a_{k-1} \) comes from the \( C \) output of the (unique) adder that adds inputs of weight \( 2^{k-1} \), termed hereafter Most Significant Weight Adder (MSA). In case that \( 2^{k-1} \leq K \leq 3 \times 2^{k-2} - 1 \) the MSA is a half-adder, while in case that \( 3 \times 2^{k-2} \leq K \leq 2^k - 1 \) the MSA is a full-adder.

We consider that \( T \) is completely tested if any adder in \( T \) receives all possible input combinations. Depending on the value of \( K, T \) may not need the all-ones input in order to be completely tested. In fact, only a maximum \( L \) of ones with \( L < K \) may be enough. The following theorem gives a sufficient test-set for \( T \).

#### Theorem 1

Let \( T \) be an adder tree with \( K \) inputs (where \( 2^{k-1} \leq K \leq 2^k - 1 \)) that generates the binary number \( (a_{k-1}, a_{k-2}, \ldots, a_0) \) corresponding to the number of \( 1 \)s in its inputs. If \( T \) receives the code words of the following codes:

- the \( 0 \)-out-of-\( K \) code;
- the \( 2^w \)-out-of-\( K \) code, for all \( w = 0, 1, \ldots, k-1 \);
- the \( (3 \times 2^w) \)-out-of-\( K \) code, for all \( w = 0, 1, \ldots, k-3 \);
- the \( (3 \times 2^w) \)-out-of-\( K \) code, only if MSA is a full-adder;

then \( T \) is completely tested.

**Proof.** Any adder in \( T \), that adds inputs of weight \( 2^w \) (\( 0 \leq w \leq k-2 \)), receives the all \( 0 \)s input combination when the code word of the \( 0 \)-out-of-\( K \) code is appearing in the \( K \) inputs of \( T \).

- Any adder in \( T \), that adds inputs of weight \( 2^w \) (\( 0 \leq w \leq k-2 \)), receives the combinations with exactly one \( 1 \) when specific code words of the \( 2^w \)-out-of-\( K \) code is appearing in the \( K \) inputs of \( T \), for all \( w = 0, 1, \ldots, k-2 \).
- Any adder in \( T \), that adds inputs of weight \( 2^w \) (\( 0 \leq w \leq k-2 \)), receives the combinations with exactly two \( 1 \)s when specific code words of the \( 2^w \)-out-of-\( K \) code is appearing in the \( K \) inputs of \( T \), for all \( w = 0, 1, \ldots, k-2 \).
- Any full adder in \( T \), that adds inputs of weight \( 2^w \) (\( 0 \leq w \leq k-3 \)), receives the all \( 1 \)s input combination when a code word of the \( (3 \times 2^w) \)-out-of-\( K \) code is appearing in the \( K \) inputs of \( T \), for all \( w = 0, 1, \ldots, k-3 \).
- If the MSA in \( T \) is a full-adder, then MSA receives the all \( 1 \)s input combination when a code word of the \( (3 \times 2^w) \)-out-of-\( K \) code is appearing in the \( K \) inputs of \( T \).

The following corollaries are derived from Theorem 1:

#### Corollary 1

If an adder tree \( T \) with \( K \) inputs, where \( 2^{k-1} \leq K \leq 3 \times 2^{k-2} - 1 \), receives the \( r \)-out-of-\( K \) codes (for all \( r = 0, 1, \ldots, 2^{k-1} \)) then it is completely tested.

#### Corollary 2

If an adder tree \( T \) with \( K \) inputs, where \( 3 \times 2^{k-2} \leq K \leq 2^k - 1 \), receives the \( r \)-out-of-\( K \) codes (for all \( r = 0, 1, \ldots, 3 \times 2^{k-2} \)) then it is completely tested.

At this point we remark that both Corollaries 1 and 2 are still valid in case that \( T \) generates the binary number \( (a_{k-1}, a_{k-2}, \ldots, a_0) \) corresponding to the number of \( 1 \)s in its inputs plus the constant \( p \), that is,
when some CHAs in $T$ have been accordingly replaced by NHAs (and vice versa) as proposed in [12].

Based on Corollaries 1 and 2, we present here TSC $m$-out-of-$n$ code checkers with $n \geq 2m$ whose structure is shown in Fig. 1. The proposed checkers consists of two adder trees $T_1$ and $T_2$ with $k_1$ and $k_2$ inputs, respectively, and a $k$-variable TSC two-rail code checker, where $n = k_1 + k_2$ and $\lceil \log_2 (m+1) \rceil = k$. $T_1$ and $T_2$ must have the same number of output lines to be compared and thus the following relation should be satisfied:

$$\lceil \log_2 (k_1 + 1) \rceil = \lceil \log_2 (k_2 + 1) \rceil = k \tag{1}$$

Fig. 1. The proposed TSC $m$-out-of-$n$ code checker.

$T_1$ generates the binary number $(a_{k-1}, a_{k-2}, ..., a_0)$ corresponding to the number $m_1$ of 1's in its inputs plus some constant $p_1$. $T_2$ generates the binary number $(b_{k-1}, b_{k-2}, ..., b_0)$ corresponding to the number $m_2$ of 1's in its inputs plus some constant $p_2$. The adders utilized are the ones given in Definitions 5–8. The trees consist of alternating layers of normal and complementary adders, with inverters inserted where appropriate. The construction details can be found in [12]. The constants $p_1$ and $p_2$ have to be chosen so that the following relation is satisfied:

$$p_1 + p_2 = 2^k - 1 - m \tag{2}$$

The satisfaction of (2) assures that during normal operation, when the proposed checker receives inputs encoded in the $m$-out-of-$n$ code, the binary numbers $(a_{k-1}, a_{k-2}, ..., a_0)$ and $(b_{k-1}, b_{k-2}, ..., b_0)$ are complementary to each other.

In some cases (e.g., see Fig. 2), $T_1$ and $T_2$ have different polarities in their corresponding outputs due to the fact that they have different number of adder layers. The problem is solved without any effort by putting inverters at the outputs of the adder tree with the least adder layers.

The $k$-variable TSC two-rail checker monitors the outputs of $T_1$ and $T_2$ and checks whether the binary numbers $(a_{k-1}, a_{k-2}, ..., a_0)$ and $(b_{k-1}, b_{k-2}, ..., b_0)$ are complementary to each other. The representation of the $k$-variable TSC two-rail checker is given in Fig. 3 [12], [16]. It consists of two 2-variable TSC two-rail code checkers (termed TRC1 and TRC2, respectively) and a $(k-2)$-variable TSC two-rail code checker (termed TRC3). The latter can be implemented in a tree structure or in two gate levels [15].

Theorem 2 gives sufficient conditions to be satisfied in order for the adder trees $T_1$, $T_2$, and the $k$-variable TSC two-rail checker to constitute a TSC $m$-out-of-$n$ code checker.

**Theorem 2.** The proposed circuit of Fig. 1 is a TSC $m$-out-of-$n$ code checker, with respect to the single stuck-at fault model, where $n = k_1 + k_2$, $m \leq k_1 \leq k_2$, and $\lceil \log_2 (m+1) \rceil = k$, if both of the following conditions are satisfied:

C1. Either

$$2^{k-1} \leq m \leq k_1 \leq k_2 \leq 3x2^{k-2} - 1 \tag{3}$$

or

$$3x2^{k-2} \leq m \leq k_1 \leq k_2 \leq 2^k - 1 \tag{4}$$

C2. If ‘$\lor$’ and ‘$\land$’ are the bitwise OR and AND operations, correspondingly, on the binary representation of the numbers involved, then

$$(k_1 \land k_2) \lor m = m \tag{5}$$

**Proof.** The proposed circuit of Fig. 1 is a TSC $m$-out-of-$n$ code checker if it is code disjoint self-testing and fault secure with respect to the single stuck-at fault model.

**Code disjoint property.** Following the same reasoning given in [12] we conclude that if (1) and (2) are satisfied the adder trees $T_1$ and $T_2$ constitute a code disjoint circuit that translates from the $m$-out-of-$n$ code into the $k$-variable two rail code. We can see easily that (1) is satisfied if condition C1 is satisfied. Let us examine under which condition (2) is satisfied. In the case of the TSC $m$-out-of-$2m$ code checker proposed in [12], when there exists a 0 at the $w$th bit of the binary representation of $m$, a half adder that adds inputs of the weight $2^w$ is changed from CHA to NHA or vice versa, in either of the two adder trees; the replacement occurs for all such

Inputs or 2W O trees with respect to implementation cost and operation speed, Fig. 2.


The k-variable TSC two-rail checker is code disjoint by construction. Consequently, the whole TSC m-out-of-n code checker is code disjoint.

Self-testing property. If (3) is satisfied then the adder tree T1 receives at least the r-out-of-k1 codes (for all r = 0, 1, ..., 2k-1) and the adder tree T2 receives at least the r-out-of-k2 codes (for all r = 0, 1, ..., 2k-1). Thus, from Corollary 1 it is derived that T1 and T2 are completely tested. Alternatively, if (4) is satisfied then the adder tree T1 receives at least the r-out-of-k1 codes (for all r = 0, 1, ..., 3 x 2k-1) and the adder tree T2 receives at least the r-out-of-k2 codes (for all r = 0, 1, ..., 3 x 2k-1). Thus, from Corollary 2 is derived that T1 and T2 are completely tested. Therefore, if condition C1 is satisfied then both adder trees T1 and T2 are completely tested. Following the procedure proposed by Marouf and Friedman [16], it is seen that for each of the adder trees T1 and T2, 8(k - 1) code words are enough to exhaustively test all single stuck-at faults. For the case of m-out-of-2m codes the same number of code words is enough to test the two trees simultaneously. In the case of m-out-of-n codes, where n > 2m, the same number of test inputs may not be enough, so that in general, we have an upper bound of 16(k - 1) code words in order for both adder trees T1 and T2 to be completely tested.

The k-variable TSC two-rail checker consists of two 2-variable TSC two-rail code checkers (termed TRC1 and TRC2, respectively) and a (k - 2)-variable TSC two-rail code checker (termed TRC3) as it is shown in Fig. 3. Since condition C1 is satisfied, TRC3 receives all possible 2k-2 code words, independently of p1 and p2. The same holds for TRC1 and TRC2, when 2k-1 < m. If 2k-1 = m then TRC1 and TRC2 are TSC only when both p1 ≠ 0 and p2 ≠ 0 [12]. In the TSC m-out-of-n code code checker proposed here this can be achieved only if both k1 and k2 have some zero bits in the positions corresponding to zero bits in the binary representation of m. But this is always the case, because, since (3) is satisfied, all three numbers (m, k1, and k2) have their (k - 2)th bit equal to zero. Therefore, if condition C1 is satisfied then the k-variable TSC two-rail checker is self-testing and thus TSC with respect to single stuck-at faults. Consequently, the whole TSC m-out-of-n code checker is self-testing with respect to single stuck-at fault model.

Fault secure property. Following the same reasoning as in [12] we can see easily that the proposed TSC m-out-of-n code checker is fault secure with respect to single stuck-at fault model.

For a given m-out-of-n code, the implementation can be done in more than one way, by varying the values of k1 and k2 as long as all the conditions are satisfied. For example, the TSC 8-out-of-19 code checker could be implemented using either two trees of 8 and 11 inputs or two trees with 9 and 10 inputs, correspondingly. Both implementations of the TSC 8-out-of-19 code checker are equivalent with respect to implementation cost and operation speed. Fig. 2 shows the checker for the code 8-out-of-19 consisting of a 9 input adder tree T1 and a 10 input adder tree T2.

Notice also that in a TSC m-out-of-n code checker designed as proposed here the replacement of normal adders (NFAs, NHAs) with complemented ones (CFAs, CHAs) and vice versa, in both trees T1 and T2, results in the corresponding TSC (n - m)-out-of-n code checker. Thus, our method is not only applicable in the design of TSC m-out-of-n code checkers with n ≥ 2m, but also in the design of the corresponding TSC (n - m)-out-of-n code checkers.

Sample values for m and n, for which the circuits described here are TSC m-out-of-n code checkers, are given in Table 1. From Table I it is derived that TSC m-out-of-n code checkers with values of m in the neighbourhood of \( \lceil n/2 \rceil \) are presented in this paper. Thus, taking into account that among all m-out-of-n codes these codes have less redundancy, we conclude that in this paper TSC code checkers for the most useful m-out-of-n codes are given.

**TABLE I**

<table>
<thead>
<tr>
<th>m</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>10</th>
<th>11</th>
<th>12</th>
<th>13</th>
<th>14</th>
</tr>
</thead>
<tbody>
<tr>
<td>n</td>
<td>8*</td>
<td>9*</td>
<td>12*</td>
<td>13*</td>
<td>16*</td>
<td>17*</td>
<td>19*</td>
<td>20*</td>
<td>21*</td>
<td>22*</td>
<td>26*</td>
</tr>
<tr>
<td>n</td>
<td>9</td>
<td>10*</td>
<td>13</td>
<td>14*</td>
<td>17</td>
<td>18*</td>
<td>19*</td>
<td>20*</td>
<td>21*</td>
<td>22*</td>
<td>27*</td>
</tr>
<tr>
<td>n</td>
<td>16*</td>
<td>17</td>
<td>19</td>
<td>20*</td>
<td>21*</td>
<td>22*</td>
<td>23*</td>
<td>24*</td>
<td>25</td>
<td>26*</td>
<td>27*</td>
</tr>
<tr>
<td>n</td>
<td>32*</td>
<td>33*</td>
<td>34*</td>
<td>35*</td>
<td>37*</td>
<td>38*</td>
<td>39*</td>
<td>40*</td>
<td>41*</td>
<td>42*</td>
<td>43*</td>
</tr>
</tbody>
</table>

*The TSC m-out-of-2m code checkers are designed as proposed in [12].

**IV. CONCLUSION**

We presented sufficient conditions, under which, the TSC m-out-of-2m code checkers proposed by Paschalis et al. in [12] can be extended to a class of m-out-of-n codes, where n ≥ 2m. The resulting circuits retain all the advantages of the circuits in [12], namely small gate count, small test-set, design modularity, and straightforward MOS VLSI implementation. A more detailed analysis of the proposed extension can be found in [18].

**REFERENCES**


