Skip to content

Latest commit

 

History

History
111 lines (81 loc) · 9.77 KB

File metadata and controls

111 lines (81 loc) · 9.77 KB

Biblioteca de Estruturas de Dados (Haskell)

Disciplina: FGA0210 - PARADIGMAS DE PROGRAMAÇÃO - T01
Nro do Grupo: 01
Paradigma: Funcional

Alunos

Matrícula Aluno
18/0013637 Arthur Paiva Tavares
18/0117548 Bruno Carmo Nunes
16/0028361 Gabriel Batista Albino Silva
14/0156909 Nathalia Lorena Cardoso Dias
17/0051277 Nicolas Georgeos Mantzos
17/0114333 Sofia Costa Patrocinio
19/0048760 Wellington Jonathan de Souza Rodrigues

Sobre

O objetivo é construir uma biblioteca que agrege as principais estruturas de dados acompanhadas de seus algoritmos principais para as operações de inserção, ordenação, deleção e busca implementados no paradigma funcional.

Ao final do semestre, os repositórios nos diversos paradigmas serão unificados para a construção de uma biblioteca que documente a performance dessas operações.

Screenshots

Screenshot Screenshot Screenshot

Instalação

Linguagens: Haskell
Tecnologias: xxxxxx
Descreva os pré-requisitos para rodar o seu projeto e os comandos necessários. Insira um manual ou um script para auxiliar ainda mais. Gifs animados e outras ilustrações são bem-vindos!

Uso

Haskell

Inicialmente é necessario que instale a plataforma do Haskell. Se você estiver no linux baseado no Debian, basta copiar a seguinte linha no seu terminal:

$ sudo apt-get install haskell-platform

Clone este repositório:

$ git clone <https://github.com/UnBParadigmas2022-1/2022.1_G1_Funcional_DataStructLib.git>

Abra o GHCI, que é o modo interativo do Haskell dentro da pasta do Projeto

$ ghci

você poderá carregar as funções digitando :l Main.hs, dentro do pasta do projeto.

Vídeo

Watch the video

Participações

A tabela abaixo sintetiza, nas palavras do contribuidor, as contribuições acompanhadas de sua respectiva significância.

Nome do Membro Contribuição Significância da Contribuição para o Projeto (Excelente/Boa/Regular/Ruim/Nula)
Arthur Paiva Tavares Adição do Módulo de Árvore binária com inserção, travessia em Pré-Ordem, Em-Ordem e Pós-Ordem e a implementação da função fmap com Functors Excelente
Bruno Carmo Nunes Adição do algoritmo de ordenação MergeSort, juntamente com o teste com 10000 e 100000 números randômicos e também repetidos. Excelente
Gabriel Batista Albino Silva Adição dos algorítmos de Kruskal's para criação de Arvores Geradoras Mínimas e Bellman Ford para encontrar distâncias a partir de um ponto, incluíndo implementação do método de detecção de ciclos "Union-Find". Excelente
Nathalia Lorena Cardoso Dias Adição do Módulo de Pilha, com inserção de novo elemento, remoção, verificação de pilha vazia e verificação do elemento topo da pilha Excelente
Nicolas Georgeos Mantzos Adição dos algoritmos para Busca em Profundidade, Busca em Largura e avaliação geral dos grafos (possui caminhos, possui passeios, possui trilhas, representa um ciclo, natureza dos caminhos etc) Excelente
Sofia Costa Patrocinio Adição do Módulo de Lista, bem com suas funções de Criação, com 1000 elementos, adição de um elemento, remoção do último elemento da lista, função reverse e retorno do maior valor. Excelente
Wellington Jonathan de Souza Rodrigues Adição do Módulo de “Algoritmos de ordenação”, contendo os principais algorítimos de ordenação entre InsertionSort, MergeSort, QuickSort juntamente com um teste utilizando um vetor de 100000 números randômicos e também repetidos. Excelente

Percepções gerais, lições aprendidas, fragilidades superadas...

A tabela abaixo compila as percepções e lições aprendidas por cada participante no desenvolvimento do primeiro módulo do projeto.

