

**THADOMAL SHAHANI ENGINEERING COLLEGE**  
**BANDRA (W). MUMBAI – 400050**

## **CERTIFICATE**

This is to certify that Mr./Miss Krish Naik of Computer  
Engineering Department, Semester 3 With Roll  
No. 2003120 has completed a course of the necessary  
experiments in the subject DLCA under my  
supervision in the **THADOMAL SHAHANI ENGINEERING**  
**COLLEGE** Laboratory in the year 20 - 20

---

Teacher in-charge

---

Head of Department

Date: 10\12\2021

Principal

List of DLCA Assignments (C1/C2/C3)

| Assignment No | Assignment                                                                                                              |
|---------------|-------------------------------------------------------------------------------------------------------------------------|
| 1             | Decimal to binary and vice versa conversion and 2's complement                                                          |
| 2             | Verify the truth table and realize the logic expression                                                                 |
| 3             | Implement NOT, AND ,OR and EXOR gates using the universal gates NAND and NOR                                            |
| 4             | Implement Half Adder and Full Adder.                                                                                    |
| 5             | Implement conversion of 4-bit binary to gray code and vice versa.                                                       |
| 6             | Implement a 4-bit ripple carry adder.                                                                                   |
| 7             | Booth's Algorithm                                                                                                       |
| 8             | Carry look ahead Generator                                                                                              |
| 9             | IEEE 754 conversion                                                                                                     |
| 10            | Implement a 8:1 Mux and 3:8 Decoder                                                                                     |
|               | <b>Written Assignment</b>                                                                                               |
| 1             | Write a short note on cache mapping techniques (Direct, Associative and Set associative mapping) with examples for each |
| 2             | Write a short note on multicore architecture                                                                            |

Prof . Tasneem Mirza

Prof. Vaishali Suryavanshi

Prof. Vaibhav Ambhire

### Experiment No 1

- Ques: A) Write a program to accept a decimal number and convert it to binary and vice versa.  
B) Accept a signed decimal no (positive/negative) and find the 2's complement of the no.

Theory :-

a) ex:  $(10)_{10} = (01010)_2$

$(01100)_2 = (12)_{10}$

b) 2's Complement ex:  $5 = 0101$

$-5 = 1011$

Program with output :-

```
start here ✘ Decimal to Binary and vice versa.c ✘
1 #include <stdio.h>
2 void main()
3 {
4     int a[10], number, i, j;
5     printf("\nEnter the Number You want to Convert : ");
6     scanf("%d", &number);
7     for(i = 0; number > 0; i++)
8     {
9         a[i] = number % 2;
10        number = number / 2;
11    }
12    printf("\nBinary Number of a Given Number = 0 ");
13    for(j = i - 1; j >= 0; j--)
14    {
15        printf(" %d ", a[j]);
16    }
17    printf("\n");
18
19
20    int num, binary, decimal = 0, base = 1, rem;
21    printf (" Enter a binary number with the combination of 0s and 1s \n");
22    scanf (" %d", &num);
23    binary = num;
24    while ( num > 0 )
25    {
26        rem = num % 10;
27        decimal = decimal + rem * base;
28        num = num / 10;
29        base = base * 2;
30    }
31    printf (" The binary number is %d \t", binary);
32    printf (" \n The decimal number is %d \t", decimal);
33 }
34
```

■ "C:\Users\krish\OneDrive\Documents\Decimal to Binary and vice versa.exe"

```
Enter the Number You want to Convert : 11

Binary Number of a Given Number = 0 1 0 1 1
Enter a binary number with the combination of 0s and 1s
1011
The binary number is 1011
The decimal number is 11
Process returned 29 (0x1D) execution time : 12.640 s
Press any key to continue.
```

Start here X 2's compliment.c X

