Automating the Last-Mile for High Performance Dense Linear Algebra
Department of Electrical and Computer Engineering, Carnegie Mellon University
arXiv:1611.08035 [cs.MS], (24 Nov 2016)
@article{veras2016automating,
title={Automating the Last-Mile for High Performance Dense Linear Algebra},
author={Veras, Richard Michael and Low, Tze Meng and Smith, Tyler Michael and Geijn, Robert van de and Franchetti, Franz},
year={2016},
month={nov},
archivePrefix={"arXiv"},
primaryClass={cs.MS}
}
High performance dense linear algebra (DLA) libraries often rely on a general matrix multiply (Gemm) kernel that is implemented using assembly or with vector intrinsics. In particular, the real-valued Gemm kernels provide the overwhelming fraction of performance for the complex-valued Gemm kernels, along with the entire level-3 BLAS and many of the real and complex LAPACK routines. Thus,achieving high performance for the Gemm kernel translates into a high performance linear algebra stack above this kernel. However, it is a monumental task for a domain expert to manually implement the kernel for every library-supported architecture. This leads to the belief that the craft of a Gemm kernel is more dark art than science. It is this premise that drives the popularity of autotuning with code generation in the domain of DLA. This paper, instead, focuses on an analytical approach to code generation of the Gemm kernel for different architecture, in order to shed light on the details or voo-doo required for implementing a high performance Gemm kernel. We distill the implementation of the kernel into an even smaller kernel, an outer-product, and analytically determine how available SIMD instructions can be used to compute the outer-product efficiently. We codify this approach into a system to automatically generate a high performance SIMD implementation of the Gemm kernel. Experimental results demonstrate that our approach yields generated kernels with performance that is competitive with kernels implemented manually or using empirical search.
December 14, 2016 by hgpu