Nome do Membro Comentário
Arthur Paiva Tavares A implementação das funções mais comuns para travessia em Árvore binária não foram tão complexas graças à forma que o paradigma funcional conversa com funções recursivas, as maiores dificuldades foram em relação à sintaxe e à correção de erros que pareciam não fazer sentido de primeira, o conhecimento teórico do funcionamento da linguagem foi mais necessário do que em linguagens com sintaxe mais convencional e erros mais genéricos comuns de outros paradigmas. A implementação de Functor foi algo que lembrou o uso de interfaces em GoLang, mesmo que com integração, sintaxe e funcionamentos diferentes
Bruno Carmo Nunes Considerei bem complicado tentar reimplementar o mergeSort, apesar de ele já haver uma recursão no paradigma estrutural, a dificuldade ocorreu justamente na falta de um laço e também nessa ideia de tipificação dos dados. Apesar de a ideia ser tranquila, onde é justamente dividir e conquistar, acabei me enrolando justamente na parte de dividir em pequenos pedaços e juntá-los tudo em uma só lista.
O maior problema foi realmente fazer essa solução como tudo sendo recursivo. Tive que procurar algumas ajudas na internet, como fazer essas quebras de cada uma das listas, onde achei o recurso para usar o fst e o snd, que são para pegar a primeira e a segunda variável dentro das tuplas.
No fim, apesar das raivas que passei, gostei de implementar esse paradigma. Creio que o maior problema deve ser na prática do mesmo.
Gabriel Batista Albino Silva Achei o paradigma funcional complicado para lidar com a recursão de algorítmos complexos de grafos como o Bellman-Ford e o de Kruskal's, uma vez que ambos dependem de iterações anteriores e estrutura de dados auxiliares para seu amplo funcionamento. Sinto que poderia ter feito um trabalho melhor na tradução dos algorítmos para o modo recursivo aproveitando mais o sugar syntax do haskell, porém me senti bastante satisfeito ao implementar uma versão funcional dos algorítimos citados acima.
Nathalia Lorena Cardoso Dias Senti dificuldades em a assimilar a sintaxe e estruturação de funções em Haskell, pois me lembram mais uma notação matemática do que uma linguagem de programação. Tive dificuldades na assimilação do paradigma funcional como um todo, por isso, optei por iniciar minha contribuição com uma estrutura de dados mais simples.
Nicolas Georgeos Mantzos Tive dificuldade de formular soluções recursivas para os problemas com os quais trabalhava iterativamente nos paradigmas estruturado e orientado a objetos. Sem falar, claro, no quanto a sintaxe do Haskell me pareceu áspera e árida na escrita das primeiras linhas e como a importação do que conhecia de outros carnavais muitas vezes mais atrapalhou do que ajudou. Conceitos como "Classes de Tipo", por exemplo, se alinham mais com a ideia de Interface das liguagens orientadas a objetos do que propriamente com classes.

Tentarei chegar mais como uma folha em branco nos próximos paradigmas.

Por outro lado, pude afinar minha atrofiada "visão recursiva" ao modelar a solução para os problemas. "Humm...será que consigo quebrar isso em pequenas partes?"
Sofia Costa Patrocinio Minha maior dificuldade foi a sintaxe do Haskell e entender funções como formas de calcular algo e simplesmente retornar um resultado, sem possibilidade de definir variáveis e afins. Achei o paradigma funcional bem elegante e com poucas linhas de código é possível fazer muito, o que é incrível. Lidar com listas no Haskell é excelente, pois possui inúmeras funções que auxiliam sua manipulação, além da própria estrutura definir cabeça e cauda.
Wellington Jonathan de Souza Rodrigues Tive uma grande Dificuldade principalmente com a sintaxe da linguagem e com a implementação do paradigma, principalmente o fato de não utilizar variáveis com estados e dados mutáveis, a mudança da chave para trabalhar com esse paradigma e bem interessante me fez conhecer alguns recursos novos, bem como trabalhar e pensar com funções recursivas.

Fontes

  • Rosen, Kenneth. Matemática Discreta e Suas Aplicações. 06. ed. São Paulo: Mc Graw Hill, 2009.
  • Khatri Lamba, Jayanti. BFS and DFS Graph Traversals | Breadth First Search and Depth First Search | Data structures. Youtube, 25 jan. 2019. Disponível em: https://www.youtube.com/watch?v=vf-cxgUXcMk. Acesso em 01 jul. 2022.