Multistage Algorithms in C++
Mehrstufige Algorithmen in C++
by Andreas Priesnitz
Date of Examination:2005-11-02
Date of issue:2006-04-19
Advisor:Prof. Dr. Gert Lube
Referee:Prof. Dr. Robert Schaback
Files in this item
Name:priesnitz.pdf
Size:950.Kb
Format:PDF
Description:Dissertation
Abstract
English
Performance-critical software is rarely implemented in a generic manner. Structural changes usually affect large parts of a project and cause expensive development cycles. Principal reason is the exclusion of efficient, specialized variants when bindings are generalized only to given type sets in favor of static semantical verification and selection. On the other hand, language-based or user-defined means for static evaluation require some according syntax of algorithm implementation and invocation, which hinders their combination.This work overcomes both obstacles by a multi-stage approach: The static and the dynamic content of an algorithm are represented explicitly and separately, where the evaluation of the static stage determines the according dynamic representation. A Turing-complete static language subset as in C++ allows decisions to be arbitrarily complex. As an application, semantical verification and selection of representation are performed by static binding analysis, which avoids explicit restrictions to type sets.
Keywords: multistage programming; generic programming; meta programming; static binding; language embedding
Other Languages
Leistungskritische Software wird selten in allgemeingültiger Form verfaßt. Strukturelle Änderungen beeinflussen gewöhnlicherweise weite Teile eines Projekts und bedeuten aufwendige Entwicklungsschritte. Hauptgrund ist der Ausschluß effizienter spezialisierter Varianten, wenn zugunsten statischer semantischer Prüfung und Auswahl Bindungen nur auf anzugebende Typmengen verallgemeinert werden. Andererseits verlangen spracheigene oder benutzerdefinierte Mittel zur statischen Auswertung eine entsprechende Syntax bei Bereitstellung und Aufruf von Algorithmen, was deren Kombination erschwert.Die vorliegende Arbeit überwindet beide Hemmnisse durch einen Mehrstufenansatz: Der statische und der dynamische Anteil eines Algorithmus werden explizit und separat dargestellt, wobei die Auswertung der statischen Stufe die geeignete dynamische Darstellung bestimmt. Ein Turing-vollständiger statischer Sprachanteil wie in C++ erlaubt dabei beliebig komplexe Entscheidungen. Als Anwendung werden semantische Prüfung und Auswahl der Darstellung durch statische Analyse einer Bindung vollzogen und so explizite Einschränkungen auf Typmengen vermieden.
Schlagwörter: Mehrstufige Programmierung; Generische Programmierung; Metaprogrammierung; statische Bindung; Spracheinbettung