```
1 #include <stdio.h>
2 #include <math.h>
3 void main()
4 {
5     int n, absN, i, j, bin[50] = {};
6     printf("Enter Number\n");
7     scanf("%d", &n);
8     absN = abs(n);
9     for(i = 0; absN != 0; i++)
10    {
11        bin[i] = absN % 2;
12        absN /= 2;
13    }
14    printf("Your number in binary is ");
15    if(n < 0)
16    {
17        for(j = 0; j <= i; j++)
18        {
19            bin[j] = (bin[j] == 1) ? 0 : 1;
20        }
21        for(j = 0; bin[j] == 1; j++)
22        bin[j] = 0;
23        bin[j] = 1;
24        for(; i >= 0; i--)
25        printf("%d", bin[i]);
26    }
27    else
28    {
29        printf("0");
30        for(i = i-1; i >= 0; i--)
31        printf("%d", bin[i]);
32    }
33 }
```

■ "C:\Users\krish\OneDrive\Documents\2's compliment.exe"

Enter Number

-5

Your number in binary is 1011.

Process returned 1 (0x1) execution time : 4.516 s

Press any key to continue.

Experiment No 2

Aim: To verify the truth tables of the following gates

- 1) NOT
- 2) AND
- 3) OR
- 4) EXOR
- 5) NAND
- 6) NOR

$$\bar{A} = A$$



Theory:-

- i) AND Gate: The And gate is an electronic circuit that gives a high input (1) only if all its inputs are high. A dot (.) is used to show And operation. A.B or AB.

$$Y = A \cdot B$$



| input | output |
|-------|--------|
| 0     | 0      |
| 0     | 0      |
| 1     | 0      |
| 1     | 1      |

Truth table of AND Gate

3) OR Gate : The OR gate is an electronic circuit that gives a high output ( $Y$ ) if one or more of its inputs are high at plus (+) is used to show the OR operation.



| input |   | output      |
|-------|---|-------------|
| A     | B | $Y = A + B$ |
| 0     | 0 | 0           |
| 0     | 1 | 1           |
| 1     | 0 | 1           |
| 1     | 1 | 1           |

3) NOT Gate : The NOT gate is an electronic circuit that produces an inverted version of the input at its output. It is also known as an inverter. If the input variable is  $A$ , the inverted output is known as  $\text{NOT } A$ . It is also known as  $A'$



| Input | Output |
|-------|--------|
| A     | $Y$    |
| 0     | 1      |
| 1     | 0      |

4) NAND Gate : This is a NOT-AND gate which is equal to an AND gate. The outputs of all NAND gates are high if any of the inputs are low.

$$Y = \overline{AB}$$



| Input |   | Output | A |
|-------|---|--------|---|
| A     | B | Y      |   |
| 0     | 0 | 1      | 0 |
| 0     | 1 | 1      | 0 |
| 1     | 0 | 0      | 1 |
| 1     | 1 | 0      | 1 |

5) NOR Gate : This is a NOT-OR gate which is equal to an OR gate followed by a NOT gate. The outputs of all NOR gates are low if any of the inputs are high. The symbol is an OR gate with a small circle on the output.

$$Y = \overline{A+B}$$



| A | B | Y | A |
|---|---|---|---|
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 0 |
| 1 | 0 | 0 | 1 |
| 1 | 1 | 0 | 1 |

Q) EXOR gate :- The EXOR gate is a circuit which will give a high output if either, but not both of its inputs are high. An enclosed plus sign ( $\oplus$ ) is used to show the EXOR operation.

$$Y = A \oplus B$$



| A | B | AXOR B |
|---|---|--------|
| 0 | 0 | 0      |
| 0 | 1 | 1      |
| 1 | 0 | 1      |
| 1 | 1 | 0      |

Q) EXNOR Gate :- The EXNOR gate circuit does the opposite to the EXOR gate. It will give a low output if either, but not both inputs are high.

$$Y = \overline{A \oplus B}$$



| A | B | Y |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

$$(b) A'B + BC$$

