



Faculty of Engineering Technology  
Electrical & Computer Engineering Department  
First Semester-2023/2024  
ENCS2340, Digital Systems  
Project Report

Prepared by: Abdulrahman Rateb Atyani

student ID: 1221808

Instructor: Dr. Ali Abdo

Section: 3

## Contents

|                                  |    |
|----------------------------------|----|
| <a href="#">Introduction:</a>    | 1  |
| <a href="#">ALU:</a>             | 1  |
| <a href="#">Bitwise_or:</a>      | 2  |
| <a href="#">Code :</a>           | 2  |
| <a href="#">Simulation :</a>     | 2  |
| <a href="#">Bitwise_and:</a>     | 3  |
| <a href="#">code :</a>           | 3  |
| <a href="#">Simulation :</a>     | 3  |
| <a href="#">Full adder :</a>     | 4  |
| <a href="#">Code :</a>           | 4  |
| <a href="#">Simulation :</a>     | 4  |
| <a href="#">Addion:</a>          | 5  |
| <a href="#">Code :</a>           | 5  |
| <a href="#">Simulation :</a>     | 5  |
| <a href="#">Subtraction:</a>     | 6  |
| <a href="#">Code :</a>           | 6  |
| <a href="#">Simulation :</a>     | 6  |
| <a href="#">DataFlow_Alu :</a>   | 7  |
| <a href="#">Code :</a>           | 7  |
| <a href="#">Simulation :</a>     | 7  |
| <a href="#">Block _diagram:</a>  | 8  |
| <a href="#">Behavioral_Alu :</a> | 9  |
| <a href="#">Code :</a>           | 9  |
| <a href="#">Simulation :</a>     | 9  |
| <a href="#">Block _diagram:</a>  | 10 |

### \*introduction of Alu

It is a digital department located inside the central processing unit responsible for performing all arithmetic operations (such as addition and subtraction) on integers. The device treats them as binary numbers 0 and 1. It also performs comparison operations to find out the result of logical comparisons, which are: (greater than, less than, equal to, and not equal to) and derivatives. These comparisons also provide the ability to temporarily store information in addition to the ability to process information .

\*This figure show the ALU Structure

Inputs: $A[n-1:0], b[n-1:0], F[1:0]$ .

Outputs: $D(\text{carry out}), R[n-1:0] (\text{ result})$ .



## Bitwise Or

```
1 module Bitwise_or ( input [3:0] a,b,output [3:0] Out);
2
3     or(Out[0],a[0],b[0]);
4     or(Out[1],a[1],b[1]);
5     or(Out[2],a[2],b[2]);
6     or(Out[3],a[3],b[3]);
7
8 endmodule
```



It is clear from the above that the code pertains to the Or operation, as it works to take values in binary as a value separately and compares according to the principle of or, and thus outputs the value to us based on the above. As for the waveform, what I said is represented by it, and where I entered two inputs and output a value, and for example, it is clear by the first The clip says that when I entered the number 0 and then the number 1, it gave me the number 1, and this is a correct result, and the same applies to the rest .

## Bitwise And

```
1 module Bitwise_and ( input [3:0] a,b,output [3:0] Out_and );
2
3     and(Out_and[0],a[0],b[0]);
4     and(Out_and[1],a[1],b[1]);
5     and(Out_and[2],a[2],b[2]);
6     and(Out_and[3],a[3],b[3]);
7
8 endmodule
```



It is clear from the above that the code pertains to the and operation, as it works to take values in binary as a value separately and compares according to the principle of and, and thus outputs the value to us based on the above. As for the waveform, what I said is represented by it, and where I entered two inputs (each input contains 4 bit)and output a value(that contains 4 bit), and for example, it is clear by the second The clip says that when I entered the number 4 and then the number 8, it gave me the number 0, and this is a correct result, and the same applies to the rest .

| A | B | A&B |
|---|---|-----|
| 0 | 0 | 0   |
| 0 | 1 | 0   |
| 1 | 0 | 0   |
| 1 | 1 | 1   |

## Full Adder

```
1 module full_Adder(input a, b, c, output cout, sum);
2   wire w1, w2, w3;
3   and (w1, a, b);
4   xor (w2, a, b);
5   and (w3, w2, c);
6   xor (sum, w2, c);
7   or (cout, w1, w3);
8 endmodule
```



It is clear from the previous code how to build a full adder from a group of gates, and how it works by adding three bits together. The principle of its work is based on sum and carry, where it collects the bits and puts the result in sum, and what is more than the sum is put in carry, and what proves the truth of my words is what we see in Semulation, where, for example, in the first clip, the input values are as follows: a=1, b=1, c=1, and this results in sum = 1, and the value of crray = 1, and this applies to The rest of the clips are in simulation.

## Addition Operation

