Understanding the Efficiency of GPU Algorithms for Matrix-Matrix Multiplication

Loading...
Thumbnail Image
Date
2004
Journal Title
Journal ISSN
Volume Title
Publisher
The Eurographics Association
Abstract
Utilizing graphics hardware for general purpose numerical computations has become a topic of considerable interest. The implementation of streaming algorithms, typified by highly parallel computations with little reuse of input data, has been widely explored on GPUs. We relax the streaming model's constraint on input reuse and perform an in-depth analysis of dense matrix-matrix multiplication, which reuses each element of input matrices O(n) times. Its regular data access pattern and highly parallel computational requirements suggest matrix-matrix multiplication as an obvious candidate for efficient evaluation on GPUs but, surprisingly we find even nearoptimal GPU implementations are pronouncedly less efficient than current cache-aware CPU approaches. We find the key cause of this inefficiency is that the GPU can fetch less data and yet execute more arithmetic operations per clock than the CPU when both are operating out of their closest caches. The lack of high bandwidth access to cached data will impair the performance of GPU implementations of any computation featuring significant input reuse.
Description

        
@inproceedings{
10.2312:EGGH/EGGH04/133-138
, booktitle = {
Graphics Hardware
}, editor = {
Tomas Akenine-Moeller and Michael McCool
}, title = {{
Understanding the Efficiency of GPU Algorithms for Matrix-Matrix Multiplication
}}, author = {
Fatahalian, K.
and
Sugerman, J.
and
Hanrahan, P.
}, year = {
2004
}, publisher = {
The Eurographics Association
}, ISSN = {
1727-3471
}, ISBN = {
3-905673-15-0
}, DOI = {
10.2312/EGGH/EGGH04/133-138
} }
Citation