An algebraic programming style for numerical software and its optimization

  • Authors:
  • T. B. Dinesh;Magne Haveraaen;Jan Heering

  • Affiliations:
  • Academic Systems Corporation, 444 Castro Street, Mountain View, CA 94041, USA. E-mail: T_Dinesh@academic.com;Department of Informatics, University of Bergen, Høyteknologisenteret, N-5020 Bergen, Norway. E-mail: Magne.Haveraaen@ii.uib.no;Department of Software Engineering, CWI, Kruislaan 413, 1098 SJ Amsterdam, The Netherlands. E-mail: Jan.Heering@cwi.nl

  • Venue:
  • Scientific Programming
  • Year:
  • 2000

Quantified Score

Hi-index 0.00

Visualization

Abstract

The abstract mathematical theory of partial differential equations (PDEs) is formulated in terms of manifolds, scalar fields, tensors, and the like, but these algebraic structures are hardly recognizable in actual PDE solvers. The general aim of the Sophus programming style is to bridge the gap between theory and practice in the domain of PDE solvers. Its main ingredients are a library of abstract datatypes corresponding to the algebraic structures used in the mathematical theory and an algebraic expression style similar to the expression style used in the mathematical theory. Because of its emphasis on abstract datatypes, Sophus is most naturally combined with object-oriented languages or other languages supporting abstract datatypes. The resulting source code patterns are beyond the scope of current compiler optimizations, but are sufficiently specific for a dedicated source-to-source optimizer. The limited, domain-specific, character of Sophus is the key to success here. This kind of optimization has been tested on computationally intensive Sophus style code with promising results. The general approach may be useful for other styles and in other application domains as well.