### **Combinational Test Generation**

- Test Generation (TG) Methods
  - (1) From truth table (2) Using Boolean equation (3) Using Boolean difference (4) From circuit structure
- TG from Circuit Structure
  - Common Concepts
  - ATPG Algorithms : D-Algorithm

### **A Test Pattern**

A test pattern



A test pattern with don't cares



Test generation: generates a test for a target fault.

生成 可以測 目標錯誤 的輸入

### **Test Generation Methods**

(From Truth Table)

Ex: How to generate tests for the stuck-at 0 fault (fault  $\alpha$ )?



| abc          | f | $ \mathbf{f}_{\alpha} $ |                |
|--------------|---|-------------------------|----------------|
| 000          | 0 | 0                       |                |
| 001          | 0 | 0                       |                |
| 010          | 0 | 0                       |                |
| 011          | 0 | 0                       | Impractical !! |
| 100          | 0 | 0                       | Impractical    |
| 101          | 1 | 1                       |                |
| <b>√110</b>  | 1 | 0                       |                |
| √ 110<br>111 | 1 | 1                       |                |

所有都測過一遍 是不實際的 TLE

### **Test Generation Methods**

(Using Boolean Equation)

用布林 方程式 推出

Since f = ab+ac, 
$$f_{\alpha}$$
 = ac =>
$$T_{\alpha}$$
 = the set of all tests for fault  $\alpha$ 

$$= ON\_set(f) * OFF\_set(f_{\alpha}) + OFF\_set(f) * ON\_set(f_{\alpha})$$

$$= \{(a,b,c) \mid (ab+ac)(ac)' + (ab+ac)'(ac) = 1\}$$

$$= \{(a,b,c) \mid abc'=1\}$$

$$= \{ (110) \}.$$
High complexity !!

Since it needs to compute the faulty function for each fault.

所有 能讓 f輸出 為1的 輸入組合 就叫ON set

• ON\_set(f): All input combinations that make f have value 1.

OFF set(f): All input combinations that make f have value 0.

布林 差分式

目的也是為了 找到某個測試訊號輸入 能讓想測的地方 的結果 傳遞到輸出

### **Boolean Difference**

- Physical Meaning of Boolean Difference
  - For a logic function  $F(X)=F(x_1, ..., x_i, ..., x_n)$ , find all the input combinations that make the change of value in xi also cause the change of value in F.
- Logic Operation of Boolean Difference
  - The Boolean difference of F(X) w.r.t. input xi is

$$\frac{dF(X)}{dxi} = F_i(0) \oplus F_i(1) = F_i(0) \bullet F_i(1) + F_i(0) \bullet F_i(1),$$
 冒要用這個XOR 是為了 希望在輸入 0 和 1 會有不同的結果 所有這個正常結果 是1

會要用這個XOR

所有這個正常結果 是1

where 
$$F_i(0) = F(x_1, ..., 0, ..., x_n)$$
 and  $F_i(1) = F(x_1, ..., 1, ..., x_n)$ .

Relationship between TG and Boolean Difference





### **Applying Boolean Difference to Test Generation (1/2)**

Case 1: Faults are present at Pls.





$$f = ab+ac = \frac{df}{da} = f_a(0) \oplus f_a(1) = 1 \cdot (b+c) + 0 = b+c$$

The set of all tests for line a s-a-1 is  $\{(a,b,c) \mid a \mid *(b+c)=1\} = \{(01x), (0x1)\}.$ The set of all tests for line a s-a-0 is  $\{(a,b,c) \mid a \mid (b+c)=1\} = \{(11x), (1x1)\}$ .

且分别去看那了input 卡在1 的 test有誰 尹雨加上一了條件 and 起来 卡在O→用1泡) → A



