dc.creator | Duarte, Rodrigo Medeiros | |
dc.date.accessioned | 2020-11-26T13:52:40Z | |
dc.date.available | 2020-11-26T13:52:40Z | |
dc.date.issued | 2020-04-23 | |
dc.identifier.citation | DUARTE, Rodrigo Medeiros. Escalonamento de Transações em Memória a Nível de Usuário em Haskell. Orientador: André Rauber Du Bois. 2020. 95 f. Dissertação (Mestrado em Ciência da Computação) – Centro de Desenvolvimento Tecnológico, Universidade Federal de Pelotas, Pelotas, 2020. | pt_BR |
dc.identifier.uri | http://guaiaca.ufpel.edu.br/handle/prefix/6656 | |
dc.description.abstract | Transactional memory is a thread synchronization model that uses a transaction concept which is similar to the one seen in databases. This model is highly abstract, since the programmer only needs to define data that must be synchronized, whereas the synchronization task is performed by the transactional system. Although transactional memories are highly abstract, they tend to lose performance in high contention systems due to the large conflict rate between transactions. This
leads to performance deterioration, as available resources (cores) are not explored in an efficient way. In this context, the transactional scheduling appears as an alternative to mitigate the high rate of cancellations. In this strategy, transactions are managed so that new conflicts are avoided, by distributing transactions in a way that available computational resources (cores) can be explored more efficiently. This work presents three transactional schedulers which are developed in Haskell,
exploring its practicality of implementing complex structures in a programming language which has a high level of abstraction. The goal of this work is to show the behaviour comparison of different scheduling techniques over different transactional algorithms, such as TL2, TINY and SWISS – where they have, respectively, late, forward and mixed data versioning. The results of this work show that by using the schedulers, the number of conflicts has been reduced in most of applications, which reduced overall runtime. In addition, when schedulers were used in applications where maximum memory contention occurred, system deterioration was lower – runtime was near constant, independently of
number of threads used. Finally, it has been noted that scheduler efficiency (reducing conflicts) is also associated with the type of transactional memory algorithm that is used, and not just with its capacity to deal with conflicts. | pt_BR |
dc.description.sponsorship | Coordenação de Aperfeiçoamento de Pessoal de Nível Superior - CAPES | pt_BR |
dc.language | por | pt_BR |
dc.publisher | Universidade Federal de Pelotas | pt_BR |
dc.rights | OpenAccess | pt_BR |
dc.subject | Computação | pt_BR |
dc.subject | Memórias transacionais | pt_BR |
dc.subject | Escalonamento de transações | pt_BR |
dc.subject | Multicore | pt_BR |
dc.subject | Transactional memory | pt_BR |
dc.subject | Transactional scheduler | pt_BR |
dc.title | Escalonamento de transações em memória a nível de usuário em Haskell | pt_BR |
dc.title.alternative | User-level Scheduling of Memory Transactions in Haskell. | pt_BR |
dc.type | masterThesis | pt_BR |
dc.contributor.authorLattes | http://lattes.cnpq.br/2301320966169130 | pt_BR |
dc.contributor.advisorLattes | http://lattes.cnpq.br/3277487290886063 | pt_BR |
dc.description.resumo | Memória Transacional é um modelo de sincronização entre threads que utiliza um conceito de transações parecido com o de bancos de dados. Este modelo de sincronização apresenta uma elevada abstração, pois nele o programador somente define os dados que deve ser sincronizados, ficando a tarefa da correta sincronização a cargo do sistema transacional. Apesar de sua elevada abstração, memórias transacionais tendem a perder desempenho em sistemas de alta contenção de memória devido à alta taxa de conflitos entre as transações. Essa alta taxa de conflitos conduz a uma degradação do desempenho por não explorar de forma eficiente os recursos disponíveis (cores).
Neste contexto, o escalonamento transacional emerge como uma alternativa para reduzir a alta taxa de cancelamentos. Nesta estratégia, as transações são gerenciadas com o objetivo de evitar que novos conflitos venham a ocorrer, distribuindo as transações na tentativa de explorar de forma mais eficiente os recursos computacionais disponíveis (cores). Este trabalho apresenta o desenvolvimento de três diferentes escalonadores transacionais em Haskell, explorando a praticidade de implementar escalonadores, os quais são estruturas complexas, dentro de uma linguagem de alto nível de abstração. O objetivo é a comparação do comportamento de diferentes técnicas de escalonamento
sobre diferentes algoritmos transacionais, como o TL2, TINY e o SWISS, que apresentam versionamento de dados tardio, adiantado e misto, respectivamente. Os resultados obtidos demonstraram que, o uso dos escalonadores reduziu a quantidade de conflitos na maioria das aplicações, impactando em uma redução no tempo de execução. Também observou-se que, quando os escalonadores foram utilizados em aplicações de contenção máxima de memória, esses evitaram que o sistema tivesse maior degradação, apresentando um tempo de execução quase constante independente da quantidade de threads usadas. Por fim, observou-se que a eficiência em um escalonador tem em reduzir os conflitos também está associado ao tipo de algoritmo de memória transacional que este usa e não somente em sua capacidade de lidar com conflitos. | pt_BR |
dc.publisher.department | Centro de Desenvolvimento Tecnológico | pt_BR |
dc.publisher.program | Programa de Pós-Graduação em Computação | pt_BR |
dc.publisher.initials | UFPel | pt_BR |
dc.subject.cnpq | CNPQ::CIENCIAS EXATAS E DA TERRA::CIENCIA DA COMPUTACAO::METODOLOGIA E TECNICAS DA COMPUTACAO | pt_BR |
dc.publisher.country | Brasil | pt_BR |
dc.contributor.advisor1 | Du Bois, André Rauber | |