Universidad Complutense de Madrid
E-Prints Complutense

Análisis de terminación para una plataforma de verificación de programas
Analysis termination for a program verification platform

Impacto

Downloads

Downloads per month over past year



Holubanský, Jakub and Mínguez Horcajada, Álvaro (2016) Análisis de terminación para una plataforma de verificación de programas. [Trabajo Fin de Grado]

[img]
Preview
PDF
1MB


Abstract

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.


Item Type:Trabajo Fin de Grado
Additional Information:

Trabajo de Fin de Grado en Ingeniería Informática (Universidad Complutense, Facultad de Informática, curso 2015/2016)

Directors:
DirectorsDirector email
Peña Mari, Ricardo Vicente
Uncontrolled Keywords:Análisis de terminación, Verificación de programas, Programación líneal, Autómatas finitos con variables enteras
Palabras clave (otros idiomas):Termination analysis, Program verification, Linear programming, Integer interpreted automata
Subjects:Sciences > Computer science > Computer programming
Sciences > Mathematics > Logic, Symbolic and mathematical
Título de Grado:Grado en Ingeniería Informática
ID Code:39842
Deposited On:02 Nov 2016 16:50
Last Modified:02 Nov 2016 16:50

Origin of downloads

Repository Staff Only: item control page