The Community for Technology Leaders
Green Image
Issue No. 01 - January/February (2011 vol. 28)
ISSN: 0740-7459
pp: 39-50
Geoff Lowney , Intel
Ryan Newton , Intel
Mark Hampton , Intel
In the era of multicores, many applications that require substantial computing power and data crunching can now run on desktop PCs. However, to achieve the best possible performance, developers must write applications in a way that exploits both parallelism and cache locality. This article proposes one such approach for x86-based architectures that uses cache-oblivious techniques to divide a large problem into smaller subproblems, which are mapped to different cores or threads. The authors then use the compiler to exploit SIMD parallelism within each subproblem. Finally, they use autotuning to pick the best parameter values throughout the optimization process. The authors have implemented this approach with the Intel compiler and the newly developed Intel Software Autotuning Tool. Experimental results collected on a dual-socket quad-core Nehalem show that the approach achieves an average speed up of almost 20x over the best serial cases for an important set of computational kernels.
multicore, throughput computing, cache-oblivious algorithms, parallelization, simdization, vectorization, autotuning, Intel Nehalem
Geoff Lowney, Ryan Newton, Mark Hampton, Chi-Keung Luk, William Hasenplaugh, "A Synergetic Approach to Throughput Computing on x86-Based Multicore Desktops", IEEE Software, vol. 28, no. , pp. 39-50, January/February 2011, doi:10.1109/MS.2011.2
281 ms
(Ver 3.3 (11022016))