Article ID: | iaor201113497 |
Volume: | 59 |
Issue: | 1 |
Start Page Number: | 95 |
End Page Number: | 118 |
Publication Date: | Jan 2012 |
Journal: | Numerical Algorithms |
Authors: | Ogita Takeshi, Ozaki Katsuhisa, Oishi Shinichi, Rump Siegfried |
Keywords: | numerical analysis |
This paper is concerned with accurate matrix multiplication in floating‐point arithmetic. Recently, an accurate summation algorithm was developed by Rump et al. (2008). The key technique of their method is a fast error‐free splitting of floating‐point numbers. Using this technique, we first develop an error‐free transformation of a product of two floating‐point matrices into a sum of floating‐point matrices. Next, we partially apply this error‐free transformation and develop an algorithm which aims to output an accurate approximation of the matrix product. In addition, an a priori error estimate is given. It is a characteristic of the proposed method that in terms of computation as well as in terms of memory consumption, the dominant part of our algorithm is constituted by ordinary floating‐point matrix multiplications. The routine for matrix multiplication is highly optimized using BLAS, so that our algorithms show a good computational performance. Although our algorithms require a significant amount of working memory, they are significantly faster than ‘gemmx’ in XBLAS when all sizes of matrices are large enough to realize nearly peak performance of ‘gemm’. Numerical examples illustrate the efficiency of the proposed method.