Computational graphs for matrix functions
Many numerical methods for evaluating matrix functions can be naturally viewed as computational graphs. Rephrasing these methods as directed acyclic graphs (DAGs) is a particularly effective approach to study existing techniques, improve them, and eventually derive new ones. The accuracy of these ma...
Gespeichert in:
Hauptverfasser: | , , |
---|---|
Format: | Artikel |
Sprache: | eng |
Schlagworte: | |
Online-Zugang: | Volltext bestellen |
Tags: |
Tag hinzufügen
Keine Tags, Fügen Sie den ersten Tag hinzu!
|
Zusammenfassung: | Many numerical methods for evaluating matrix functions can be naturally
viewed as computational graphs. Rephrasing these methods as directed acyclic
graphs (DAGs) is a particularly effective approach to study existing
techniques, improve them, and eventually derive new ones. The accuracy of these
matrix techniques can be characterized by the accuracy of their scalar
counterparts, thus designing algorithms for matrix functions can be regarded as
a scalar-valued optimization problem. The derivatives needed during the
optimization can be calculated automatically by exploiting the structure of the
DAG, in a fashion analogous to backpropagation. This paper describes
GraphMatFun.jl, a Julia package that offers the means to generate and
manipulate computational graphs, optimize their coefficients, and generate
Julia, MATLAB, and C code to evaluate them efficiently at a matrix argument.
The software also provides tools to estimate the accuracy of a graph-based
algorithm and thus obtain numerically reliable methods. For the exponential,
for example, using a particular form (degree-optimal) of polynomials produces
implementations that in many cases are cheaper, in terms of computational cost,
than the Pad\'e-based techniques typically used in mathematical software. The
optimized graphs and the corresponding generated code are available online. |
---|---|
DOI: | 10.48550/arxiv.2107.12198 |