# **Logic Simulation**

- Introduction
- Simulation Models
- Logic Simulation Techniques
  - Compiled-code simulation
  - Event-driven simulation (1965)
    - Zero delay
    - Nominal delay
    - \* False events
  - Parallel Simulation
- Issues of Logic Simulations
- Conclusions



### **Compiled-code Simulation Problems**

- 1. Gate delay model not considered
- 2. Oblivious: forgets results in previous cycle





### Event-Driven Simulation [Ulrich 1965]

- IDEA: evaluates a gate only if there is event(s) at its gate inputs
  - Event is a signal value change (at time t)
  - Gates with inputs changed are activated
- Example:
  - Event: A 0→1
  - Activated gate: G<sub>2</sub>

• Only evaluate 1 gate, instead of 4 gates

O 1 A  $G_1$ ,  $G_3$ ,  $G_4$  not evaluated again in  $2^{\text{nd}}$  cycle

O B  $G_1$ ,  $G_3$ ,  $G_4$  not evaluated  $G_4$  in  $G_4$   $G_4$   $G_4$   $G_4$   $G_4$   $G_4$   $G_5$   $G_6$   $G_7$   $G_8$   $G_8$   $G_9$   $G_9$  G

# Zero-delay Event-driven Sim.



event  $(g, v_g^+)$  means gate g changes to  $v_g^+$ 

| Executed events        | Q                              |
|------------------------|--------------------------------|
| (B,1)(A,1)             | G <sub>1,</sub> G <sub>2</sub> |
| (G <sub>1</sub> , 1) - | G <sub>2</sub>                 |
| (G <sub>2</sub> ,1)    | G <sub>4</sub>                 |
| (G <sub>4</sub> ,0)    | -                              |



### Quiz

# Please simulate this circuit



| Executed Events | Q              |
|-----------------|----------------|
| (B,1)           | G <sub>1</sub> |
|                 |                |
|                 |                |
|                 |                |
|                 |                |
|                 |                |



**VLSI Test 2.4** © National Taiwan University

# **Logic Simulation**

- Introduction
- Simulation Models
- Logic Simulation Techniques
  - Compiled-code simulation
  - Event-driven simulation (1965)
    - \* Zero delay
    - Nominal delay
    - \* False events
  - Parallel Simulation
- Issues of Logic Simulations
- Conclusions



# Nominal-delay Event-drive Sim.

every gate delay = 1ns

event  $(g, v_g^+)$  @ tgate g changes to  $v_g^+$ at time stamp t

| A 1                                          | $G_2$ $H$ $O$ |
|----------------------------------------------|---------------|
| 0 <b>→</b> 1                                 | $G_4$ $K$     |
| $C = \begin{bmatrix} G_1 \\ E \end{bmatrix}$ | $G_3$ $J$ $I$ |

| t | Executed events     | sch'd<br>events Q                              |
|---|---------------------|------------------------------------------------|
| 0 | (B,1)               | (G <sub>1</sub> ,1)@1                          |
| 1 | (G <sub>1</sub> ,1) | (G <sub>3</sub> ,0)@2<br>(G <sub>2</sub> ,1)@2 |
| 2 | (G <sub>3</sub> ,0) | (G <sub>2</sub> ,1)@2<br>(G <sub>4</sub> ,1)@3 |
| 2 | (G <sub>2</sub> ,1) | (G <sub>4</sub> ,1)@3<br>(G <sub>4</sub> ,0)@3 |
| 3 | (G <sub>4</sub> ,1) | (G <sub>4</sub> ,0)@3                          |
| 3 | (G <sub>4</sub> ,0) |                                                |



### FFT

### Simultaneous signal change

of G<sub>4</sub> @3 wastes CPU time.

Q: Can we do better?