| A | B | C | $A'$ | $A'B$ | $BC$ | $A'B + BC$ |
|---|---|---|------|-------|------|------------|
| 1 | 1 | 1 | 0    | 0     | 1    | 1          |
| 1 | 1 | 0 | 0    | 0     | 0    | 0          |
| 1 | 0 | 1 | 0    | 0     | 0    | 0          |
| 1 | 0 | 0 | 0    | 0     | 0    | 0          |
| 0 | 1 | 1 | 1    | 1     | 1    | 1          |
| 0 | 1 | 0 | 1    | 1     | 0    | 1          |
| 0 | 0 | 1 | 1    | 0     | 0    | 0          |
| 0 | 0 | 0 | 1    | 0     | 0    | 0          |

$$2) A(B+C) + A'BCD$$



Experiment No 3

Aim: Implement NOT, AND, OR and EXOR gates using the universal gates NAND and NOR.

Theory:-

1.1) NAND gates as OR gate :- From DeMorgan's theorem :-

$$(A \cdot B)' = A' + B'$$

$$(A' \cdot B')' = A + B$$

So, give the inverted inputs to a NAND gate, obtain OR operation at output.

| A | B | Y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 1 |

1.2) NAND gates as AND gate :- An NAND produces complement of AND gate. So, if the output of a NAND gate is inverted the output will be of AND gate.

| A | B | $Y = A \cdot B$ |
|---|---|-----------------|
| 0 | 0 | 0               |
| 0 | 1 | 0               |
| 1 | 0 | 0               |
| 1 | 1 | 1               |

1.3) NAND gates as Ex-OR gate: The output of a two input Ex-OR gate is shown by:  $Y = A'B + AB'$ . This can be achieved with the logic diagram.

| A | B | $A \oplus B$ |
|---|---|--------------|
| 0 | 0 | 0            |
| 0 | 1 | 1            |
| 1 | 0 | 1            |
| 1 | 1 | 0            |

1.4) NAND gates as Ex-NOR gate: An Ex-NOR gate is actually Ex-OR gate followed by NOT gate. So, give the output of Ex-OR gate to a NOT gate, overall output is of Ex-NOR gate.

| A | B | $\bar{A} \oplus \bar{B}$ |
|---|---|--------------------------|
| 0 | 0 | 1                        |
| 0 | 1 | 0                        |
| 1 | 0 | 0                        |
| 1 | 1 | 1                        |

2.1) NOR gates as OR gate: A NOR produces complement of OR gate. So, if output of a NOR gate is inverted, overall output will be of an OR gate.

| A | B | $\bar{A} \vee \bar{B}$ |
|---|---|------------------------|
| 0 | 0 | 0                      |
| 0 | 1 | 0                      |
| 1 | 0 | 0                      |
| 1 | 1 | 0                      |

2.2) NOR gates as AND gate : from De Morgan's theorem:

$$(A+B)' = A'B'$$

$$(A'+B')' = A''B'' = AB$$

So, give the inverted inputs to a NOR gate, obtain AND operation at output.

| A | B | $A \cdot B$ |
|---|---|-------------|
| 0 | 0 | 0           |
| 0 | 1 | 0           |
| 1 | 0 | 0           |
| 1 | 1 | 1           |

2.3) NOR gates as ExOR gate : ExOR gate is actually an ExNOR gate followed by a NOT gate. So, give output of ExNOR gate to a NOT gate, overall output is that of ExOR gate.

| A | B | $A \oplus B$ |
|---|---|--------------|
| 0 | 0 | 0            |
| 0 | 1 | 1            |
| 1 | 0 | 1            |
| 1 | 1 | 0            |

2.4) NOR gates as ExNOR gate : The output of a two input ExNOR gate is achieved by  $Y = AB + A'B'$ .

| A | B | $Y$ | B | A |
|---|---|-----|---|---|
| 0 | 0 | 1   | 0 | 0 |
| 0 | 1 | 0   | 1 | 0 |
| 1 | 0 | 0   | 0 | 1 |
| 1 | 1 | 1   | 1 | 1 |

# 1- NAND Gates as OR Gate

## INSTRUCTIONS

Experiment to perform logic of Or Using Nand on kit



# 2- NAND Gates as AND Gate

## INSTRUCTIONS

Experiment to perform logic of AND Using NAND on kit



## 3- NAND Gates as XOR Gate

