Evolution of the SLATE linear algebra library

TitleEvolution of the SLATE linear algebra library
Publication TypeJournal Article
Year of Publication2024
AuthorsGates, M., A. Abdelfattah, K. Akbudak, M. Al Farhan, R. Alomairy, D. Bielich, T. Burgess, ébastien. Cayrols, N. Lindquist, D. Sukkari, and A. YarKhan
JournalThe International Journal of High Performance Computing Applications
Date Published2024-09
ISSN1094-3420
Abstract

SLATE (Software for Linear Algebra Targeting Exascale) is a distributed, dense linear algebra library targeting both CPU-only and GPU-accelerated systems, developed over the course of the Exascale Computing Project (ECP). While it began with several documents setting out its initial design, significant design changes occurred throughout its development. In some cases, these were anticipated: an early version used a simple consistency flag that was later replaced with a full-featured consistency protocol. In other cases, performance limitations and software and hardware changes prompted a redesign. Sequential communication tasks were parallelized; host-to-host MPI calls were replaced with GPU device-to-device MPI calls; more advanced algorithms such as Communication Avoiding LU and the Random Butterfly Transform (RBT) were introduced. Early choices that turned out to be cumbersome, error prone, or inflexible have been replaced with simpler, more intuitive, or more flexible designs. Applications have been a driving force, prompting a lighter weight queue class, nonuniform tile sizes, and more flexible MPI process grids. Of paramount importance has been building a portable library that works across several different GPU architectures – AMD, Intel, and NVIDIA – while keeping a clean and maintainable codebase. Here we explore the evolving design choices and their effects, both in terms of performance and software sustainability.

URLhttps://journals.sagepub.com/doi/10.1177/10943420241286531
DOI10.1177/10943420241286531
Short TitleThe International Journal of High Performance Computing Applications
Project Tags: 
External Publication Flag: