Finite Automata Theory Based Optimization of Conditional Variable Binding
From LRDE
- Authors
- Jim Newton, Didier Verna
- Where
- European Lisp Symposium
- Place
- Genova, Italy
- Type
- inproceedings
- Projects
- Climb
- Keywords
- finite automata, infinite alphabets, type systems, Common Lisp, meta programming
- Date
- 2019-01-14
Abstract
We present an efficient and highly optimized implementation of destructuring-case in Common Lisp. This macro allows the selection of the most appropriate destructuring lambda list of several given based on structure and types of data at run-time and thereafter dispatches to the corresponding code branch. We examine an optimization technique, based on finite automata theory applied to conditional variable binding and execution, and type-based pattern matching on Common Lisp sequences. A risk of inefficiency associated with a naive implementation of destructuring-case is that the candidate expression being examined may be traversed multiple times, once for each clause whose format fails to match, and finally once for the successful match. We have implemented destructuring-case in such a way to avoid multiple traversals of the candidate expression. This article explains how this optimization has been implemented.
Documents
Bibtex (lrde.bib)
@InProceedings{ newton.19.els, author = {Jim Newton and Didier Verna}, title = {Finite Automata Theory Based Optimization of Conditional Variable Binding}, booktitle = {European Lisp Symposium}, year = 2019, address = {Genova, Italy}, month = apr, abstract = {We present an efficient and highly optimized implementation of destructuring-case in Common Lisp. This macro allows the selection of the most appropriate destructuring lambda list of several given based on structure and types of data at run-time and thereafter dispatches to the corresponding code branch. We examine an optimization technique, based on finite automata theory applied to conditional variable binding and execution, and type-based pattern matching on Common Lisp sequences. A risk of inefficiency associated with a naive implementation of destructuring-case is that the candidate expression being examined may be traversed multiple times, once for each clause whose format fails to match, and finally once for the successful match. We have implemented destructuring-case in such a way to avoid multiple traversals of the candidate expression. This article explains how this optimization has been implemented.}, doi = {10.5281/zenodo.2635412} }