### INSTRUCTIONS

Experiment to perform logic of Ex-OR Using Nand on kit



## 4- NAND Gates as XNOR Gate

### INSTRUCTIONS

Experiment to perform logic of Ex-NOR Using Nand on kit



# 1- NOR Gates as OR Gate

## INSTRUCTIONS

Experiment to perform logic of OR Using NOR on kit



# 2-NOR Gates as AND Gate

## INSTRUCTIONS

Experiment to perform logic of And Using Nor on kit



## 3-NOR Gates as XOR Gate

### INSTRUCTIONS

Experiment to perform logic of Ex-OR using NOR on kit



## 4-NOR Gates as XNOR Gate

### INSTRUCTIONS

Experiment to perform logic of Ex-NOR Using Nor on kit



Experiment No 4

Aim:- Using the logicsim simulator:  
Implement half adder and full adder.

Draw the truth table and realize the expression for half and full adder.

Theory:

i) **Half Adder:** It is a combinational circuit that performs simple addition of two binary numbers. If we assume A and B as the two bits whose addition is to be performed, the truth table for half adder with A, B as inputs and Sum, Carry as outputs can be calculated as

| Input |   | Output |       |
|-------|---|--------|-------|
| A     | B | Sum    | Carry |
| 0     | 0 | 0      | 0     |
| 0     | 1 | 1      | 0     |
| 1     | 0 | 1      | 0     |
| 1     | 1 | 0      | 1     |

**Full Adder:** It is a digital circuit used to calculate the sum of three binary bits. Full adders are complex and difficult to implement when compared to half adders. Two of the three bits are same as before which are A and B.

The additional third bit is carry bit from the previous stage and is called carry generally represented by CIN. It calculates the sum of three bits along with the carry. The output carry is called Carry out and is represented by CO<sub>UT</sub>.

The truth table of full adder with A, B and CIN as inputs and Sum and CO<sub>UT</sub> as outputs is:

| Input |   |     | Output |       |
|-------|---|-----|--------|-------|
| A     | B | CIN | Sum    | Carry |
| 0     | 0 | 0   | 0      | 0     |
| 0     | 0 | 1   | 1      | 0     |
| 0     | 1 | 0   | 1      | 0     |
| 0     | 1 | 1   | 0      | 1     |
| 1     | 0 | 0   | 1      | 0     |
| 1     | 0 | 1   | 0      | 1     |
| 1     | 1 | 0   | 0      | 1     |
| 1     | 1 | 1   | 1      | 1     |

Implementation of full adder:

Implementation of full adder is shown below. It consists of two half adders. The first half adder takes inputs A and B and produces sum S and carry C. The second half adder takes inputs CIN and C as inputs and produces sum S and carry CO<sub>UT</sub>. The final sum S is the output of the second half adder.



Experiment No 5

Aim: Using logicin simulators:  
Implement conversion of 4-bit binary  
to gray code and vice versa.

Theory:

1) Binary to gray conversion:

i) MSB of the gray code is always equal to  
MSB of the given binary code.

ii) Other bits of the output gray code can be  
obtained by XORing binary code  
bit at the index and previous index.

There are 4 inputs and outputs. The input  
variables are defined as  $B_3, B_2, B_1, B_0$  and  
output variables are defined as  $G_3, G_2, G_1, G_0$ .

$$B_3 = G_3$$

$$B_2 \oplus B_3 = G_2$$

$$B_1 \oplus B_2 = G_1$$

$$B_0 \oplus B_1 = G_0$$

