Efficient sorting using registers and caches

  • Authors:
  • Rajiv Wickremesinghe;Lars Arge;Jeffrey S. Chase;Jeffrey Scott Vitter

  • Affiliations:
  • Department of Computer Science, Duke University, Box 90129, Durham, NC;Department of Computer Science, Duke University, Box 90129, Durham, NC;Department of Computer Science, Duke University, Box 90129, Durham, NC;Department of Computer Science, Duke University, Box 90129, Durham, NC

  • Venue:
  • Journal of Experimental Algorithmics (JEA)
  • Year:
  • 2002

Quantified Score

Hi-index 0.00

Visualization

Abstract

Modern computer systems have increasingly complex memory systems. Common machine models for algorithm analysis do not reflect many of the features of these systems, e.g., large register sets, lockup-free caches, cache hierarchies, associativity, cache line fetching, and streaming behavior. Inadequate models lead to poor algorithmic choices and an incomplete understanding of algorithm behavior on real machines.A key step toward developing better models is to quantify the performance effects of features not reflected in the models. This paper explores the effect of memory system features on sorting performance. We introduce a new cache-conscious sorting algorithm, R-MERGE, which achieves better performance in practice over algorithms that are superior in the theoretical models. R-MERGE is designed to minimize memory stall cycles rather than cache misses by considering features common to many system designs.