Tesis
Nominal equational problems modulo associativity, commutativity and associativity-commutativity
Fecha
2019-09-27Registro en:
CARVALHO SEGUNDO, Washington Luís Ribeiro de. Nominal equational problems modulo associativity, commutativity and associativity-commutativity. 2019. xi, 161 f., il. Tese (Doutorado em Informática)—Universidade de Brasília, Brasília, 2019.
Autor
Carvalho Segundo, Washington Luís Ribeiro de
Institución
Resumen
A sintaxe nominal tem sido utilizada em vários contextos por quase duas décadas. Ela é
uma ferramenta poderosa para se lidar com ligação de variáveis de uma forma concreta,
que pode ser aplicada a qualquer especificação na qual parâmetros são utilizados para se
abstrair variáveis, tal como em predicados e funções. Na sintaxe nominal, objetos que
são sintaticamente diferentes podem ter a mesma semântica módulo alfa-conversão, tal
como acontece no Cálculo Lambda. O tratamento de igualdades, em especial a alphaequivalêcia,
é algo essencial em linguagens formais e implementações. Este trabalho investiga
a alpha-equivalência nominal com símbolos de função associativos (A), comutativos
(C) e associativos-comutativos (AC). Verificação de equivalência, casamento e unificação
módulo A, C e AC são investigados. Em relação a verificação de igualdade, as alphaequivalências
nominais módulo A, C e AC foram especificadas em Coq e provadas ser
corretas. Um algoritmo implementado em OCaml para verificação de igualdade módulo
A, C e AC é automaticamente extraído da especificação e experimentos são executados
utilizando-se também um algoritmo aperfeiçoado. Limites superiores para o tempo de
execução na solução de problemas nominais de verificação equacional são fornecidos. Um
algoritmo de unificação módulo C baseado em regras de redução é especificado em Coq
e provado ser correto e completo. Por meio do uso de variáveis protegidas, este algoritmo
de unificação resolve problemas de casamento nominal módulo C, o que foi também
formalizado ser correto e completo. O algoritmo de unificação baseado em regras de redução
fornece uma família finita de conjuntos de equações nominais de ponto fixo. Cada
uma destas equações pode ter um conjunto infinito de soluções independentes. Portanto,
demonstra-se que problemas de unificação nominal módulo C e AC podem gerar um conjunto
infinito de soluções independentes. Este fato contrasta com unificação sintática
módulo C ou AC, que são conhecidas por estar na classe finitária de problemas. Uma
implementação em OCaml do algoritmo de unificação nominal é fornecida e utilizado para
se construir exemplos.