| Natural-binary code |                |                |                | gray code      |                |                |                |  |
|---------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--|
| B <sub>3</sub>      | B <sub>2</sub> | B <sub>1</sub> | B <sub>0</sub> | G <sub>3</sub> | G <sub>2</sub> | G <sub>1</sub> | G <sub>0</sub> |  |
| 0                   | 0              | 0              | 0              | 0              | 0              | 0              | 0              |  |
| 0                   | 0              | 0              | 1              | 0              | 0              | 0              | 1              |  |
| 0                   | 0              | 1              | 0              | 0              | 0              | 1              | 1              |  |
| 0                   | 0              | 1              | 1              | 0              | 0              | 1              | 0              |  |
| 0                   | 1              | 0              | 0              | 0              | 1              | 1              | 0              |  |
| 0                   | 1              | 0              | 1              | 0              | 1              | 1              | 1              |  |
| 0                   | 1              | 1              | 0              | 0              | 1              | 0              | 1              |  |
| 1                   | 0              | 0              | 0              | 1              | 0              | 0              | 0              |  |
| 1                   | 0              | 0              | 1              | 1              | 0              | 1              | 1              |  |
| 1                   | 0              | 1              | 0              | 1              | 1              | 1              | 1              |  |
| 1                   | 0              | 1              | 1              | 1              | 1              | 0              | 0              |  |
| 1                   | 1              | 0              | 0              | 1              | 0              | 1              | 0              |  |
| 1                   | 1              | 0              | 1              | 1              | 0              | 1              | 1              |  |
| 1                   | 1              | 1              | 0              | 1              | 0              | 0              | 1              |  |
| 1                   | 1              | 1              | 1              | 1              | 0              | 0              | 0              |  |

2) To gray to binary conversion:

i) MSB of the binary code is always equal to MSB of given binary number.

ii) Other bits of the output binary code can be obtained by checking gray code bit at that index. If current gray code bit is 0, then copy previous binary code bit, else copy invert of previous binary code bit.

Page No. : Date : | |

There are 4 inputs and outputs. The input variables are defined as  $G_3, G_2, G_1, G_0$  and output variables are defined as  $B_3, B_2, B_1, B_0$ .

$$G_0 \oplus G_1 \oplus G_2 \oplus G_3 = B_0$$

$$G_1 \oplus G_2 \oplus G_3 = B_1$$

$$G_2 \oplus G_3 = B_2$$

$$G_3 = B_3$$

| Gray code |       |       |       | Natural-binary code |       |       |       |
|-----------|-------|-------|-------|---------------------|-------|-------|-------|
| $G_3$     | $G_2$ | $G_1$ | $G_0$ | $B_3$               | $B_2$ | $B_1$ | $B_0$ |
| 0         | 0     | 0     | 0     | 0                   | 0     | 0     | 0     |
| 0         | 0     | 0     | 1     | 0                   | 0     | 0     | 1     |
| 0         | 0     | 1     | 0     | 0                   | 0     | 1     | 1     |
| 0         | 0     | 1     | 1     | 0                   | 0     | 1     | 0     |
| 0         | 1     | 0     | 0     | 0                   | 1     | 1     | 1     |
| 0         | 1     | 0     | 1     | 0                   | 1     | 1     | 0     |
| 0         | 1     | 1     | 0     | 0                   | 1     | 0     | 0     |
| 0         | 1     | 1     | 1     | 0                   | 1     | 0     | 1     |
| 1         | 0     | 0     | 0     | 1                   | 1     | 1     | 1     |
| 1         | 0     | 0     | 1     | 1                   | 1     | 1     | 0     |
| 1         | 0     | 1     | 0     | 1                   | 1     | 0     | 0     |
| 1         | 0     | 1     | 1     | 1                   | 1     | 0     | 1     |
| 1         | 1     | 0     | 0     | 1                   | 0     | 0     | 0     |
| 1         | 1     | 0     | 1     | 1                   | 0     | 0     | 1     |
| 1         | 1     | 1     | 0     | 1                   | 0     | 1     | 1     |
| 1         | 1     | 1     | 1     | 1                   | 0     | 1     | 0     |



Experiment no. 6

Aim:-

Using the logicism simulator,  
Implement a 4-bit ripple carry adder.

Use the 1-bit Full adder to implement the  
ripple carry adder (four 1-bit full adders)

Theory:-

Ripple Carry Adder is a combinational logic circuit. It is used for the purpose of adding two n-bit binary numbers. It requires  $n$  full adders in its circuit for adding two  $n$ -bit binary numbers. It is also known as  $n$ -bit parallel adder. 4-bit ripple carry adder is used for the purpose of adding two 4-bit binary numbers.



