High performance matrix inversion based on LU factorization for multicore architectures

Jack Dongarra, Mathieu Faverge, Hatem Ltaief, Piotr R. Luszczek

Research output: Chapter in Book/Report/Conference proceedingConference contribution

21 Scopus citations

Abstract

The goal of this paper is to present an efficient implementation of an explicit matrix inversion of general square matrices on multicore computer architecture. The inversion procedure is split into four steps: 1) computing the LU factorization, 2) inverting the upper triangular U factor, 3) solving a linear system, whose solution yields inverse of the original matrix and 4) applying backward column pivoting on the inverted matrix. Using a tile data layout, which represents the matrix in the system memory with an optimized cache-aware format, the computation of the four steps is decomposed into computational tasks. A directed acyclic graph is generated on the fly which represents the program data flow. Its nodes represent tasks and edges the data dependencies between them. Previous implementations of matrix inversions, available in the state-of-the-art numerical libraries, are suffer from unnecessary synchronization points, which are non-existent in our implementation in order to fully exploit the parallelism of the underlying hardware. Our algorithmic approach allows to remove these bottlenecks and to execute the tasks with loose synchronization. A runtime environment system called QUARK is necessary to dynamically schedule our numerical kernels on the available processing units. The reported results from our LU-based matrix inversion implementation significantly outperform the state-of-the-art numerical libraries such as LAPACK (5x), MKL (5x) and ScaLAPACK (2.5x) on a contemporary AMD platform with four sockets and the total of 48 cores for a matrix of size 24000. A power consumption analysis shows that our high performance implementation is also energy efficient and substantially consumes less power than its competitors. © 2011 ACM.
Original languageEnglish (US)
Title of host publicationProceedings of the 2011 ACM international workshop on Many task computing on grids and supercomputers - MTAGS '11
PublisherAssociation for Computing Machinery (ACM)
Pages33-42
Number of pages10
ISBN (Print)9781450311458
DOIs
StatePublished - 2011

Bibliographical note

KAUST Repository Item: Exported on 2020-10-01

Fingerprint

Dive into the research topics of 'High performance matrix inversion based on LU factorization for multicore architectures'. Together they form a unique fingerprint.

Cite this