Protocols between programs and proofs


Autoria(s): Poernomo, Iman; Crossley, John
Contribuinte(s)

Lau, Kung-Kiu

Data(s)

2001

Resumo

In this paper we describe a new protocol that we call the Curry-Howard protocol between a theory and the programs extracted from it. This protocol leads to the expansion of the theory and the production of more powerful programs. The methodology we use for automatically extracting “correct” programs from proofs is a development of the well-known Curry-Howard process. Program extraction has been developed by many authors, but our presentation is ultimately aimed at a practical, usable system and has a number of novel features. These include 1. a very simple and natural mimicking of ordinary mathematical practice and likewise the use of established computer programs when we obtain programs from formal proofs, and 2. a conceptual distinction between programs on the one hand, and proofs of theorems that yield programs on the other. An implementation of our methodology is the Fred system. As an example of our protocol we describe a constructive proof of the well-known theorem that every graph of even parity can be decomposed into a list of disjoint cycles. Given such a graph as input, the extracted program produces a list of the (non-trivial) disjoint cycles as promised.

Formato

application/pdf

Identificador

http://calcium.dcs.kcl.ac.uk/251/1/protocols-between-programs-and-proofs.pdf

Poernomo, Iman and Crossley, John (2001) Protocols between programs and proofs. In: Logic Based Program Synthesis and Transformation, 10th International Workshop, LOPSTR 2000 London, UK, July 24–28, 2000 Selected Papers.

Publicador

Springer

Relação

http://calcium.dcs.kcl.ac.uk/251/

Tipo

Conference or Workshop Item

PeerReviewed