4-bit Ripple Carry Adder



objectives :- Experiment no. 7 : Binary Multiplier  
 Aim: Implement Booth's algorithm

Theory:-



Experiment no 8

Aim : Implement Carry look ahead generator.

Theory :



| A | B | Cin | Carry |
|---|---|-----|-------|
| 0 | 0 | 0   | 0     |
| 0 | 0 | 1   | 0     |
| 0 | 1 | 0   | 0     |
| 0 | 1 | 1   | 1     |
| 1 | 0 | 0   | 0     |
| 1 | 0 | 1   | 1     |
| 1 | 1 | 0   | 1     |
| 1 | 1 | 1   | 1     |

$$\text{As } C_{in} = 0$$

$$C_1 = G_0$$

$$C_2 = G_1 + P_1 C_1$$

$$C_3 = G_2 G_2 + P_2 G_1 + P_2 P_1 C_1$$

$$C_4 = G_3 + P_3 G_2 + P_3 P_2 G_1 + P_3 P_2 P_1 C_1$$



Experiment No 4

Nim: Program to implement IEEE-754 floating point single precision format.

Theory: IEEE single-precision floating point format is a binary computing format that occupies (32 bits) 4 bytes in computer memory.

Three numbers are associated with a floating point to numbers of single precision.

- 1 Sign bit: 1 bit
- 2 Exponent width: 8 bits
- 3 Significant precision: 23 bits



- 1) The sign of Mantissa: 0 represents a positive number while 1 represents a negative number.
- 2) The Biased exponent: The exponent field needs to represent both positive and negative exponents. A bias is added to get the stored exponent.
- 3) Mantissa: It is a floating-point number consisting of its significant digits.

Program:

```
#include <stdio.h>

void printBinary(int n, int i)

{
    int k;
    for (k = i - 1; k >= 0; k--)
        printf("%d", n & 1);
    printf("\n");
}
```

```
{  
if ((n >> k) & 1)  
printf("1");  
else  
printf("0");  
}  
}  
  
typedef union  
{  
float f;  
struct  
{  
unsigned int mantissa : 23;  
unsigned int exponent : 8;  
unsigned int sign : 1;  
} raw;  
} myfloat;  
  
void printIEEE(myfloat var)  
{  
  
printf(" %d | ", var.raw.sign);  
printBinary(var.raw.exponent, 8);  
printf(" | ");  
printBinary(var.raw.mantissa, 23);  
printf("\n");  
}  
  
int main()
```

```
{  
    myfloat var;  
    printf("Enter any float number : ");  
    scanf("%f",&var);  
    printf("\nIEEE 754 representation of %f is : \n", var.f);  
    printIEEE(var);  
    return 0;  
}
```

Output:

```
C:\Users\krish\OneDrive\Documents\IEEE 754.exe"  
Enter any float number : 26.08  
IEEE 754 representation of 26.080000 is :  
0 | 10000011 | 10100001010001111010111  
Process returned 0 (0x0) execution time : 10.878 s  
Press any key to continue.
```

## Experiment no 10

Aim: Implement 8:1 multiplexer and 3:8 decoder.

Theory: Mux Multiplexer is a device that has  $2^n$  input lines but has only 1 output line where  $n =$  number of input selector line.

## Truth table



Assignment No. 1

Cache Mapping Techniques :- Mapping function and replacement algorithm together decides where a line from the main memory can reside in the cache.

## 1) Direct Mapping Technique :-

In this case each block of main function memory can map to only one cache line. A given block maps to any line  $i \bmod j$ , where  $i$  is the line number of the main memory to be mapped and  $j$  is the total number of lines in the cache memory.

The address is divided into 3 parts :- the word selector, line selector and tag. Least significant  $w$  bits identify unique word of a particular line. Most significant  $s$  bits specify one memory block to which the cache line corresponds. The MSB's are split into a cache line field  $\rightarrow$  and a tag of  $s-2$ .

