

# SPPAM: Signature Pattern Prediction and Access-Map Prefetcher

Maccroy Merrell, Lei Wang, Stavros Kalafatis, Paul V. Gratz  
{maccroy.merrell,wilsonwang2019,skalafatis-tamu,pgratz}@tamu.edu

Texas A&M University  
College Station, Texas, USA

## Abstract

The discrepancy between processor speed and memory system performance continues to limit the performance of many workloads. To address the issue, one effective and well studied technique is cache prefetching. Many prefetching designs have been proposed, with varying approaches and effectiveness. For example, SPP is a popular prefetcher that leverages confidence throttled recursion to speculate on the future path of the program's references, however it is very susceptible to the reference reordering of higher-level caches and the OoO core. Orthogonally, AMPM is another popular approach to prefetching which uses reordering-resistant access maps to identify patterns within a region but is unable to speculate beyond that region. In this paper, we propose SPPAM, a new approach to prefetching, inspired by prior works such as SPP and AMPM, while addressing their limitations. SPPAM utilizes online-learning to build a set of access-map patterns. These patterns are used in a speculative lookahead which is throttled by a confidence metric. Targeting the second-level cache, SPPAM alongside state-of-the-art prefetchers Berti and Bingo improve system performance by 31.4% over no prefetching and 6.2% over the baseline of Berti and Pythia.

## CCS Concepts

- Computer systems organization → Architectures.

## Keywords

Computer Architecture, Cache, Prefetching

### ACM Reference Format:

Maccroy Merrell, Lei Wang, Stavros Kalafatis, Paul V. Gratz. 2026. SPPAM: Signature Pattern Prediction and Access-Map Prefetcher . In *Proceedings of 4th Data Prefetching Championship (DPC-4)*. ACM, Sydney, Australia, 6 pages. <https://doi.org/10.1145/nnnnnnnn.nnnnnnn>

## 1 Introduction

As is well known, the processor has outpaced the speed of the memory system and memory system performance has become a major bottleneck. This phenomenon, known as the *Memory Wall*, plagues memory-bound workloads. A common and effective technique to address this issue is hardware prefetching which speculatively populates the caches with data, ideally maximizing coverage, timeliness

---

Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. Copyrights for components of this work owned by others than the author(s) must be honored. Abstracting with credit is permitted. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from [permissions@acm.org](mailto:permissions@acm.org).

DPC-4, Sydney, Australia

© 2026 Copyright held by the owner/author(s). Publication rights licensed to ACM.  
ACM ISBN 978-x-xxxx-xxxx-x/YY/MM  
<https://doi.org/10.1145/nnnnnnnn.nnnnnnn>

and accuracy [9]. Many prefetcher designs have been proposed, among these being AMPM [5], Bingo [1], Pythia [2], Berti [8] and SPP [6]. Each of these prefetchers have certain strengths and weaknesses, targeting different cache levels and offering widely varying state overheads. SPP [6] is a popular prefetcher that leverages confidence throttled recursion to speculate on the future path of the program's references. SPP, however, requires consistent replays of the same pattern of access, making it very susceptible to the reference reordering caused by higher-level caches and the OoO core. Orthogonally, AMPM, though somewhat older, has been implemented in recent systems [3, 7]. AMPM uses reordering-resistant reference pattern matching via access maps to identify patterns within a region. While this technique speculates well within the given region, it does not extend patterns beyond that space.

In this paper, we propose SPPAM, a new approach to prefetching, inspired by prior works such as SPP and AMPM, while addressing their limitations. SPPAM utilizes online-learning to build a set of access-map patterns. These patterns are used in a speculative lookahead which is throttled by a confidence metric. Targeting the second-level cache, SPPAM alongside state-of-the-art prefetchers Berti and Bingo improve system performance by 31.4% over no prefetching and 6.2% over the baseline of Berti and Pythia.

## 2 Previous Works

Second-level-cache (L2C) prefetching offers the most potential compared to other cache levels [10]. The size of the cache and its private nature allows for large working sets and speculative data to coexist, which cannot be said of the smaller first-level data caches (L1D). Unlike the last-level-cache (LLC), the L2C is close to the core and has lower access latency which means successful prefetches are more effective at reducing apparent latency from the CPU. It also offers challenges, primarily in the form of information. The L2C receives accesses that are heavily reordered by the core, and these reordered requests are heavily filtered and randomly decimated by the L1D. Learning from these patterns is difficult without complex pattern recognition techniques, and such techniques are prone to over-differentiation.

