How does the performance of a cache change with cache size


Assignment

Objective

For this programming assignment, you will design and implement a cache simulator. Your simulator will read a memory access trace from a file, determine whether each memory access is a hit or a miss, and output the hit rate. You can use whatever programming language you choose to implement your simulator (e.g. C++, Java, Python).

You will then analyze the performance (hit rate) of three cache designs. You will create this in an analysis paper which should answer the following questions:

A. How does the performance of a cache change with its associativity? (e.g. direct mapped vs n-way associative vs fully associative)
B. How does the performance of a cache change with cache size?
C. How does the performance change with replacement policy?

Important Information

The format of the memory trace file is the following:

A. The first field is "l" or "s" depending on whether the processor is loading from or storing to memory. You don't need to do anything differently for load or store.

B. The second field is a 32-bit memory address.

C. The third field is the number of bytes being requested.

You don't need to do anything with the number of bytes being requested. The only field you care about is the address. You may assume that each request will be contained in one block.

I have provided some sample trace files in the Canvas directory Files / Cache Analysis.

A. The small files are for debugging. Your analysis should be based on the hit rates for the larger files.
B. You can use your own using the valgrind lackey tool.

Sharing trace files and results is welcomed and encouraged.

Guidelines

Items to Examine

A. Parameters

a. Number of bytes in the cache (a positive power of 2)
b. Number of blocks in each set (associativity)
c. Number of bytes in a block (a positive power of 2, must be at least 4)
d. 1 set of n blocks is fully associative
e. n sets of 1 block is direct mapped
f. n sets of m blocks is m-way set associative

B. Replacement policy (for caches that aren't direct mapped)

a. Least recently used (LRU)
b. First in, first out (FIFO)

C. Examine effect of changing cache type

a. Direct mapped vs. Set associative vs. Fully associative

D. Examine effect of replacement type

E. Examine effect of cache size

Analysis Paper

Objective

Design a paper with your analysis of cache designs.

Sections to Include

A. Introduction

a. Description of simulation

B. Description of Tests

a. What were the parameters for each test? Include the values of parameters. Give a table with the parameter values for each test.
b. Make sure to specify the associativity for set associative.
c. Why did you choose these parameters?

C. Results

a. What were the hit rates for the different configurations?
b. Create plots to show your results.

i. Example: Line graph of hit rate vs cache size, with separate lines for FIFO and LRU

ii. Make sure your plots are labeled on the x and y axes. y axis should be hit rate, x axis is independent variable. Give units on the independent variable (e.g. bytes)

D. Conclusions

a. What can you say about cache design (direct mapped/set associative/fully associative)?
b. What can you say about replacement policies?
c. What can you say about cache size?

Request for Solution File

Ask an Expert for Answer!!
Computer Engineering: How does the performance of a cache change with cache size
Reference No:- TGS03276327

Expected delivery within 24 Hours