| t | Executed events     | sch'd<br>events Q                              |
|---|---------------------|------------------------------------------------|
| 0 | (B,1)               | (G <sub>1</sub> ,1)@1                          |
| 1 | (G <sub>1</sub> ,1) | (G <sub>3</sub> ,0)@2<br>(G <sub>2</sub> ,1)@2 |
| 2 | (G <sub>3</sub> ,0) | (G <sub>2</sub> ,1)@2<br>(G <sub>4</sub> ,1)@3 |
| 2 | (G <sub>2</sub> ,1) | (G <sub>4</sub> ,1)@3<br>(G <sub>4</sub> ,0)@3 |
| 3 | (G <sub>4</sub> ,1) | (G <sub>4</sub> ,0)@3                          |
| 3 | (G <sub>4</sub> ,0) |                                                |



### Quiz



| t  | executed                | scheduled events in Q                                                                            |
|----|-------------------------|--------------------------------------------------------------------------------------------------|
| 0  | (A,1)                   | (G <sub>2</sub> ,1)@8                                                                            |
| 2  | (C,0)                   | (G <sub>2</sub> ,1)@8; (G <sub>1</sub> ,1)@10                                                    |
| 4  | ( <i>B</i> ,0)          | $(G_2,1)@8; (G_1,1)@10; (G_1,0)@12$                                                              |
| 8  | $(A,0),(G_2,1)$         | $(G_1,1)@10; (G_1,0)@12$<br>$(G_4,0)@14; (G_2,0)@16$                                             |
| 10 | (G <sub>1</sub> ,1)     | $(G_1,0)@12;(G_4,0)@14;(G_2,0)@16$                                                               |
| 12 | (G <sub>1</sub> ,0)     | (G <sub>4</sub> ,0)@14; (G <sub>2</sub> ,0)@16<br>(G <sub>3</sub> ,1)@16; (G <sub>2</sub> ,0)@20 |
| 14 |                         |                                                                                                  |
| 16 |                         |                                                                                                  |
| 20 |                         |                                                                                                  |
| 22 | $(G_4,1)(G_4,0)(G_4,0)$ | -                                                                                                |



\*Two events are shown in same row for simplicity

**VLSI Test 2.4** © National Taiwan University

# **Logic Simulation**

- Introduction
- Simulation Models
- Logic Simulation Techniques
  - Compiled-code simulation
  - Event-driven simulation (1965)
    - \* Zero delay
    - Nominal delay
    - \* False events
  - Parallel Simulation
- Issues of Logic Simulations
- Conclusions



### **False Events**



| t  | executed                    | scheduled events in Q                                                                            |
|----|-----------------------------|--------------------------------------------------------------------------------------------------|
| 0  | (A,1)                       | (G <sub>2</sub> ,1)@8                                                                            |
| 2  | (C,0)                       | (G <sub>2</sub> ,1)@8; (G <sub>1</sub> ,1)@10                                                    |
| 4  | ( <i>B</i> ,0)              | $(G_2,1)@8; (G_1,1)@10; (G_1,0)@12$                                                              |
| 8  | (A,0),(G <sub>2</sub> ,1)   | $(G_1,1)@10; (G_1,0)@12$<br>$(G_4,0)@14; (G_2,0)@16$                                             |
| 10 | $(G_1,1)$ false             | $(G_1,0)@12;(G_4,0)@14;(G_2,0)@16$                                                               |
| 12 | ( <i>G</i> <sub>1</sub> ,0) | (G <sub>4</sub> ,0)@14; (G <sub>2</sub> ,0)@16<br>(G <sub>3</sub> ,1)@16; (G <sub>2</sub> ,0)@20 |
| 14 | ( <i>G</i> <sub>4</sub> ,0) | (G <sub>2</sub> ,0)@16;(G <sub>3</sub> ,1)@16;(G <sub>2</sub> ,0)@20                             |
| 16 | $(G_2,0)(G_3,1)$            | $(G_2,0)$ @20; $(G_4,1)$ @22; $(G_4,0)$ @22                                                      |
| 20 | $(G_2,0)$ false             | $(G_4,1)@22; (G_4,0)@22; (G_4,0)@22$                                                             |
| 22 | $(G_4,1)(G_4,0)(G_4,0)$     | -                                                                                                |



# False Events cause no change in signal