The Signature Path Prefetcher (SPP) addresses some of the problems of L2C prefetching by identifying repeated access patterns in the form of delta signatures. These signatures are page-, offset-, and time- agnostic, instead only recording the past three differences between consecutive block accesses in a page and predicting the subsequent one through previous access patterns. This allows for SPP to aggressively collect and apply data patterns in prefetching even in data regions with no history, with high accuracy. These predictions can be used recursively by appending the predicted delta to the signature, allowing SPP to speculate deeply into an access stream upon only a small number of initial accesses. Over time, this history leads to emergent prefetching behavior allowing SPP

to predict complex access patterns. This technique has a clear weak point: its signatures are order-dependent. If requests to the L2C are reordered (likely, as previously described) then the signature will change, resulting in the same memory pattern being reclassified upon subsequent accesses. This prevents some patterns from being correctly identified and its state from being efficiently used, thus causing losses in performance.

A popular order-agnostic prefetcher design is known as AMPM. AMPM, unlike SPP, checks the use of nearby blocks in a region rather than deltas. The pattern of block accesses can then be used to inform which other blocks need pulled into the cache. AMPM's algorithm is resilient to reordering interference, as these access maps encode no order information. AMPM typically relies on static pattern matching, meaning that access patterns that are outside AMPM's internal catalog are ignored. Likewise, AMPM can make only a single set of predictions from a pattern, solely within the scope of the pattern itself. Workloads whose following accesses do not exactly match AMPM's pre-programmed expectations yield many incorrect predictions and thus performance loss. Other workloads may be inherently incompatible with AMPM, particularly if they have access patterns with significant internal page fragmentation. Techniques like scanning can help compensate for this, where areas around the initial access are evaluated for potential pattern matches, but if too many regions are active at once AMPM begins losing region history and thus suffers substantial performance degradation. These two strategies are effective in isolation despite their flaws, suggesting that future spatial data prefetchers that which to supercede these designs should leverage their strengths and avoid these weaknesses.

### 3 Motivation

Utilizing history for making predictions is a powerful technique utilized not only in hardware prefetching but also in branch prediction. Unlike branch prediction, identifying the history of memory accesses requires far more discernment. AMPM, SPP, and other spatial data prefetchers correctly identified that segmenting the histories of memory accesses by region leads to many patterns being found that are not readily apparent from observing the access stream in-order. Crucially, data structures are not merely read, but operated upon. These data structures may be accessed in a well-ordered and observable way, but this behavior may be intermittent with other memory being utilized in-between. Even when these patterns should be easily identified, processors issue memory requests out-of-order and some memory requests may hit in upper-level caches while others will not. These patterns fluctuate under short-term observation, leading prefetchers who attempt to learn detailed delta-based histories to fail. Instead of delta-based prefetching, a prefetcher which encodes a history of which nearby blocks have been utilized (such as AMPM) is immune to this fluctuation. While AMPM does not learn from its history, a different prefetcher utilizing this strategy could delay learning any current patterns until it is certain the history has stabilized, and likewise can revisit old history and re-evaluate it as patterns emerge.



Figure 1: SPPAM Architecture

### 4 Design Overview

We propose the Signature Pattern Prediction and Access Map (SPPAM) prefetcher, which combines novel techniques as well as those from SPP and AMPM into a single system, attempting to rectify each strategies' individual weaknesses. We utilize AMPM's region-tracking technique to record accesses to individual regions in access maps. For each of these accesses, the segment of the access map before the current access can be extracted and used as a pattern. A pattern can be taken from both before (positive) and after (negative) the offset into the region. These patterns are then used to access a direct-mapped pair of positive and negative pattern tables. These tables track the most-common access map pattern pairs, with a fully-associative set of matches being stored within each entry as a prediction. The most-common entry is selected for use as the prediction, which indicates which of the next consecutive blocks in the region will be prefetched. The predicted sequence is of the same width as the index into the pattern table, so it can be used recursively to generate prefetches deeper into the region, similarly to SPP's look-ahead feature, but far denser allowing for many predictions for each table lookup. Along with these improvements, SPPAM incorporates several different throttling techniques, taking in feedback in the form of DRAM bandwidth consumption and prefetch utilization.

