Sparse automatic differentiation for complex networks of differential-algebraic equations using abstract elementary algebra

Slaven Peleš, Stefan Klus

Research output: Contribution to journalArticlepeer-review

Abstract

Most numerical solvers and libraries nowadays are implemented to use mathematical models created with language-specific built-in data types (e.g. real in Fortran or double in C) and their respective elementary algebra implementations. However, the built-in elementary algebra typically has limited functionality and often restricts the exibility of mathematical models and the analysis types that can be applied to those models. To overcome this limitation, a number of domain-specific languages such as gPROMS or Modelica with more feature-rich built-in data types have been proposed. In this paper, we argue that if numerical libraries and solvers are designed to use abstract elementary algebra rather than the language-specific built-in algebra, modern mainstream languages can be as effective as any domain-specific language. We illustrate our ideas using the example of sparse Jacobian matrix computation. We implement an automatic differentiation method that takes advantage of sparse system structures and is straightforward to parallelize in a distributed memory setting. Furthermore, we show that the computational cost scales linearly with the size of the system.

Original languageEnglish
Pages (from-to)916-934
Number of pages19
JournalInternational Journal of Numerical Analysis and Modeling
Volume14
Issue number6
Publication statusPublished - 2017

Keywords

  • Abstract elementary algebra
  • Differential-algebraic equations
  • Sparse automatic differentiation

ASJC Scopus subject areas

  • Numerical Analysis

Fingerprint

Dive into the research topics of 'Sparse automatic differentiation for complex networks of differential-algebraic equations using abstract elementary algebra'. Together they form a unique fingerprint.

Cite this