Otimização para reduzir o tamanho de código-fonte JavaScript

Bibliographic Details
Main Author: Farzat, Fabio de Almeida
Publication Date: 2018
Format: Doctoral thesis
Language: por
Source: Repositório Institucional da UFRJ
Download full: http://hdl.handle.net/11422/13045
Summary: JavaScript is one of the most used programming languages for front-end development of Web application. The increase in complexity of front-end features brings concerns about performance, especially the load and execution time of JavaScript code. To reduce the size of JavaScript programs and, therefore, the time required to load and execute these programs in the front-end of Web applications. To characterize the variants of JavaScript programs and use this information to build a search procedure that scans such variants for smaller implementations that pass all test cases. We applied this procedure to 19 JavaScript programs varying from 92 to 15,602 LOC and observed reductions from 0.2% to 73.8% of the original code, as well as a relationship between the quality of a program’s test suite and the ability to reduce its size.
id UFRJ_a22097fd2f4d4e4e1deb91ffd606792b
oai_identifier_str oai:pantheon.ufrj.br:11422/13045
network_acronym_str UFRJ
network_name_str Repositório Institucional da UFRJ
repository_id_str
spelling Otimização para reduzir o tamanho de código-fonte JavaScriptOtimização de código-fonteEngenharia de software baseada em buscaHeurísticasMelhoramento GenéticoProgramação genéticaCNPQ::ENGENHARIASJavaScript is one of the most used programming languages for front-end development of Web application. The increase in complexity of front-end features brings concerns about performance, especially the load and execution time of JavaScript code. To reduce the size of JavaScript programs and, therefore, the time required to load and execute these programs in the front-end of Web applications. To characterize the variants of JavaScript programs and use this information to build a search procedure that scans such variants for smaller implementations that pass all test cases. We applied this procedure to 19 JavaScript programs varying from 92 to 15,602 LOC and observed reductions from 0.2% to 73.8% of the original code, as well as a relationship between the quality of a program’s test suite and the ability to reduce its size.Esta Tese aborda o problema de otimização de tempo de carga de software, especificamente software escrito na linguagem de programação JavaScript, uma linguagem interpretada, baseada em objetos e amplamente utilizada no desenvolvimento de aplicativos e sistemas para a internet. Estudos experimentais foram projetados para avaliar a hipótese de que técnicas heurísticas já aplicadas com sucesso em linguagens orientadas a objeto poderiam ter resultados positivos na redução do tempo de carga de programas escritos em JavaScript. Para tanto, um ferramental que permitisse observar a aplicação de heurísticas selecionadas em programas JavaScript foi construído e executado em um ambiente de computação de alto desempenho. Os resultados dos estudos preliminares foram utilizados para criar um procedimento de busca que varre o código JavaScript criando variantes do programa que sejam menores e passem em todos os casos de teste do programa original. Aplicamos este procedimento a 19 programas JavaScript, variando de 92 a 15.602 linhas de código, e observamos reduções de 0,2% a 73,8% do código original, bem como uma relação entre a qualidade do conjunto de casos de testes e a capacidade de reduzir o tamanho dos programas.Universidade Federal do Rio de JaneiroBrasilInstituto Alberto Luiz Coimbra de Pós-Graduação e Pesquisa de EngenhariaPrograma de Pós-Graduação em Engenharia de Sistemas e ComputaçãoUFRJTravassos, Guilherme Hortahttp://lattes.cnpq.br/7541486051032916http://lattes.cnpq.br/6738473152907998Barros, Márcio de Oliveirahttp://lattes.cnpq.br/0821562324429813Vergilio, Silvia ReginaMurta, Leonardo Gresta PalinoPires, Paulo de FigueiredoOliveira, Toacy Cavalcante deFarzat, Fabio de Almeida2020-09-20T20:04:46Z2023-12-21T03:02:17Z2018-12info:eu-repo/semantics/publishedVersioninfo:eu-repo/semantics/doctoralThesishttp://hdl.handle.net/11422/13045porinfo:eu-repo/semantics/openAccessreponame:Repositório Institucional da UFRJinstname:Universidade Federal do Rio de Janeiro (UFRJ)instacron:UFRJ2023-12-21T03:02:17Zoai:pantheon.ufrj.br:11422/13045Repositório InstitucionalPUBhttp://www.pantheon.ufrj.br/oai/requestpantheon@sibi.ufrj.bropendoar:2023-12-21T03:02:17Repositório Institucional da UFRJ - Universidade Federal do Rio de Janeiro (UFRJ)false
dc.title.none.fl_str_mv Otimização para reduzir o tamanho de código-fonte JavaScript
title Otimização para reduzir o tamanho de código-fonte JavaScript
spellingShingle Otimização para reduzir o tamanho de código-fonte JavaScript
Farzat, Fabio de Almeida
Otimização de código-fonte
Engenharia de software baseada em busca
Heurísticas
Melhoramento Genético
Programação genética
CNPQ::ENGENHARIAS
title_short Otimização para reduzir o tamanho de código-fonte JavaScript
title_full Otimização para reduzir o tamanho de código-fonte JavaScript
title_fullStr Otimização para reduzir o tamanho de código-fonte JavaScript
title_full_unstemmed Otimização para reduzir o tamanho de código-fonte JavaScript
title_sort Otimização para reduzir o tamanho de código-fonte JavaScript
author Farzat, Fabio de Almeida
author_facet Farzat, Fabio de Almeida
author_role author
dc.contributor.none.fl_str_mv Travassos, Guilherme Horta
http://lattes.cnpq.br/7541486051032916
http://lattes.cnpq.br/6738473152907998
Barros, Márcio de Oliveira
http://lattes.cnpq.br/0821562324429813
Vergilio, Silvia Regina
Murta, Leonardo Gresta Palino
Pires, Paulo de Figueiredo
Oliveira, Toacy Cavalcante de
dc.contributor.author.fl_str_mv Farzat, Fabio de Almeida
dc.subject.por.fl_str_mv Otimização de código-fonte
Engenharia de software baseada em busca
Heurísticas
Melhoramento Genético
Programação genética
CNPQ::ENGENHARIAS
topic Otimização de código-fonte
Engenharia de software baseada em busca
Heurísticas
Melhoramento Genético
Programação genética
CNPQ::ENGENHARIAS
description JavaScript is one of the most used programming languages for front-end development of Web application. The increase in complexity of front-end features brings concerns about performance, especially the load and execution time of JavaScript code. To reduce the size of JavaScript programs and, therefore, the time required to load and execute these programs in the front-end of Web applications. To characterize the variants of JavaScript programs and use this information to build a search procedure that scans such variants for smaller implementations that pass all test cases. We applied this procedure to 19 JavaScript programs varying from 92 to 15,602 LOC and observed reductions from 0.2% to 73.8% of the original code, as well as a relationship between the quality of a program’s test suite and the ability to reduce its size.
publishDate 2018
dc.date.none.fl_str_mv 2018-12
2020-09-20T20:04:46Z
2023-12-21T03:02:17Z
dc.type.status.fl_str_mv info:eu-repo/semantics/publishedVersion
dc.type.driver.fl_str_mv info:eu-repo/semantics/doctoralThesis
format doctoralThesis
status_str publishedVersion
dc.identifier.uri.fl_str_mv http://hdl.handle.net/11422/13045
url http://hdl.handle.net/11422/13045
dc.language.iso.fl_str_mv por
language por
dc.rights.driver.fl_str_mv info:eu-repo/semantics/openAccess
eu_rights_str_mv openAccess
dc.publisher.none.fl_str_mv Universidade Federal do Rio de Janeiro
Brasil
Instituto Alberto Luiz Coimbra de Pós-Graduação e Pesquisa de Engenharia
Programa de Pós-Graduação em Engenharia de Sistemas e Computação
UFRJ
publisher.none.fl_str_mv Universidade Federal do Rio de Janeiro
Brasil
Instituto Alberto Luiz Coimbra de Pós-Graduação e Pesquisa de Engenharia
Programa de Pós-Graduação em Engenharia de Sistemas e Computação
UFRJ
dc.source.none.fl_str_mv reponame:Repositório Institucional da UFRJ
instname:Universidade Federal do Rio de Janeiro (UFRJ)
instacron:UFRJ
instname_str Universidade Federal do Rio de Janeiro (UFRJ)
instacron_str UFRJ
institution UFRJ
reponame_str Repositório Institucional da UFRJ
collection Repositório Institucional da UFRJ
repository.name.fl_str_mv Repositório Institucional da UFRJ - Universidade Federal do Rio de Janeiro (UFRJ)
repository.mail.fl_str_mv pantheon@sibi.ufrj.br
_version_ 1834470883827122176