### COAL Lab # 00

## **Introductory Lab**

Name: Muhammad Usman

Class: BSCS 3C1

**Reg No:** cs211208

#### **Literature Review:**

In this lab we learned about the RISC-V architecture which is an open instruction set architecture (ISA) to implement CPU I microprocessor or microcontroller. hardware description language (HDL) is a specialized computer language used to describe the structure and behavior of electronic circuits, and most commonly, digital logic circuits. Verilog is one of a Hardware Description Language (HDL) used to model digital systems. VS code is an IDE (Integrated Development Environment) where Verilog designs could be written and edited.

### Task:

Implement AND gate function using Verilog.

### **Truth Table:**

| Α | В | X |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

# **Block Diagram:**



# **Boolean Equation:**

X = A.B

# **Verilog Code:**

design.v

```
module gate(A,B,Y);
    // Declaring inputs
    input A,B;
    // Declaring output
    output Y;
    // Using gate level modeling
    and(Y,A,B);
```

#### testBench.v

```
module tb();
    // declaring variables
    reg A,B;
    wire Y;
    // declaring design // dut (Design Under Test)
    gate dut (.A(A),.B(B),.Y(Y));
    initial begin
     // value change dump // variable change dump
      $dumpfile("Dump.vcd");
      $dumpvars(0);
    // All input values for AND gate
    initial begin;
      A <= 1'b0;
     B <= 1'b0;
      #100
      A <= 1'b0;
     B <= 1'b1;
      #100
      A \leftarrow 1'b1;
      B <= 1'b0;
      #100
      A <= 1'b1;
      B <= 1'b1;
      #100;
      $finish;
    end;
endmodule;
```

### **Waveforms:**