Figure 1 shows SPPAM in the L2C, leaving both the L1D and LLC available for other prefetcher designs. For our design, we utilize Berti as the L1D prefetcher and Bingo as the LLC prefetcher. Minor improvements in these systems were made, in the figure these additions are shown in orange, with Berti utilizing an improved filter inspired by AMPM's region tables and Bingo being core-partitioned, preventing cross-core interference in Bingo's learning. Berti also provides region-association information to SPPAM from the virtual space, allowing SPPAM to use cross-page information.

#### 4.1 Region Table and Pattern Scraping

SPPAM's region table is managed as a set-associative table indexed by region number. Within each region table entry bitmaps are stored both for the accesses into the region and prefetches done into the region. The former bitmap is used to identify patterns, while the latter is used as a filter - being cleared and set as blocks in the region are populated into the cache. Region sizing determines



Figure 2: Region Table Architecture

the size of the bitmap and overall efficiency of representing the full memory space. Smaller region sizes introduce more state overhead, while larger sizes can potentially lead to significant internal fragmentation and wasted space within the region's bitmaps. We found that sizing regions to 4KiB is a good compromise, preventing additional complexity from sequencing non-consecutive physical pages into regions while not being so small as to incur significant storage overheads for workloads with large memory spaces. Figure 2 shows different access types into the region table. Either additional bits are added or removed from the internal bitmap structures, or patterns are retrieved from those bitmaps for use in the pattern table. Two additional pieces of data are stored within each region table entry compared to AMPM. These exist to facilitate a SPPAM-specific feature - pattern scraping. First, a timer has been added that indicates how long the region has gone without access. The second is an access counter which stores how many recent accesses have occurred into the region. If either the timer or the counter exceed their respective thresholds, a region scrape is initiated for the region. Region scraping is how SPPAM builds its pattern tables. Once a region has had sufficient activity or falls out-of-scope, the access map must be processed to identify which access patterns were present. The access map is navigated both from front to back and back to front for the positive and negative pattern tables. A rolling window of the access map (sized according to the pattern table) and the following pattern (offset ahead/behind) is tallied into the pattern table, modifying the confidence of the predictions for the given pattern.

## 4.2 Pattern Tables and Lookahead

The pattern tables are direct-mapped and sized according to the pattern window used by SPPAM. Each pattern is used to index into the table and produce the predicted pattern that follows. Each entry within the pattern table includes an associative set of predictions. This technique assumes that many different predictions may be associated with a single pattern. The most-common of these is



Figure 3: Pattern Table Architecture

expected to be the most-useful, since it offers the most opportunities to prefetch. For this reason, only the most-common prediction is used. These tables are susceptible to interference - particularly from other predictions within a hamming-distance of 1 from the most-common pattern. The impact of this interference can be somewhat negated by properly timing region scraping to avoid incomplete patterns from being learned and thus reducing the chance of small variations of the same pattern being encoded.

Three different types of information are stored within the pattern table, with the overall architecture shown in Figure 3. The prediction table tracks the confidence of different predictions. Confidence is increased each time a region scrape results in the predicted pattern being incremented, and the confidences of all entries in the table are halved when the confidence max is reached for any given pattern. The most-confident pattern above the minimum confidence is used as the prediction, with no valid pattern being returned if no prediction is above the minimum confidence. The least-confident pattern is chosen as the eviction candidate. In addition to the prediction table, each entry also includes useful and useless counters. As prefetches are utilized or evicted from the cache, their corresponding region provides the patterns that predicted the prefetch and inform the pattern table. The patterns within the pattern table track the counts and when the total of useless and useful prefetches reaches a sampling threshold, the usefulness of the pattern is estimated.

Figure 4 shows an overview of SPPAM's logic, including lookahead. Predicted patterns can be fed back into SPPAM to continue prefetching beyond the initial region offset. This can continue as long as the predicted pattern does not equal zero, at which point SPPAM proceeds with the standard AMPM strategy of scanning outwards from the original region offset to find more prefetch candidates. Upon each subsequent lookahead, SPPAM reduces the usefulness proportional to the predicted usefulness of the new pattern. This is continued until the prefetch degree is satisfied or usefulness falls too low to continue. How these thresholds are chosen is discussed further in the following section.