```
1 module addion (input [3:0] a,b , input cin, output c_out ,output [3:0] sum, output over_flow);
2
3     wire [2:0] w;
4
5     full_Adder(a[0], b[0], cin , w[0] , sum[0]);
6     full_Adder( a[1], b[1], w[0], w[1], sum [1]);
7     full_Adder( a[2], b[2], w[1], w[2], sum[2]);
8     full_Adder(a[3], b[3],w[2], c_out, sum[3]);
9     xor (over_flow,w[2],c_out);
10
11 endmodule
```



We see in this summation process that we have made a call to the module of full adder four times for each bit once in order to sum the inputs a and b. As for the third input, which is cin, its value is always zero. We also notice in simulation that there is a new output, which is over flow, which appears when it is last. Two carry is different, or when adding two positive numbers and the result is negative, or two negative numbers and the result is positive, for example in the third section when adding 3 with 6, the result is 9, and there is also over flow in addition to the lack of carry, and this is what the addition process looks like.

## Subtraction Operation

```
1 module Subtraction (input [3:0] a,b , input cin, output c_out ,output [3:0] result,output over_flow);
2
3 wire [2:0] wa;
4
5 full_Adder(a[0], ~b[0], cin , wa[0] , result[0]);
6 full_Adder( a[1], ~b[1], wa[0], wa[1], result[1]);
7 full_Adder( a[2], ~b[2], wa[1], wa[2], result[2]);
8 full_Adder(a[3], ~b[3],wa[2], c_out, result[3]);
9 xor(over_flow,wa[2],c_out);
10
11 endmodule
```



We see in this subtraction process that we did the same thing by calling full adder four times for each bit once in order to subtract the inputs a and b. As for the third input, which is cin, its value is always 1, as we notice in the code that we took the value of 1s complement of b, in order to add This value is combined with cin and appears as -b. We also notice in the simulation that there is a new output, which is over flow, which appears as it appears during the addition process. For example, in the second section, when 4 is subtracted with -8, the result is -4, and this is illogical, so over flow appears, and this picture that show the subtraction process.

## Data Flow\_Alu

```
1 module DataFlow_Alu (input [3:0] a,b , input cin, input [2:0] op ,output [3:0] result1,output cout
2 ,output c_out,output over_flow,output over_flow1);
3
4 wire [3:0] w_or,w_and,w_add,w_sub ;
5
6 Bitwise_or (a,b,w_or);
7 Bitwise_and (a,b,w_and);
8 addion ( a , b , cin, cout ,w_add,over_flow);
9 Subtraction ( a , b ,cin, c_out ,w_sub,over_flow1);
10
11 assign result1=(op==3'b000) ?w_add:
12 (op==3'b001) ?w_sub:
13 (op==3'b010) ?w_and:
14 (op==3'b011) ?w_or:3'bz;
15
16 endmodule
17
18
```



Here we see how to build Alu through the Data flow method, which is characterized by assign keyword, where we collected all the modules by calling them and placing them inside the shown module, where we added a new input, which is opcode, which determines the calculation process through the conditions inside the code, as is shown in simulation. Each section represents a mathematical operation. The first, for example, represents the addition operation, where we entered 1 with 0 and the result was 1. In the second section, we performed the subtraction operation, the third section performed the and operation between inputs, and the last section we performed the or operation.



## beahviroal\_Alu

```
1  module Behavioral_ALU (input [3:0] a,b , input cin, input [2:0] F ,output reg [3:0] result,output reg cout,output reg over_flow);
2   wire [3:0] w_or,w_and,w_add,w_sub ;
3   wire overflow_add,overflow_sub,c_add,c_sub;
4
5   Bitwise_or (a,b,w_or);
6   Bitwise_and (a,b,w_and);
7   addition ( a , b , cin, c_add ,w_add,overflow_add);
8   Subtraction ( a , b ,cin, c_sub ,w_sub,overflow_sub );
9
10
11  always @(*) begin
12
13    if (F==3'b000)result=w_add;
14    else if(F==3'b001)result=w_sub;
15    else if(F==3'b010)result=w_and;
16    else if(F==3'b011)result=w_or;
17    else result=3'bz;
18
19    if(F==3'b000)cout=c_add;
20    else if(F==3'b001)cout=c_sub;
21    else cout=1'bz;
22
23    if(F==3'b000)over_flow=overflow_add;
24    else if(F==3'b001)over_flow=overflow_sub;
25    else over_flow=1'bz;
26
27
28  end
29 endmodule
```



Here we see how to build Alu through the behavioral method, which is characterized by the always keyword, where we collected all the modules by calling them and placing them inside the shown module, where we added the input itself that is present in the data flow, which is the opcode that determines the computational process through the conditions inside the code, As it becomes clear in simulation, each stanza represents a mathematical operation. The first, for example, represents the addition operation, where we entered 1 with 0 and the result was 1. In the second stanza we performed the subtraction operation,

the third stanza we performed the and operation between inputs, and the last stanza we performed the or operation.

This is the block diagram of behavirol \_Alu