**VLSI Test 2.4 © National Taiwan University** 

# Event-driven Alg. w/o False Events

- For each gate, record last scheduled value to avoid false events
- (BA Fig. 3.32)

```
event-driven-sim (t) /* t is current time stamp*/

1. for every event (g, v_g^+) @ t
2. v_g = v_g^+
3. for every j on the fauout list of g
4. update input values of j
5. v_j^+ = \text{evaluate}(j)
6. if v_j^+ \neq \text{lsv}(j) /* lsv = last scheduled value */
7. schedule (j, v_j^+) @ t + d_j /* d_j = gate \ delay \ of \ j */
8. \text{lsv}(j) = v_j^+
```

### **Trade off Memory for Speed**

# **How to Implement Event List?**

#### 1. Linked list

- © t is flexible
- **Slower** to search



- 2. Cyclic Array (aka. Timing Wheel) [Ulrich 1969]
  - © Faster to search
  - $\otimes$   $\Delta t$  is fixed
  - **⊗** Limited **L** slots in a cycle



# **Summary**

- Event-driven simulation
  - Consider gate delay
  - Saves CPU time. Only evaluate gates with events at input.
- Two algorithms
  - Zero delay
  - Nominal delay
- False events are redundant events that can be removed
- Event list implementation
  - Linked list: slow but flexible
  - Cyclic Array (Timing wheel): fast but fixed time slots



### Comparison

|               | Pros ©                                                             | Cons 🙁                                             |
|---------------|--------------------------------------------------------------------|----------------------------------------------------|
| Compiled-code | Simple implementation                                              | No gate delay Oblivious Suitable for high activity |
| Event-driven  | Consider gate delay Only simulate events Suitable for low activity | Complex algorithm                                  |

**ED** is Generally Better than CC

### FFT

### Simultaneous signal change

of G<sub>4</sub> @3 wastes CPU time.

Q: Can we do better?

| t | Executed events     | sch'd<br>events Q                              |
|---|---------------------|------------------------------------------------|
| 0 | (B,1)               | (G <sub>1</sub> ,1)@1                          |
| 1 | (G <sub>1</sub> ,1) | (G <sub>3</sub> ,0)@2<br>(G <sub>2</sub> ,1)@2 |
| 2 | (G <sub>3</sub> ,0) | (G <sub>2</sub> ,1)@2<br>(G <sub>4</sub> ,1)@3 |
| 2 | (G <sub>2</sub> ,1) | (G <sub>4</sub> ,1)@3<br>(G <sub>4</sub> ,0)@3 |
| 3 | (G <sub>4</sub> ,1) | (G <sub>4</sub> ,0)@3                          |
| 3 | (G <sub>4</sub> ,0) |                                                |



**16** 

### IDEA#1 Two-pass Algorithm [Ulrich 1965]

- 1<sup>st</sup> pass executes events
  - L<sub>E</sub> event list, priority queue of events
- 2<sup>nd</sup> pass evaluates gates

 $L_{\Delta}$  activity list, list of gates

All input events to a gate evaluated together. **Avoid simultaneous** signal change



### IDEA #2 One-pass Algorithm [Ulrich 1969]

- Add last scheduled time (lst)
- Cancel previously scheduled events when needed

```
event-driven-sim-new (t)
 1. for every event (g, v_g^+) @ t
 2. 	 v_{\varphi} = v_{\varphi}^{+}
 3. for every j on the fauout list of g
           update input values of j
          v_i^+ = evaluate (j)
 6. if v_i^+ \neq lsv(j)
              t^+ = t + d_i
 7.
 8.
              if t^+ == 1st(j) /* simultaneous signal change*/
                  cancel event (j, lsv(j)) @ t^+
 9.
10.
               schedule (j, v_i^+) @ t^+
               lsv(j) = v_i^+
11.
               lst(j) = t^{+} /* lst = last scheduled time */
12.
```

### **FFT**

- Cyclic Array (aka. Timing Wheel)
  - **⊗** Limited *L* slots in a cycle
- Q:what if remote events that is outside of (n+L)∆t?

