• 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