## 4.3 Global Metrics and Bandwidth

Alongside pattern usefulness, global usefulness is also estimated using a sampling procedure. Once enough samples of useful and useless prefetches are accumulated, the 4-bit global usefulness is set and remains until the next sampling. Pattern usefulness is effective at estimating the usefulness of a pattern as long as feedback from



Figure 4: SPPAM Lookahead

useful and useless prefetches can return in time for the region to still reside in the region table, otherwise global usefulness must be used. To determine if this is the case, a 4-bit region lifespan metric is tracked by SPPAM. Region lifespan is the proportion of useless prefetches evicted from the cache whose regions are still within the region table. A low region lifespan indicates that pattern usefulness is unreliable and SPPAM will instead use global usefulness. Usefulness controls two throttling mechanisms within SPPAM. The first of these is the prefetch degree, the number of prefetches that may be issued from a single cache access. As usefulness drops, the prefetch degree drops. Because of SPPAM's (and for that matter AMPM's) nature, this only reduces the rate at which prefetches are issued, and will not prevent a prefetch from eventually being issued. The second mechanism is prefetch dropping. If SPPAM predicts low usefulness for a given prefetch, then it has a chance of dropping the prefetch. The rate at which this is done increases as usefulness decreases. SPPAM never drops all prefetches, as samples are still required to determine usefulness. Dropping is implemented using a 7-bit counter that tracks the current cycle count, with prefetches being dropped if the cycle count that triggered the prefetch was below a certain value. A third throttling mechanism is controlled by available DRAM bandwidth, a 4-bit value provided by the memory controller. SPPAM reduces the prefetch degree by an amount proportional to the consumed bandwidth. The prefetch degree, prefetch drop chance, and bandwidth throttling are all hard-coded as 16-entry tables, indexed by the 4-bit usefulness and 4-bit bandwidth utilization respectively.

#### 4.4 Prefetch Filtering and LLC Prefetching

SPPAM filters prefetches via its region table. If a prefetch has already been issued, it will not be issued again until the region is out of scope or that prefetch is evicted from the cache. SPPAM may choose to fill only into the LLC if the MSHR of the L2C is currently fully occupied. The region table cannot track the occupancy of blocks within the LLC, so SPPAM utilizes a second region table that tracks only recently accessed or prefetched blocks within the LLC. If a block is bound for the LLC and resides in the LLC region table, it is dropped and not used. The LLC region table clears its entries as matching blocks in the L2C are evicted.

| Prefetcher | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Total State        |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| Berti      | Delta Table: 64 entries, 16 deltas each: 2.54 KiB<br>History Table: 8 sets, 16 ways: 0.74 KiB<br>L1D: 12-bit latency per line: 1.13 KiB<br>Region Filter: 64 sets, 12 ways, 30-bit region tag, 64-bit access map, 4-bit, 4-bit LRU: 9.19 KiB                                                                                                                                                                                                                                                 | 13.60 KiB          |
| Bingo      | Pattern History Table: 512 sets, 15 ways: 56.25 KiB<br>Filter Table: 4 sets, 16 ways: 0.48 KiB<br>Accumulation Table: 8 sets, 16 ways: 1.44 KiB<br>Prefetch Streamer: 8 sets, 16 ways: 1.86 KiB<br>Region Table: 128 sets, 24 ways, 29-bit region tag, 72-bit region adjacency tag, 64-bit access map, 64-bit prefetch map, 4-bit access counter, 9-bit access timer, 5-bit LRU: 92.63 KiB<br>LLC Region Table: 64 sets, 16 ways, 30-bit region tag, 64-bit access map, 4-bit LRU: 12.25 KiB | 60.03 KiB per core |
| SPPAM      | Pattern Table: 64 entries, 8-bit useful counter, 8-bit useless counter, 4-bit usefulness, 16-bit predictions, x2: 3.56 KiB<br>Cross-Page Tracker: 128 entries, 8-bit stream id, 36-bit region id, 1-bit direction: 0.71 KiB<br>Global Usefulness Tracker: 4-bit usefulness, 10-bit useful counter, 10-bit useless counter: 3 B<br>Region Lifespan Tracker: 4-bit lifespan, 8-bit hit counter, 8-bit miss counter: 2.5 B                                                                      | 109.16 KiB         |

