



CS/IT 429

# Switch Level Modeling

**Dr. Yash Agrawal**  
 Visiting Faculty, IIIT Vadodara  
 Associate Professor, DA-IICT Gandhinagar

## Introduction

What is  
 Switch Level Modeling...?

Dr. Yash Agrawal @ IIIT Vadodara

## Primitives

| Gate Level Primitive                    |                    |                                      | Switch Level Primitive                              |                                                                 |                    |
|-----------------------------------------|--------------------|--------------------------------------|-----------------------------------------------------|-----------------------------------------------------------------|--------------------|
| Multi Input Gates                       | Multi Output Gates | Tristate Gates                       | Unidirectional                                      | Bidirectional                                                   | Pull Gates         |
| and<br>nand<br>or<br>nor<br>xor<br>Xnor | buf<br>not         | bufif0<br>bufif1<br>notif0<br>notif1 | nmos<br>pmos<br>cmos<br><br>rnmos<br>rpmos<br>rcmos | tran<br>tranif0<br>tranif1<br><br>rtran<br>rtranif0<br>rtranif1 | pullup<br>pulldown |

Dr. Yash Agrawal @ IIIT Vadodara

## Switch Level Primitive



### Syntax

nmos <instance name> (<drain>, <source>, <gate>);

### Example

nmos n1(out1, data, control);

| nmos |  | control |   |       |       |
|------|--|---------|---|-------|-------|
| data |  | 0       | 1 | x     | z     |
| 0    |  | z       | 0 | x (L) | x (L) |
| 1    |  | z       | 1 | x (H) | x (H) |
| x    |  | z       | x | x     | x     |
| z    |  | z       | z | z     | z     |

L → 0 or z  
 H → 1 or z



### Syntax

pmos <instance name> (<drain>, <source>, <gate>);

### Example

pmos n1(out2, data, control);

| pmos |  | control |   |       |       |
|------|--|---------|---|-------|-------|
| data |  | 0       | 1 | x     | z     |
| 0    |  | 0       | z | x (L) | x (L) |
| 1    |  | 1       | z | x (H) | x (H) |
| x    |  | x       | z | x     | x     |
| z    |  | z       | z | z     | z     |

# Switch Level Modeling

$$\text{out} = \overline{\text{in}}$$



Implement using  
Switch Level Model

$$\text{out} = \overline{\mathbf{a} \cdot \mathbf{b}}$$



Implement using  
Switch Level Model

Dr. Yash Agrawal @ IIIT Vadodara

5

6

# Switch Level Modeling

$$\mathbf{F} = \mathbf{A} + \mathbf{B}$$

| B | A | F |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 1 |

Implement using  
Switch Level Model



$$\mathbf{F} = \mathbf{A} \cdot \mathbf{B}$$

| B | A | F |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

Implement using  
Switch Level Model



Dr. Yash Agrawal @ IIIT Vadodara

7

8

Dr. Yash Agrawal @ IIIT Vadodara

# Switch Level Modeling



Implement using  
Switch Level Model

# Switch Level Modeling



Implement using  
Switch Level Model



Dr. Yash Agrawal @ IIIT Vadodara

9

Dr. Yash Agrawal @ IIIT Vadodara

10

# Switch Level Modeling

Bidirectional switches



tran t1(inout1, inout2);



tranif1 t2(inout1, inout2, control);



tranif0 t3(inout1, inout2, control);

# Switch Level Modeling



Implement the circuits  
using  
Switch Level Model

Dr. Yash Agrawal @ IIIT Vadodara

11

Dr. Yash Agrawal @ IIIT Vadodara

12



## Data Types

Usage of 'nmos' logic



Implement such as above  
circuits act as  
capacitor/storing element

I am available/approachable at

email: [yash\\_agrawal@iiitvadodara.ac.in](mailto:yash_agrawal@iiitvadodara.ac.in)  
[yash\\_agrawal@daiict.ac.in](mailto:yash_agrawal@daiict.ac.in)