Please use this identifier to cite or link to this item:
https://hdl.handle.net/1822/83668
Title: | On the performance of strategic attribute grammars |
Author(s): | Rodrigues, José Emanuel Silva |
Advisor(s): | Saraiva, João |
Keywords: | Strategic programming Attribute grammars Zippers Ztrategic Programação estratégica Gramáticas de atributos |
Issue date: | 5-Sep-2022 |
Abstract(s): | Strategic programming is a powerful technique used in language processing to define functions that traverse
abstract syntax trees. With strategies, the programmer only indicates the nodes of the tree where the work has to
be done, and the strategy used to traverse the whole tree and apply the function that works only on the defined
nodes.
In Haskell, there are two libraries that implement strategies: Strafunski and an equivalent library developed
by DI: Ztrategic. Beyond that, we also have the Kiama library which is implemented in the Scala programming
language. The Ztrategic library uses memorization in order to save work. Using memorization, the elimination of
all occurrences of "bad smells" in an abstract tree of a program is done only once!
In this thesis, we present a detailed study of the performance of the Kiama, Ztrategic, and memoized Ztrategic
libraries, using different strategic problems and input languages. Programação estratégica é uma técnica poderosa usada em processamento de linguagens para definir funções que atravessam árvores de sintaxe abstracta. Com estratégias o programador apenas indica os nodos da árvore onde o trabalho tem de ser feito, e depois que estratégia é utilizada para atravessar toda a árvore e aplicar a função que faz trabalho apenas nos nodos definidos. Em Haskell existem duas bibliotecas de combinadores que implementam estratégias: Strafunski e uma biblioteca equivalente desenvolvida no DI: Ztrategic. Existe também outra biblioteca desenvolvida em Scala, Kiama. A biblioteca Ztrategic usa memorização de modo a poupar trabalho. Usando memorização, a eliminação de todas a ocorrências do "mau cheiro" numa árvore abstracta de um programa é feita apenas uma vez! Nesta tese faz-se um estudo detalhado da performance das bibliotecas Kiama, Ztrategic, e memoized Ztrategic, utilizando diferentes problemas de programação estratégica e diferentes linguagens de input. |
Type: | Master thesis |
Description: | Dissertação de mestrado integrado em Engenharia Informática |
URI: | https://hdl.handle.net/1822/83668 |
Access: | Open access |
Appears in Collections: | BUM - Dissertações de Mestrado DI - Dissertações de Mestrado |
Files in This Item:
File | Description | Size | Format | |
---|---|---|---|---|
Jose Emanuel Silva Rodrigues.pdf | 465,76 kB | Adobe PDF | View/Open |
This item is licensed under a Creative Commons License