Detailseite
Projekt Druckansicht

CLAK: Eine automatische Umgebung für lineare Algebra-Gleichungen

Fachliche Zuordnung Softwaretechnik und Programmiersprachen
Förderung Förderung von 2015 bis 2020
Projektkennung Deutsche Forschungsgemeinschaft (DFG) - Projektnummer 266457877
 
Erstellungsjahr 2019

Zusammenfassung der Projektergebnisse

With this project, we made several lasting contributions. • Linear algebra compilers. As we set out to do, we built Linnea, a linear algebra compiler for matrix expressions that arise in end applications. Linnea offers a high-level input language, enabling domain scientists to code at the same level of abstraction as they reason. Linnea was designed with extensibility in mind, to make it possible for follow-up projects to focus on issues such as parallelism, memory consumption, and performance modeling. In collaboration with ETH Zürich, we also developed the prototype of a second compiler, SLinGen, specifically designed for small operations, that is, for matrices that fit in cache. Even though SLinGen did not reach the same level of maturity and generality of Linnea, it clearly demonstrated that in the small-scale regime there are wide margins for gains over current state-of-the-art libraries. • GMC algorithm. One the most important building blocks for Linnea is the Generalized Matrix Chain algorithm which we developed. The standard version of the problem (Matrix Chain) is only concerned with the optimal parentesisation of a sequence of matrix products. We tackled the more general problem in which matrices can be transposed, inverted, re-used, and have properties. In constrast to a time-consuming exhaustive search, with the GMC algorithm, the optimal solution is found constructively. The GMC algorithm should become an integral part in any high-level language and compiler for linear algebra. • Pattern matching. The algorithm-generation process in Linnea is based on symbolic manipulation of a target linear algebra expression. Since linear algebra has both commutative and non-commutative operators, we developed and released MatchPy, a pattern-matching library that offers functionality similar to that provided by Mathematica, but as an opensource and extensible package. MatchPy is now widely adopted. • Benchmarks. In order to assess the quality of any language and compiler for high-level matrix expressions, we created two benchmarks, for a total of 125 target linear algebra expressions. These benchmarks are meant both as a stress test (with corner cases), and as representative use cases, as they arise in practice.

Projektbezogene Publikationen (Auswahl)

 
 

Zusatzinformationen

Textvergrößerung und Kontrastanpassung