CS224 Lab No: 6 Section No: 06 Barış Tan Ünal 22003617

### **CS224 LAB 6 CACHE SIMULATOR REPORT**

## PART A.1) COLUMN WISE COPY

#### 100x100 MATRIX

| Block Size<br>(words) /<br>Cache Size<br>(bytes) | 128 words | 256 words | 512 words | 1024 words | 2048 words |
|--------------------------------------------------|-----------|-----------|-----------|------------|------------|
| 8 MB                                             | 77%       | 39%       | 52%       | 75%        | 98%        |
| O IVID                                           | 15.644    | 7.859     | 10.582    | 15.202     | 20.002     |
| 16 MB                                            | 77%       | 38%       | 20%       | 10%        | 17%        |
| 10 MD                                            | 19.620    | 7.903     | 4.003     | 2.003      | 3.503      |
| 22 MD                                            | 76%       | 37%       | 20%       | 10%        | 15%        |
| 32 MB                                            | 15.644    | 7.835     | 4.003     | 2.043      | 3.002      |
| 64 MB                                            | 29%       | 15%       | 8%        | 5%         | 3%         |
| 04 MB                                            | 5.822     | 3.051     | 1.626     | 1.013      | 607        |
| 120 MD                                           | 2%        | 1%        | 1%        | 1%         | 1%         |
| 128 MB                                           | 160       | 81        | 41        | 22         | 13         |

Table 1.1, Miss rates and miss counts for given block and cache sizes with LRU replacement policy for 100x100 matrix while performing column-wise copying.

#### 60x60 MATRIX

| Block Size<br>(words) /<br>Cache Size<br>(bytes) | 64 words | 128 words | 256 words | 512 words | 1024 words |
|--------------------------------------------------|----------|-----------|-----------|-----------|------------|
| 4 MB                                             | 89%      | 45%       | 23%       | 12%       | 95%        |
| 4 MD                                             | 6.757    | 3.424     | 1.743     | 903       | 7.202      |
| 8 MB                                             | 89%      | 45%       | 23%       | 12%       | 44%        |
| o IVID                                           | 6.756    | 3.420     | 1.743     | 903       | 3.342      |
| 16 MB                                            | 77%      | 39%       | 20%       | 11%       | 44%        |
| 10 MD                                            | 5.843    | 2.953     | 1.525     | 835       | 3.314      |
| 32 MB                                            | 3%       | 2%        | 1%        | 1%        | 1%         |
| 32 IVID                                          | 117      | 60        | 31        | 17        | 10         |
| CA MD                                            | 2%       | 1%        | 1%        | 1%        | 1%         |
| 64 MB                                            | 117      | 59        | 31        | 16        | 10         |

Table 1.2, Miss rates and miss counts for given block and cache sizes with LRU replacement policy for 60x60 matrix while performing column-wise copying.



Table 2.1, Miss rate vs block size and cache size line chart for 100x100 matrix while performing column-wise copying.



Table 2.2, Miss rate vs block size and cache size line chart for 60x60 matrix while performing column-wise copying.

# PART A.2) ROW WISE COPY

### 100x100 MATRIX

| Block Size<br>(words) /<br>Cache Size<br>(bytes) | 128 words | 256 words | 512 words | 1024 words | 2048 words |
|--------------------------------------------------|-----------|-----------|-----------|------------|------------|
| 8 MB                                             | 99%       | 94%       | 52%       | 75%        | 98%        |
| o MD                                             | 161       | 1.252     | 10.531    | 15.202     | 20.002     |
| 16 MB                                            | 2%        | 1%        | 1%        | 1%         | 12%        |
| 10 MD                                            | 161       | 82        | 43        | 24         | 2.414      |
| 32 MB                                            | 2%        | 1%        | 1%        | 1%         | 10%        |
| 32 IVID                                          | 161       | 82        | 43        | 24         | 1.934      |
| 64 MB                                            | 2%        | 1%        | 1%        | 1%         | 1%         |
| 04 MD                                            | 160       | 81        | 42        | 22         | 12         |
| 120 MD                                           | 2%        | 1%        | 1%        | 1%         | 1%         |
| 128 MB                                           | 159       | 81        | 42        | 21         | 9          |

Table 2.1, Miss rates and miss counts for given block and cache sizes with LRU replacement policy for 100x100 matrix while performing row-wise copying.

### **60x60 MATRIX**

| Block Size<br>(words) /<br>Cache Size<br>(bytes) | 64 words | 128 words | 256 words | 512 words | 1024 words |
|--------------------------------------------------|----------|-----------|-----------|-----------|------------|
| 4 MB                                             | 2%       | 1%        | 1%        | 3%        | 5%         |
| 4 MD                                             | 118      | 61        | 132       | 258       | 7.202      |
| 8 MB                                             | 2%       | 1%        | 1%        | 3%        | 45%        |
| O IVID                                           | 118      | 61        | 32        | 228       | 3.395      |
| 1.6 MD                                           | 77%      | 39%       | 20%       | 11%       | 44%        |
| 16 MB                                            | 5.843    | 2.953     | 1.525     | 835       | 3.314      |
| 32 MB                                            | 2%       | 1%        | 1%        | 1%        | 1%         |
| 32 MD                                            | 117      | 61        | 31        | 17        | 10         |
| 64 MD                                            | 2%       | 1%        | 1%        | 1%        | 1%         |
| 64 MB                                            | 116      | 59        | 31        | 17        | 10         |

Table 2.2, Miss rates and miss counts for given block and cache sizes with LRU replacement policy for 60x60 matrix while performing row-wise copying.

# PART B)

## 100x100 MATRIX

|                             | Hit Rate: Good   | Hit Rate: Medium | Hit Rate: Poor   |
|-----------------------------|------------------|------------------|------------------|
|                             | Cache Size: 64MB | Cache Size: 16MB | Cache Size: 8MB  |
|                             | Block Size: 1024 | Block Size: 256  | Block Size: 1014 |
| Direct Mapped               | 4%               | 39%              | 75%              |
| Direct Mapped               | 814              | 7.899            | 15.334           |
| Fully Associative I BU      | 10%              | 39%              | 11%              |
| Fully Associative LRU       | 2002             | 7.903            | 2.182            |
| Fully Associative Random    | 5%               | 40%              | 21%              |
| rully Associative Kalluolli | 1051             | 8.104            | 4.242            |

Table 3.1, Miss rates and miss counts for three types of caches for 100x100 matrix while performing column-wise copying.

### 60x60 MATRIX

|                          | Hit Rate: Good   | Hit Rate: Medium | Hit Rate: Poor  |
|--------------------------|------------------|------------------|-----------------|
|                          | Cache Size: 32MB | Cache Size: 16MB | Cache Size: 4MB |
|                          | Block Size: 64   | Block Size: 128  | Block Size: 64  |
| Direct Manned            | 1%               | 40%              | 89%             |
| Direct Mapped            | 60               | 3.010            | 6.757           |
| Fully Associative I BII  | 1%               | 45%              | 89%             |
| Fully Associative LRU    | 59               | 3.412            | 6.761           |
| Fully Associative Random | 1%               | 34%              | 90%             |
| Fully Associative Random | 60               | 2.607            | 6.782           |

Table 3.2, Miss rates and miss counts for three types of caches for 60x60 matrix while performing column-wise copying.

# PART C)

## 100x100 MATRIX

| N-Way Set         | Hit Rate: Good   | Hit Rate: Medium | Hit Rate: Poor   |
|-------------------|------------------|------------------|------------------|
| Associative Cache | Cache Size: 64MB | Cache Size: 16MB | Cache Size: 32MB |
| Set Size          | Block Size: 512  | Block Size: 128  | Block Size: 64   |
| 1                 | 7%               | 77%              | 88%              |
| 1                 | 1.490            | 15.664           | 18.030           |
| 2                 | 12%              | 77%              | 91%              |
| Δ                 | 2.419            | 15.652           | 18.591           |
| 1                 | 19%              | 77%              | 95%              |
| 4                 | 3.852            | 15.664           | 19.344           |
| 8                 | 20%              | 77%              | 98%              |
| 8                 | 4.003            | 15.664           | 20.004           |

Table 4.1, Miss rates and miss counts for three types of caches for 100x100 matrix while performing column-wise copying.

### **60x60 MATRIX**

| N-Way Set         | Hit Rate: Good   | Hit Rate: Medium | Hit Rate: Poor   |  |  |
|-------------------|------------------|------------------|------------------|--|--|
| Associative Cache | Cache Size: 64MB | Cache Size: 16MB | Cache Size: 32MB |  |  |
| Set Size          | Block Size: 512  | Block Size: 32   | Block Size: 64   |  |  |
| 1                 | 7%               | 43%              | 88%              |  |  |
| 1                 | 1.490            | 3.224            | 18.030           |  |  |
| 2                 | 12%              | 56%              | 91%              |  |  |
| Δ                 | 2.419            | 4.254            | 18.591           |  |  |
| 4                 | 19%              | 64%              | 95%              |  |  |
|                   | 3.852            | 4.870            | 19.344           |  |  |
| Q                 | 20%              | 4%               | 98%              |  |  |
| 8                 | 4.003            | 336              | 20.004           |  |  |

Table 4.2, Miss rates and miss counts for three types of caches for 60x60 matrix while performing column-wise copying.