$$\frac{df'}{dh} = \int_{\Gamma} (0 + \int_{\Gamma} f \cdot n) = \alpha \cdot (0) = \alpha \cdot$$

# Applying Boolean Difference to Test Generation (2/2)

Case 2: Faults are present at internal lines.



f = h+ac, h = ab => 
$$\frac{df}{dh} = f_h(0) \oplus f_h(1) = \overline{ac} \cdot 1 + ac \cdot \overline{1} = \overline{a} + \overline{c}$$

$$\overline{h} = \overline{ab} = \overline{h} + \overline{b}$$

The set of all tests for line h s-a-1 is

H卡1 這樣就會有兩種通解

$$\{ (a,b,c)|h'_*(a'+c')=1 \} = \{ (a,b,c)|(a'+b')_*(a'+c')=1 \} = \{ (0xx), (x00) \}.$$

The set of all tests for line h s-a-0 is

$$\{(a,b,c)|h_*(a'+c')=1\} = \{(110)\}.$$
 h+0 這樣只會有一個解

這裡就是要從 要測試的地方 推到輸出 能夠穿出去再反推到 其他一開始的輸入

### **Test Generation Methods**

(From Circuit Structure)



Two basic goals:

∦ test ← Fault activation(FA)

這兩個合稱 又叫

=> Line justification (LJ)

Fault propagation(FP)

1/0 代表 正常是1 錯誤是0 這樣給他一個符號 D

0/1 同理反推 D'

where 1/0 means that the good value is 1 and the faulty value is 0 and is denoted as D. Similarly, 0/1 is denoted as D'. D and D' are called fault effects (FE).

錯誤效益

### **Common Concepts for Structural TG**

- The FA problem => a LJ problem.
- The FP problem =>
  - (1) Select a FP path to a PO => decisions.
  - (2) Once the path is selected => a set of LJ problems.
- The LJ problems => <u>decisions</u> or <u>implications</u>.

ex: a — c 決定 暗示

To justify c=1 => a=1 and b=1. (implication) 有c是1 就 暗示 a b都是 1
To justify c=0 => a=0 or b=0. (need make decisions) 有c是0 就需要 決定 a b 誰是0 或都是

- Incorrect decision => Backtracking => Another decision.
- Once the fault effect is propagated to a PO and all line values to be justified are justified, the test is generated.
   Otherwise, the decision process must be continued repeatedly until all possible decisions have been tried.



### **Ex: Decisions When Fault Propagation**



FA => a=1, b=1, c=1 => G1= D', G3=0; FP => through G5 or G6.

Decision: through G5 => G2=1 => d=0, a=0. => inconsistency => backtracking!!

Decision: through G6 => G4=1 => e=0. => done!! 無法從好此

The resulting test is 111x0.

D-frontier: The set of all gates whose output value is currently x but have one or more fault signals on their inputs. Ex: Initially, the D-frontier of this example is {G5, G6}.

### **Ex: Decisions When Line Justification**





The corresponding decision tree

FA => h=D'; FP => e=1, f=1 (=> o=0); FP => q=1, r=1.

To justify  $q=1 \Rightarrow l=1$  or k=1.

Decision:  $I=1 \Rightarrow c=1$ ,  $d=1 \Rightarrow m=0$ ,  $n=0 \Rightarrow r=0$ .  $\Rightarrow$  inconsistency  $\Rightarrow$  backtracking!!

Decision: k=1 => a=1, b=1.

To justify r=1 => m=1 or n=1 (=> c=0 or d=0). => done!!

J-frontier: The set of all gates whose output value is known but is not implied by its input values. Ex: Initially, the J-frontier of the example is  $\{q=1, r=1\}$ .

### **Implications**

暗示 就是 一個地方決定了 某一個地方 就一定能直接推斷而出

- Implication: computation of the values that can be uniquely determined.
  - Local implication: propagation of values from one line to its immediate successors or predecessors. 區域性的 暗示 能推斷出 一個後代 或 祖先
  - Global implication: the propagation involving a larger area of the circuit and reconvergent fanout.

    全域性的 暗示 會傳遞 推斷到一組電路的某個地方 一定是某值
- Maximum implication principle: perform as many implications as possible. 能夠推的 都寫出來
- Maximum implications help us to either reduce the number of problems that need decisions or to reach an inconsistency sooner.

  □以很快發現誰是矛盾的

### **Local Implications (Forward)**

#### **Before**

$$0 \xrightarrow{\underline{X}} X$$

$$\frac{1}{x} \longrightarrow \frac{0}{a}$$
 J-frontier={ ...,a

#### **After**

$$\frac{0}{x}$$
  $\rightarrow$ 

J-frontier=
$$\{ ...,a \}$$
  $\frac{1}{0}$  J-frontier= $\{ ... \}$ 

$$X D - frontier = \{ ..., a \}$$
  $D - frontier = \{ ... \}$ 

### Local Implications (Backward)

#### **Before**



$$\frac{x}{x}$$
 J-frontier={ ... }

$$\frac{x}{x}$$

#### **After**



$$\frac{x}{x}$$
 J-frontier={ ...,a }

### **Global Implications**

全域性 暗示





(1) Future unique D-drive.



(2) F=1 implies B=1. (Static learning)



動態的 推斷

- (3) F=0 implies B=0 when A=1. (Dynamic learning)
- (2), (3) are based on contraposition law: (A=>B) <=> (!B => !A).

也是和之前一樣 要測的地方 找路出去

能用的訊號 有這幾種

Logic values = {0, 1, D, D', x}.



Logic values = {0, 1, D, D', x}.



想從G1 傳遞到最後 來去推 e那邊會有問題 k會錯

- 1. Propagate fault effect through G1 → Set d to 1
- 2. Propagate fault effect through G2 → Set j,k,l,m to 1
- 3. Conflict occured at k
  → Backtrack

Logic values = {0, 1, D, D', x}.



想從 G2 去傳遞到最後輸出來去推斷 也有會有問題

- 1. Propagate fault effect through G2 → Set j,l,m to 1
- 2. Conflict occured at m
  → Backtrack

Logic values = {0, 1, D, D', x}.



### **D-Algorithm: Value Computation**

| Decision                | Implication                               | Comments                        |                |                                    |                 |
|-------------------------|-------------------------------------------|---------------------------------|----------------|------------------------------------|-----------------|
|                         | a = 0<br>h = 1<br>b = 1<br>c = 1<br>g = D | Active the fault Unique D-drive | e = 1          | k = D'<br>e' = 0<br>j = 1          | Propagate via k |
| d = 1                   | i = D'<br>d' = 0                          | Propagate via i                 | l = 1<br>m = 1 | n = D                              | Propagate via n |
| j = 1<br>k = 1<br>l = 1 |                                           | Propagate via n                 |                | f' = 0<br>f = 1<br>m = D'          | Contradiction   |
| m = 1                   | n = D<br>e' = 0<br>e = 1<br>k = D'        | Contradiction                   | f = 1          | m = D'<br>f' = 0<br>l = 1<br>n = D | Propagate via m |

### **D-Algorithm: Decision Tree**



- Decision node: the associated D-frontier. branch: the decision taken, i.e., the gate selected from the D-frontier.
- The D-algorithm first tried to propagate the fault solely through i, then through both i and k, and eventually succeeded when all three paths were simultaneously sensitized.

### Iterative Logic Array (ILA) Model for **Sequential Circuits**

會儲存上一次的輸出 PO 就叫做 續向邏輯 這次的輸出 會和上一次有關係 Combinational Logic 會比較難測 **y**2 所以我們會想把它變成組合邏輯來測 FF 把它想像成動畫

一秒鐘30個畫面

看他是第幾貞的畫面 訊號

多複製幾個 這一秒 和 上一秒 的自己 相連



FF

## Sequential Test Generation Extended D-Algorithm

- 1. Pick up a target fault f.
- 2. Create a copy of a combinational logic, set it time-frame 0.
- 3. Generate a test for f using D-algorithm for time-frame 0.
- 4. When the fault effect is propagate to the DFFs, continue fault propagation in the next time-frame.
- 5. When there are values required in the DFFs, continue the justification in the previous time-frame.

### **Example for Extended D-Algorithm**



### **Example: Step 1**



### **Example: Step 2**



但是這裡的 0 也要從

### **Example: Step 3**