Table 1: State Overheads

| SPPAM Configuration            |                                                           |
|--------------------------------|-----------------------------------------------------------|
| Pattern Size: 6-bit            | Scrape Time Threshold: 1000                               |
| Scrape Access Threshold: 14    | Prefetch Degrees: [1,1,2,2,2,3,3,4,4,8,8,12,12,16,16]     |
| Lookahead Decay, Cutoff: 13, 7 | Drop Chance: [123,120,110,110,80,50,10,0,0,0,0,0,0,0,0,0] |
| Scan Distance: 16              | Bandwidth Reduction: [0,0,0,0,1,1,1,2,2,4,4,4,8,8]        |
| Prefetch Drop Cutoff: 8        | Region Lifespan Cutoff: 7                                 |

Table 2: SPPAM Configuration

| System Configuration |                                                                                                                 |
|----------------------|-----------------------------------------------------------------------------------------------------------------|
| CPU                  | Frequency: 4 GHz, ROB Size: 576, LSQ Size: 352, Issue Width: 8, Retire Width: 8, Branch Predictor: Perceptron   |
| L1D                  | Sets: 64, Ways: 12, MSHR Size: 16, Latency: 5 cycles                                                            |
| L2C                  | Sets: 2048, Ways: 16, MSHR Size: 32, Latency: 10 cycles                                                         |
| LLC                  | Sets: 4096/core, Ways: 12, MSHR Size: 64/core, Latency: 35 cycles                                               |
| DRAM                 | MTPS: 4800 (LimitBW: 800), Channels: 1, Ranks: 1, Banks: 32 tCAS: 15 ns, tRCD: 15 ns, tRP: 15 ns, tRAS: 32.5 ns |

Table 3: System Configuration

#### 4.5 Berti and Virtual Prefetching

Berti is a state-of-the-art L1D virtual prefetcher and thus crosses page boundaries when prefetching. SPPAM operates within the physical space and thus cannot know which pages are consecutive. We modify Berti to pass along this information via a stream identification tag. This tag indicates that a sequence of prefetches are from the same access stream and the direction of the access stream. SPPAM utilizes this along with a small page crossing table to identify which regions are consecutive in both the forwards and backwards directions. SPPAM can then "shadow" region edges, allowing patterns that cross page boundaries to both be read and scraped. This also allows SPPAM to prefetch into new regions, utilizing the shadow-region information to jump-start the prefetching process. SPPAM does not issue prefetches across page boundaries, as it offers little to no performance benefit and presents potential security issues.

#### 5 State and Configuration

SPPAM is designed for use alongside Berti in the L1D and Bingo in the LLC. Both designs follow what was originally proposed, but Bingo has been partitioned per-cpu and its overall state slightly reduced per-core to remain within state limits when 4 instances of Bingo are present. Berti utilizes an additional filtering table



**Figure 5: Single core speedup over Berti + Pythia across DPC4 traces**



**Figure 6: Sorted 4 core speedup over Berti + Pythia across 50 mixes**

and provides stream-continuity information to SPPAM. SPPAM’s configuration is tabulated in Table 2 and the state overheads of the prefetchers in each level of the cache are tabulated in Table 1.

## 6 Evaluation Methodology

We use the ChampSim-based [4] DPC4 simulator and provided traces for evaluating SPPAM. We evaluate against the baseline of DPC3 Berti in the L1D and Pythia in the L2C. We evaluate SPPAM’s speedup in three different system configurations: single core, single core with limited bandwidth, and 4-core. The relevant details of each of these configurations are tabulated in Table 3.

For calculating the single-core speedups, the geometric mean of speedups across all traces is used. For multi-core, we calculate the harmonic mean of the speedup of the traces within each mix over the baseline prefetcher configuration.

## 7 Experimental Results and Conclusion

The speedups for each set of traces for both single core configurations are displayed in Figure 5, with geometric means of 6.2% and 5.9% for standard and limited-bandwidth runs respectively. SPPAM offers substantial speedups for the sierra, bc, cc, sssp, gcc, mcf, and xalancbmk workloads over both the baseline and standard AMPM.

