Use este identificador para citar ou linkar para este item: http://repositorio.ufla.br/jspui/handle/1/59329
Título: Uma abordagem de deep-learning para realizar a predição de refatorações
Título(s) alternativo(s): Realizing refactoring prediction through deep-learning
Autor : Pereira, Lucas Rafael Rodrigues
Lattes: http://lattes.cnpq.br/6502664083187109
Primeiro orientador: Durelli, Rafael Serapilha
Primeiro coorientador: Pereira, Dilson
Primeiro membro da banca: Dias, Diego Roberto Colombo
Segundo membro da banca: Parreira Junior, Paulo Afonso
Terceiro membro da banca: Oliveira, Johnatan Alves de
Palavras-chave: Deep Learning
Refatoração de código
Machine Learning
Qualidade de software
Predição de refatoração
Mineração de dados
Code Refactoring
Machine Learning
Software Quality
Refactoring Prediction
Data Mining
Data da publicação: 4-Set-2024
Referência: PEREIRA, Lucas Rafael Rodrigues. Uma abordagem de deep-learning para realizar a predição de refatorações. 2024. 42p. Dissertação (Mestrado em Ciência da Computação) - Universidade Federal de Lavras, 2024.
Resumo: A pesquisa mostrou que a refatoração geralmente leva a uma maior capacidade de manutenção, resultando em um código mais legível e compreensível para os desenvolvedores. No entanto, ao aplicar métodos de refatoração para aumentar a qualidade do software, os desenvolvedores enfrentam desafios na identificação de métodos de refatoração eficazes. Acontece que encontrar oportunidades de refatoração é uma tarefa desafiadora. Um problema notável é a ausência de diretrizes específicas e práticas para determinar o método de refatoração apropriado para um determinado trecho de código. Consequentemente, já que as decisões sobre quando refatorar geralmente são baseadas em conceitos subjetivos, como codesmells, desenvolvedores menos experientes frequentemente contam com a orientação de desenvolvedores seniores para determinar quando o software precisa passar por refatoração. Pesquisas anteriores mostraram que algoritmos de aprendizado de máquina podem ser usados para ajudar os desenvolvedores a identificar oportunidades de refatoração. Com os recentes avanços em hardware, algoritmos de aprendizado profundo têm atraído cada vez mais atenção. Nessa pesquisa, pretendemos avaliar a eficácia de alguns modelos de Deep Learning (CNN, RNN, LSTM e DenseLayer) na previsão de oportunidades de refatoração, em comparação com modelos tradicionais de aprendizado de máquina. Especificamente, avaliamos esses modelos usando métricas padrão, como precisão, recall e exatidão. Nossas descobertas parecem sugerir que, embora os modelos de aprendizado de máquina geralmente superem os modelos de aprendizado profundo, os últimos apresentam desempenho superior aos primeiros quando treinados em conjuntos de dados não balanceados.
Abstract: Research has shown that refactoring often leads to greater maintainability, resulting in more readable and understandable code for developers. However, when applying refactoring methods to increase software quality, Developers face challenges in identifying effective refactoring methods. It turns out that finding refactoring opportunities is a challenging task. One notable problem is the absence of specific, practical guidelines for determining the appropriate refactoring method for a given piece of code. Consequently, since decisions about when to refactor are often based on subjective concepts such as codesmells, Less experienced developers often rely on guidance from senior developers to determine when software needs to undergo refactoring. Previous research has shown that machine learning algorithms can be used to help developers identify refactoring opportunities. With recent advances in hardware, Deep learning algorithms have attracted more and more attention. In this research, we intend to evaluate the effectiveness of some Deep Learning models (CNN, RNN, LSTM and DenseLayer) in predicting refactoring opportunities, compared to traditional machine learning models. Specifically, We evaluate these models using standard metrics such as precision, recall, and accuracy. Our findings seem to suggest that although machine learning models generally outperform deep learning models, the latter perform better than the former when trained on unbalanced datasets.
URI: http://repositorio.ufla.br/jspui/handle/1/59329
Publicador: Universidade Federal de Lavras
Idioma: por
Aparece nas coleções:DAE - Administração - Mestrado (Dissertações)



Este item está licenciada sob uma Licença Creative Commons Creative Commons