Example: let cache be of 64 kByte that is divided into blocks of 4 bytes hence cache is 16 k ( $2^{14}$ ) lines of 4 bytes.

Let the main memory size be 16 MBytes that requires 24 bit address lines ( $2^{24} = 16 M$ ).

|                       |                       |                      |
|-----------------------|-----------------------|----------------------|
| Tag( $s-2$ ) (8 bits) | Line( $s$ ) (14 bits) | Word( $w$ ) (2 bits) |
|-----------------------|-----------------------|----------------------|

Advantages :-

- 1) Simple implementation
- 2) Inexpensive

Disadvantage :-

Fixed location for given block hence if a program accesses 2 blocks that map to the same line repeatedly, cache misses are very high.

## 2) Associative Mapping :-

In this case a main memory block can lead into any line of cache. There are only two fields in the address as tag and word. The tag uniquely identifies block of memory from where the line has been copied into the cache memory. To search a particular data the tag of every line is to be examined for a match. Thus cache searching gets expensive in terms of time required.

Example : let cache be of 64 k bytes that is divided into blocks of 4 bytes hence cache is 16 k ( $2^{14}$ ) lines of 4 bytes.

let the main memory size be 16 M bytes that requires 24-bit address lines ( $2^{24} = 16 \text{ M}$ ).

The associative mapping address structure for this example considered 22-bit tag stored with each 4-word block of data.

Compare tag field with tag entry in cache to check for least significant 2 bytes of address identify which word is required from 4-word data block.

Tag (22 bits) | Word (2 bits)

Advantages:

- 1) If a program accesses 2 blocks repeatedly, cache misses will not occur.

Disadvantages:

- 1) Complex design for many parallel comparisons of tag.
- 2) Expensive due to implementation of parallel comparators.

### 3) Set Associative Mapping :

In this case cache is divided into a number of sets. Each set contains a number of lines. A given block maps to any line in a given set ( $i \bmod j$ ), where  $i$  is the line number of the main memory to be mapped and  $j$  is the total number of sets in the cache memory.

Example: let cache be of 64 kByte that is divided into blocks of 4 bytes hence cache is 16 k ( $2^{14}$ ) lines of 4 bytes. Let the main memory size be 16 M Bytes that requires

24-bit address lines ( $2^{24} = 16M$ ).

For this example for set associative mapping address structure: 2 bits for one of the 4 words, 8K lines in each of the 2 sets hence 13 bits to select a set ( $2^{13} = 8K$ ) and remaining ( $24 - 13 - 2 = 9$ ) bits for tag.

[ Tag (9 bits) | Set (13 bits) | Word (2 bits) ]

Advantages:

- 1) If a program accesses 2 blocks that map to the same set repeatedly, cache misses will not occur because they would go into different lines of the set.
- 2) Not very complex because of just 2, 4 or 8 parallel comparisons.
- 3) Not much expensive again because of simple implementation.

Assignment No 2: To brush up your knowledge about Multicore architecture.

Multicore refers to an architecture in which a single physical processor incorporates the core logic of more than one processor. A single integrated circuit is used to package or hold these processors. These single integrated circuits are known as a die. Multicore architecture places multiple processor cores and bundles them as a single physical processor. The objective is to create a system that can complete more tasks at the same time, thereby gaining better overall system performance.

This technology is most commonly used in multicore processors, where two or more processors, chips or cores run concurrently as a single system. Multicore-based processors are used in mobile devices, desktops, workstations and servers.

The concept of multicore technology is mainly centered on the possibility of parallel computing, which can significantly boost computer speed and efficiency by including two or more Central Processing Units (CPUs) in a single chip. This reduces the system's heat and power consumption. This means much better performance with less or the same amount of energy.

The architecture of a multicore processor enables communication between all available cores to ensure that the processing tasks are divided and assigned accurately. At the time of task completion, the processed data from each core is delivered back to the motherboard by means of a single shared gateway. This technique significantly enhances performance compared to a single-core processor of similar speed.

Multicore technology is very effective in challenging tasks and applications, such as encoding, 3-D gaming and video editing.