Utilizing Bingo in the LLC offered slight performance improvements, with variations excluding Bingo seeing only a 5.5% speedup and 4.9% speedup for regular and bandwidth-limited runs.

Multi-core results are shown in Figure 6, with each mix sorted from lowest to highest speedup and a geometric mean slowdown of 2.12%. Bingo offers no performance advantages for SPPAM in multi-core, and could be excluded with minimal harm to the overall performance. SPPAM fares well in single-core low-bandwidth simulations, suggesting that LLC and DRAM conflicts likely play a key role in the slowdown, rather than reduced resources in-and-of themselves. For these reasons, SPPAM’s poor performance in multi-core can likely be resolved with proper tuning, and this will be pursued in future work.

## Acknowledgments

The authors acknowledge the support from the Purdue Center for Secure Microelectronics Ecosystem – CSME#210205.

## References

- [1] Mohammad Bakhshaliour, Mehran Shakerinava, Pejman Lotfi-Kamran, and Hamid Sarbazi-Azad. 2019. Bingo Spatial Data Prefetcher. In *2019 IEEE International Symposium on High Performance Computer Architecture (HPCA)*. 399–411. doi:10.1109/HPCA.2019.00053
- [2] Rahul Bera, Konstantinos Kanellopoulos, Anant Nori, Taha Shahroodi, Sreenivas Subramoney, and Onur Mutlu. 2021. Pythia: A Customizable Hardware Prefetching Framework Using Online Reinforcement Learning. In *MICRO-54: 54th Annual IEEE/ACM International Symposium on Microarchitecture (Virtual Event, Greece) (MICRO ’21)*. Association for Computing Machinery, New York, NY, USA, 1121–1137. doi:10.1145/3466752.3480114
- [3] Magnus Bruce. 2023. *Arm Neoverse V2 platform: Leadership Performance and Power Efficiency for NextGeneration Cloud Computing, ML and HPC Workloads*. IEEE.
- [4] Nathan Gober, Gino Chacon, Lei Wang, Paul V. Gratz, Daniel A. Jimenez, Elvira Teran, Seth Pugsley, and Jinchun Kim. 2022. The Championship Simulator: Architectural Simulation for Education and Competition. arXiv:2210.14324 [cs.AR] https://arxiv.org/abs/2210.14324
- [5] Yasuo Ishii, Mary Inaba, and Kei Hiraki. 2011. Access map pattern matching for high performance data cache prefetch. *Journal of Instruction-Level Parallelism* 13, 2011 (2011), 1–24.
- [6] Jinchun Kim, Seth H. Pugsley, Paul V. Gratz, A. L. Narasimha Reddy, Chris Wilkerson, and Zeshan Chishti. 2016. Path confidence based lookahead prefetching. In *The 49th Annual IEEE/ACM International Symposium on Microarchitecture (Taipei, Taiwan) (MICRO-49)*. IEEE Press, Taipei, Taiwan, Article 60, 12 pages.

- [7] Stephan G Meier, Gerard R Williams, Hari S Kannan, and Pavlos Konas. 2015. Access map-pattern match based prefetch unit for a processor.
- [8] Agustín Navarro-Torres, Biswabandan Panda, Jesús Alastruey-Benedé, Pablo Ibáñez, Víctor Viñals-Yúfera, and Alberto Ros. 2022. Berti: an Accurate Local-Delta Data Prefetcher. In *2022 55th IEEE/ACM Int. Symp. on Microarchitecture*. IEEE Press, Chicago, IL, USA, 975–991. doi:10.1109/MICRO56248.2022.00072
- [9] Viji Srinivasan, E.S. Davidson, and G.S. Tyson. 2004. A prefetch taxonomy. *IEEE Trans. Comput.* 53, 2 (2004), 126–140. doi:10.1109/TC.2004.1261824
- [10] Lei Wang, Chia-Hang Lee, Maccoy Merrell, Gino Chacon, Daniel A. Jiménez, and Paul V. Gratz. 2025. R-Max: A Method for Approximating the Benefit of Ideal Prefetching and Replacement Policy. *IEEE Computer Architecture Letters* 24, 2 (2025), 293–296. doi:10.1109/LCA.2025.3611316

Received 19 December 2026