## **Problems**

- 15.1 Test length. If N=15 patterns are produced by an LFSR, and 2 of those patterns detect a given fault, say e stuck-at 0, what is the average test length T to detect e stuck-at-0? Hint: See the paper by Wagner  $et\ al.\ [702]$ .
- 15.2 Standard LFSR. Implement a standard LFSR for the characteristic polynomial  $f(x) = x^8 + x^7 + x^2 + 1$ . Write the system of equations with the companion matrix for this LFSR.
- 15.3 Modular LFSR. Implement a modular LFSR for the characteristic polynomial  $f(x) = x^3 + x + 1$ . Write the system of equations with the companion matrix for this LFSR.
- 15.4 Standard LFSR. Compute the first eight patterns generated by the standard LFSR with characteristic polynomial  $f(x) = x^8 + x^7 + x^2 + 1$  and an initialization of "00000001," with the one in the least significant bit.
- 15.5 Modular LFSR. Compute the first eight patterns generated by the modular LFSR with characteristic polynomial  $f(x) = x^3 + x + 1$  assuming that the LFSR was initialized to "001" with the one in the least significant bit.
- 15.6 MISRs. Figure 15.49 shows a multiple-input signature register of the STAN-DARD (external XOR) type. This MISR takes outputs from the circuit, labeled as A and B, and compacts their responses. Please convert this signature register into the equivalent MODULAR (internal XOR) type and draw this equivalent signature register. Although the equations representing these two response compacters are the same, the signatures will be different, so explain the relationship between the two signatures.



Figure 15.49: MISR for Problem 15.6.

15.7 Weighted random patterns. Apply four bits of the weighted pseudo-random pattern generator of Figure 15.16(b) to the four-input circuit:  $f = (a \oplus b) \cdot (c \oplus d)$ . For each of the four inputs, you can either choose one of  $X_7$ ,  $X_6$ ,  $X_5$ ,  $X_4$ ,  $X_3$ ,  $X_2$ ,  $X_1$ ,  $X_0$  (1/2 probability),  $X_2 \wedge X_0$  (1/4 probability),  $X_4 \wedge X_2 \wedge X_0$  (1/8 probability), or  $X_6 \wedge X_4 \wedge X_2 \wedge X_0$  (1/16 probability.) If necessary, you may activate the *Inversion* signal to invert the probability. How many weight sets are needed to obtain 100% stuck-fault coverage for the faults in this circuit?

Problems 545

15.8 Weighted random pattern generator. Design a weighted pseudo-random pattern generator with programmable weights 1/2, 1/4, 11/32, and 1/16.

- 15.9 Cellular automaton. Build a four flip-flop rule 150 cellular automaton (CA), and compute its pattern sequence. Seed the CA pattern generator with "0001." What is the period of the cellular automaton? Compute the pattern sequence of the four flip-flop LFSR with characteristic polynomial  $f(x) = 1 + x^4$ . What is the LFSR's period? Is the CA better than the LFSR, and if so, then why?
- 15.10 Maximal LFSR. Design a 3-bit maximal LFSR, but please add hardware to map the test-pattern "010," which is not useful, into the pattern "000," which detects several circuit faults.
- 15.11 Aliasing probability. Using Figure 15.22, please compute the probability of aliasing for an error vector e with error probability p = 0.3, where a 15-bit LFSR is used for response compaction.
- 15.12 Fault detection. In Figure 15.23, can the transition counter detect the multiple stuck-at fault both b and c stuck-at-0? Can the LFSR detect this fault?
- 15.13 LFSR enhancement. Design test pattern embedding hardware to control an LFSR with the characteristic polynomial  $f(x) = 1 + x + x^3$  to produce an allzero test pattern. This problem also requires you to design the actual LFSR. Is this less hardware than just implementing a 3-bit binary counter?
- 15.14 Aliasing analysis. Consider the BIST system in Figure 15.50. Circuit inputs are A, B, and C, which are generated by the LFSR, and the outputs are Y and Z, which are compacted by the output MISR. The LFSR is initialized to 001 (i.e., the bottom LFSR flip-flop is set to 1 and the other two are cleared) and the MISR is initialized to 000. The circuit is clocked for eight periods to produce this test sequence:

$$egin{array}{c|c|c} L_1 & 0 & 1 & 0 & 1 & 1 & 1 & 0 & 0 \\ L_2 & 0 & 0 & 1 & 0 & 1 & 1 & 1 & 0 \\ L_3 & 1 & 0 & 0 & 1 & 0 & 1 & 1 & 1 \\ \hline \end{array}$$

The LFSR and the MISR are wired to the same clock line, and are fault-free. Explain why aliasing does not occur for the fault e stuck-at 0, even though it is expected since the test 001 for this fault is applied twice. What are the final good machine and bad machine signatures for the fault e stuck-at-0, eight clock periods after the LFSR and the MISR were initialized?

15.15 Fault detection. For Problem 15.14, find which of these faults are detected:

| A sa0 | A  sa 1 | B- $e$ sa0 | B- $e$ sa 1 | C- $e$ sa 0 | C- $e$ sa 1 |
|-------|---------|------------|-------------|-------------|-------------|

15.16 Fault detection. For Problem 15.14, find which of these faults are detected: