Tile size selection revisited

Sanyam Mehta, Gautham Beeraka, Pen-Chung Yew

Research output: Contribution to journalArticlepeer-review

22 Scopus citations

Abstract

Loop tiling is a widely used loop transformation to enhance data locality and allow data reuse. In the tiled code, however, tiles of different sizes can lead to significant variation in performance. Thus, selection of an optimal tile size is critical to performance of tiled codes. In the past, tile size selection has been attempted using both static analytical and dynamic empirical (auto-tuning) models. Past work using static models assumed a direct-mapped cache for the purpose of analysis and thus proved to be less robust. On the other hand, the auto-tuning models involve an exhaustive search in a large space of tiled codes. In this article, we propose a new analytical model for tile size selection that leverages the high set associativity in modern caches to minimize conflict misses. Our tile size selection model targets data reuse in multiple levels of cache. In addition, it considers the interaction of tiling with the SIMD unit in modern processors in estimating the optimal tile size. We find that these factors, not considered in previous models, are critical in developing a robust model for tile size selection. We implement our tile size selection model in a polyhedral compiler and test it on 12 benchmark kernels using two different problem sizes. Our model outperforms the previous analytical models that are based on reusing data in a single level of cache and achieves an average performance improvement of 9.7% and 20.4%, respectively, over the best square (cubic) tiles for the two problem sizes. In addition, the tile size chosen by our tile size selection algorithm is similar to the best performing size obtained through an extensive search, validating the analytical model underlying the algorithm.

Original languageEnglish (US)
Article number35
JournalTransactions on Architecture and Code Optimization
Volume10
Issue number4
DOIs
StatePublished - Dec 1 2013

Keywords

  • Loop tiling
  • Multilevel cache
  • Tile size selection
  • Vectorization

Fingerprint Dive into the research topics of 'Tile size selection revisited'. Together they form a unique fingerprint.

Cite this