Análisis de terminación para una plataforma de verificación de programas


Autoria(s): Holubanský, Jakub; Mínguez Horcajada, Álvaro
Contribuinte(s)

Peña Mari, Ricardo Vicente

Data(s)

2016

Resumo

De entre una serie de métodos estudiados acerca de la terminación de algoritmos, tales como Size-Change Termination o Isabelle, elegimos el método de RANK como instrumento para desarrollar nuestro propio programa de detección de terminación sobre el lenguaje de la IR. Esta decisión se basa en el coste polinómico de este método (frente a costes en PSPACE como el Size-Change Termination)y la posibilidad de obtener una herramienta asociada al mismo que además nos da la posibilidad de conocer un tiempo de ejecución aproximado. La herramienta asociada a RANK es compleja y va de la mano de una segunda herramienta (ASPIC). Hemos estudiado varios ejemplos, tales como el Mergesort o el Quicksort, para explicar la utilización de estas dos herramientas y a su vez ponernos en situación de los diferentes problemas que nos podemos encontrar a la hora de estudiar un programa. Partiendo del proceso que hemos usado para construir los automátas de los ejemplos anteriores, hemos diseñado e implementado en Java un algoritmo para transformar programas en el lenguaje de la IR al formato de entrada de RANK. Los resultados han sido satisfactorios, puesto que con los autómatas generados somos capaces de detectar de forma automatizada la terminación de, entre otros, los algoritmos recursivos antes mencionados.

Formato

application/pdf

Identificador

http://eprints.ucm.es/39842/1/proyecto.pdf

Idioma(s)

es

Relação

http://eprints.ucm.es/39842/

Direitos

info:eu-repo/semantics/openAccess

Palavras-Chave #Programación de ordenadores #Lógica simbólica y matemática
Tipo

info:eu-repo/semantics/bachelorThesis

PeerReviewed