# 10/5/2016

# Project 1

Verilog Model for  $f = x\bar{y} + yz$ 

Bibodi, Jay Nikhil

Sec 2: 5:30-6:45 Fall 2016



## 2.29 b. Module

```
module Project1
(

input x,y,z,

output f
);
wire out1, out2, out3;
not n1(out1,y);
nand n2(out2,out1,x);
nand n3(out3,y,z);
nand n4(f,out2,out3);
endmodule
```

## 2.29 b. Test Bench

```
`include "Project1.v"
module tester();
reg x,y,z;
wire f;
Project1 po(x,y,z,f);
initial begin
$display ("Time x y z f");
                    %b", $time,f);
$monitor ("%4d
x=0; y=0; z=0; $display("%4d %b %b %b", $time, x, y,z);
//test1
#1 //simulate
x=0; y=0; z=1; $display("%4d %b %b %b", $time, x, y,z);
//test2
#1 //simulate
x=0; y = 1; z = 0; $display("%4d %b %b %b", $time, x, y,z);
//test3
#1 //simulate
x=0; y = 1; z = 1; $display("%4d %b %b %b", $time, x, y,z);
//test4
#1 //simulate
x=1; y = 0; z = 0; $display("%4d %b %b %b", $time, x, y,z);
//test5
#1 //simulate
x=1; y = 0; z = 1; $display("%4d %b %b %b", $time, x, y,z);
//test6
```

```
#1 //simulate
x=1; y = 1; z = 0; $display("%4d %b %b %b", $time, x, y,z);
//test7
#1 //simulate
x=1; y = 1; z = 1; $display("%4d %b %b %b", $time, x, y,z);
//test8
#1 //simulate
$finish;
end
endmodule
```

# 2.29 b Output

```
Chronologic VCS simulator copyright 1991-2014
Contains Synopsys proprietary information.
Compiler version I-2014.03-2; Runtime version I-2014.03-2; Oct 4 18:33 2016
Time x y z
   0 0 0 0
   Θ
   1001
   2 0 1 0
   3 0 1 1
   4 1 0 0
   5 1 0 1
   6 1 1 0
   7 1 1 1
$finish called from file "project1 testBench.v", line 45.
$finish at simulation time
           V C S
                  Simulation
                                          Report
Time: 8
CPU Time:
               0.520 seconds;
                                 Data structure size:
                                                             0.0Mb
Tue Oct 4 18:33:10 2016
[bibodij@titan:39]>
```

## 2.29 d. Module

#### 2.29 d. Test Bench

```
`include " Project1_AssignStatement.v"
module tester();
reg x,y,z;
wire f;
```

```
Project1 AssignStatement po(x,y,z,f);
initial begin
$display ("Time x y z f");
$monitor ("%4d
                    %b", $time,f);
x=0; y=0; z=0; $display("%4d %b %b %b", $time, x, y,z);
//test1
#1 //simulate
x=0; y=0; z=1; $display("%4d %b %b %b", $time, x, y,z);
//test2
#1 //simulate
x=0; y = 1; z = 0; $display("%4d %b %b %b", $time, x, y,z);
//test3
#1 //simulate
x=0; y = 1; z = 1; $display("%4d %b %b %b", $time, x, y,z);
//test4
#1 //simulate
x=1; y = 0; z = 0; $display("%4d %b %b %b", $time, x, y,z);
//test5
#1 //simulate
x=1; y = 0; z = 1; $display("%4d %b %b %b", $time, x, y,z);
//test6
#1 //simulate
x=1; y = 1; z = 0; $display("%4d %b %b %b", $time, x, y,z);
//test7
#1 //simulate
x=1; y = 1; z = 1; $display("%4d %b %b %b", $time, x, y,z);
//test8
#1 //simulate
$finish;
end
endmodule
```

# 2.29 d. Output

```
Chronologic VCS simulator copyright 1991-2014
Contains Synopsys proprietary information.
Compiler version I-2014.03-2; Runtime version I-2014.03-2; Oct 4 18:54 2016
Time x y z
   0 0 0 0
   Θ
   1001
   2 0 1 0
   3 0 1 1
   3
   4 1 0 0
   5 1 0 1
   6 1 1 0
   6
   7 1 1 1
$finish called from file "project1 testBench.v", line 45.
$finish at simulation time
                    Simulation
           V C S
                                           Report
Time: 8
CPU Time:
                0.540 seconds;
                                      Data structure size:
                                                               Θ.ΘMb
Tue Oct 4 18:54:53 2016
[bibodij@titan:41]>
```