Implementing Strassen’s Algorithm with CUTLASS on NVIDIA Volta GPUs
Institute for Computational Engineering and Sciences, The University of Texas at Austin, Austin, TX 78712
arXiv:1808.07984 [cs.MS], (24 Aug 2018)
@article{huang2018implementing,
title={Implementing Strassen’s Algorithm with CUTLASS on NVIDIA Volta GPUs},
author={Huang, Jianyu and Yu, Chenhan D. and Geijn, Robert A. van de},
year={2018},
month={aug},
archivePrefix={"arXiv"},
primaryClass={cs.MS}
}
Conventional GPU implementations of Strassen’s algorithm (Strassen) typically rely on the existing high-performance matrix multiplication (GEMM), trading space for time. As a result, such approaches can only achieve practical speedup for relatively large, "squarish" matrices due to the extra memory overhead, and their usages are limited due to the considerable workspace. We present novel Strassen primitives for GPUs that can be composed to generate a family of Strassen algorithms. Our algorithms utilize both the memory and thread hierarchies on GPUs, reusing shared memory and register files inherited from GEMM, fusing additional operations, and avoiding extra workspace. We further exploit intra- and inter-kernel parallelism by batching, streaming, and employing atomic operations. We also develop a performance model for NVIDIA Volta GPUs to select the appropriate blocking parameters and predict the performance for GEMM and Strassen. Overall, our 1-level Strassen can achieve up to 1.11x speedup with a crossover point as small as 1,536 compared to cublasSgemm on a NVIDIA Tesla V100 GPU. With additional workspace, our 2-level Strassen can achieve 1.19x speedup with a crossover point at 7,680.
September 2, 2018 by hgpu