DocumentCode
1202927
Title
A new architecture for transformation-based generators
Author
Biggerstaff, Ted J.
Author_Institution
SoftwareGenerators, Austin, TX, USA
Volume
30
Issue
12
fYear
2004
Firstpage
1036
Lastpage
1054
Abstract
A challenge of many transformation-based generators is that they are trying to achieve three mutually antagonistic goals simultaneously: 1) deeply factored operators and operands to gain the combinatorial programming leverage provided by composition, 2) high-performance code in the generated program, and 3) small (i.e., practical) generation search spaces. The anticipatory optimization generator (AOG) has been built to explore architectures and strategies that address this challenge. The fundamental principle underlying all of AOG´s strategies is to solve separate, narrow, and specialized generation problems by strategies that are narrowly tailored to specific problems rather than a single, universal strategy aimed at all problems. A second fundamental notion is the preservation and use of domain-specific information as a way to gain extra leverage on generation problems. This paper focuses on two specific mechanisms: 1) Localization: the generation and merging of implicit control structures and 2) Tag-directed transformations: a new control structure for transformation-based optimization that allows differing kinds of retained domain knowledge (e.g., optimization knowledge) to be anticipated, affixed to the component parts in the reuse library, and triggered when the time is right for its use.
Keywords
automatic programming; optimising compilers; partial evaluation (compilers); program control structures; software reusability; anticipatory optimization generator; domain specific architecture; logic programming; partial evaluation; program control structure; program synthesis; program transformation; software reuse; tag-directed transformation; Automatic programming; Computer architecture; Engines; Image processing; Logic programming; Merging; Pattern matching; Refining; Software libraries; Software reusability;
fLanguage
English
Journal_Title
Software Engineering, IEEE Transactions on
Publisher
ieee
ISSN
0098-5589
Type
jour
DOI
10.1109/TSE.2004.89
Filename
1377196
Link To Document