]> matita.cs.unibo.it Git - fireball-separation.git/commitdiff
Remove Marco Polo files new_algorithm
authoracondolu <andrea.condoluci@unibo.it>
Tue, 6 Mar 2018 09:19:12 +0000 (10:19 +0100)
committeracondolu <andrea.condoluci@unibo.it>
Tue, 29 May 2018 14:41:20 +0000 (16:41 +0200)
marco polo/statement.bib [deleted file]
marco polo/statement.tex [deleted file]

diff --git a/marco polo/statement.bib b/marco polo/statement.bib
deleted file mode 100644 (file)
index fbe6808..0000000
+++ /dev/null
@@ -1,128 +0,0 @@
-@article{bohm,\r
- author =       "Corrado B{\"o}hm",\r
- title =        "Alcune propriet{\`a} delle Forme $\beta\eta$-normali nel\r
- $\lambda${K}-calcolo. ({Italian})",\r
- journal =      "Pubblicazioni dell'IAC",\r
- volume =       "696:119",\r
- year =         "1968"\r
-}\r
-\r
-@article{DBLP:journals/tcs/Huet93,\r
-  author    = {G{\'{e}}rard P. Huet},\r
-  title     = {An Analysis of {B}{\"{o}}hm's theorem},\r
-  journal   = {Theor. Comput. Sci.},\r
-  volume    = {121},\r
-  number    = {1{\&}2},\r
-  pages     = {145--167},\r
-  year      = {1993},\r
-  url       = {https://doi.org/10.1016/0304-3975(93)90087-A},\r
-  doi       = {10.1016/0304-3975(93)90087-A},\r
-  timestamp = {Sun, 28 May 2017 13:20:07 +0200},\r
-  biburl    = {http://dblp.uni-trier.de/rec/bib/journals/tcs/Huet93},\r
-  bibsource = {dblp computer science bibliography, http://dblp.org}\r
-}\r
-\r
-@phdthesis{morris,\r
-  author       = {J.-H. Morris},\r
-  title        = {Lambda-calculus models of programming languages},\r
-  school       = {M.I.T.},\r
-  year         = 1968,\r
-}\r
-\r
-@inproceedings{DBLP:conf/lics/Saurin05,\r
-  author    = {Alexis Saurin},\r
-  title     = {Separation with Streams in the $\lambda\mu$-calculus},\r
-  booktitle = {20th {IEEE} Symposium on Logic in Computer Science {(LICS} 2005),\r
-               26-29 June 2005, Chicago, IL, USA, Proceedings},\r
-  pages     = {356--365},\r
-  year      = {2005},\r
-  crossref  = {DBLP:conf/lics/2005},\r
-  url       = {https://doi.org/10.1109/LICS.2005.48},\r
-  doi       = {10.1109/LICS.2005.48},\r
-  timestamp = {Thu, 25 May 2017 00:42:40 +0200},\r
-  biburl    = {http://dblp.uni-trier.de/rec/bib/conf/lics/Saurin05},\r
-  bibsource = {dblp computer science bibliography, http://dblp.org}\r
-}\r
-@proceedings{DBLP:conf/lics/2005,\r
-  title     = {20th {IEEE} Symposium on Logic in Computer Science {(LICS} 2005),\r
-               26-29 June 2005, Chicago, IL, USA, Proceedings},\r
-  publisher = {{IEEE} Computer Society},\r
-  year      = {2005},\r
-  url       = {http://ieeexplore.ieee.org/xpl/mostRecentIssue.jsp?punumber=10087},\r
-  isbn      = {0-7695-2266-1},\r
-  timestamp = {Fri, 21 Nov 2014 14:08:56 +0100},\r
-  biburl    = {http://dblp.uni-trier.de/rec/bib/conf/lics/2005},\r
-  bibsource = {dblp computer science bibliography, http://dblp.org}\r
-}\r
-\r
-@inproceedings{DBLP:conf/cade/Gacek08,\r
-  author    = {Andrew Gacek},\r
-  title     = {The Abella Interactive Theorem Prover ({System} Description)},\r
-  booktitle = {Automated Reasoning, 4th International Joint Conference, {IJCAR} 2008,\r
-               Sydney, Australia, August 12-15, 2008, Proceedings},\r
-  pages     = {154--161},\r
-  year      = {2008},\r
-  crossref  = {DBLP:conf/cade/2008},\r
-  url       = {https://doi.org/10.1007/978-3-540-71070-7_13},\r
-  doi       = {10.1007/978-3-540-71070-7_13},\r
-  timestamp = {Tue, 13 Jun 2017 10:37:55 +0200},\r
-  biburl    = {http://dblp.uni-trier.de/rec/bib/conf/cade/Gacek08},\r
-  bibsource = {dblp computer science bibliography, http://dblp.org}\r
-}\r
-@proceedings{DBLP:conf/cade/2008,\r
-  editor    = {Alessandro Armando and\r
-               Peter Baumgartner and\r
-               Gilles Dowek},\r
-  title     = {Automated Reasoning, 4th International Joint Conference, {IJCAR} 2008,\r
-               Sydney, Australia, August 12-15, 2008, Proceedings},\r
-  series    = {Lecture Notes in Computer Science},\r
-  volume    = {5195},\r
-  publisher = {Springer},\r
-  year      = {2008},\r
-  url       = {https://doi.org/10.1007/978-3-540-71070-7},\r
-  doi       = {10.1007/978-3-540-71070-7},\r
-  isbn      = {978-3-540-71069-1},\r
-  timestamp = {Tue, 13 Jun 2017 10:37:55 +0200},\r
-  biburl    = {http://dblp.uni-trier.de/rec/bib/conf/cade/2008},\r
-  bibsource = {dblp computer science bibliography, http://dblp.org}\r
-}\r
-\r
-@inproceedings{DBLP:conf/lics/AccattoliC15,\r
-  author    = {Beniamino Accattoli and\r
-               Claudio Sacerdoti Coen},\r
-  title     = {On the Relative Usefulness of Fireballs},\r
-  booktitle = {30th Annual {ACM/IEEE} Symposium on Logic in Computer Science, {LICS}\r
-               2015, Kyoto, Japan, July 6-10, 2015},\r
-  pages     = {141--155},\r
-  year      = {2015},\r
-  crossref  = {DBLP:conf/lics/2015},\r
-  url       = {https://doi.org/10.1109/LICS.2015.23},\r
-  doi       = {10.1109/LICS.2015.23},\r
-  timestamp = {Thu, 15 Jun 2017 21:41:13 +0200},\r
-  biburl    = {http://dblp.uni-trier.de/rec/bib/conf/lics/AccattoliC15},\r
-  bibsource = {dblp computer science bibliography, http://dblp.org}\r
-}\r
-@proceedings{DBLP:conf/lics/2015,\r
-  title     = {30th Annual {ACM/IEEE} Symposium on Logic in Computer Science, {LICS}\r
-               2015, Kyoto, Japan, July 6-10, 2015},\r
-  publisher = {{IEEE} Computer Society},\r
-  year      = {2015},\r
-  url       = {http://ieeexplore.ieee.org/xpl/mostRecentIssue.jsp?punumber=7174833},\r
-  isbn      = {978-1-4799-8875-4},\r
-  timestamp = {Wed, 25 May 2016 10:19:57 +0200},\r
-  biburl    = {http://dblp.uni-trier.de/rec/bib/conf/lics/2015},\r
-  bibsource = {dblp computer science bibliography, http://dblp.org}\r
-}\r
-\r
-@article{BOHM1979271,\r
-title = "A discrimination algorithm inside $\lambda$-$\beta$-calculus",\r
-journal = "Theoretical Computer Science",\r
-volume = "8",\r
-number = "3",\r
-pages = "271 - 291",\r
-year = "1979",\r
-note = "",\r
-issn = "0304-3975",\r
-doi = "http://dx.doi.org/10.1016/0304-3975(79)90014-8",\r
-author = "C. B{\"o}hm and M. Dezani-Ciancaglini and P. Peretti and S. Ronchi Della Rocca",\r
-}\r
diff --git a/marco polo/statement.tex b/marco polo/statement.tex
deleted file mode 100644 (file)
index 2672eb8..0000000
+++ /dev/null
@@ -1,138 +0,0 @@
-\documentclass[10pt]{article}\r
-\r
-\title{B\"ohm's Theorem in Abella}\r
-\author{Andrea Condoluci}\r
-\date{June 30, 2017}\r
-\r
-\newcommand{\lc}[0]{{$\lambda$-calculus}}\r
-\newcommand{\bohm}[0]{{B\"ohm}}\r
-\newcommand{\TODO}[1]{\textcolor{red}{\textbf{TODO} #1}}\r
-\newcommand{\fire}[0]{$\lambda_{\operatorname{fire}}$}\r
-\r
-\newcommand{\conv}[1]{=_{#1}}\r
-\newcommand{\convb}[0]{\conv{\beta}}\r
-\newcommand{\convbe}[0]{\conv{\beta\eta}}\r
-\r
-\usepackage{xcolor}\r
-\usepackage{amsmath, amsthm, amssymb}\r
-\usepackage{verbatim, hyperref}\r
-\usepackage[normalem]{ulem}\r
-\usepackage{cleveref}\r
-\r
-\theoremstyle{definition}\r
-\newtheorem{theorem}{Theorem}\r
-\newtheorem*{theoren}{Theorem}\r
-\newtheorem{lemma}[theorem]{Lemma}\r
-% \newtheorem{corollary}[theorem]{Corollary}\r
-\newtheorem*{corollary}{Corollary}\r
-\newtheorem*{notation}{Notation}\r
-\newtheorem*{definition}{Definition}\r
-\newtheorem{fact}[theorem]{Fact}\r
-\r
-\r
-\begin{document}\r
-\r
-\maketitle\r
-\r
-Segue una presentazione del progetto di ricerca che effettuerei presso il \textit{Laboratoire d'informatique de l'\'Ecole polytechnique} di Parigi nel gruppo di ricerca \textit{Parsifal} (\url{https://team.inria.fr/parsifal/}), con il supporto economico del programma Marco Polo.\r
-\r
-\begin{abstract}\r
- \bohm's theorem is a celebrated theorem in untyped lambda-calculus, and it states that lambda-terms behave differently if they are syntactically different. The proof of this statement is well-known, and consists of a separation algorithm manipulating the syntax of lambda-terms. The proof assistant Abella (co-developed at LIX, Paris) is particularly suited to handle proofs which manipulate lambda-terms. Formalizing \bohm's theorem in Abella would both challenge Abella's underlying logic, and assist us proving correct a much harder separation algorithm for a different calculus that we are studying.\r
-\end{abstract}\r
-\r
-\section*{Background}\r
-\r
-% \subsubsection*{Lambda Calculus}\r
- \textit{Pure lambda calculus} (which we call \lc) was originally conceived by Alonzo Church, being intended as a general theory of functions which could serve as foundation for mathematics.\r
- Its syntax is based on two basic conceptual operations: $\lambda$-abstraction and application. Since \lc{} can represent computable functions, it is considered an idealized functional programming language, where $\beta$-reduction corresponds to a computational step.\r
-\r
- In the following, we say that $M \convb N$ if $M$ and $N$ are $\alpha\beta$-convertible ($\alpha$ being the renaming of bound variables). $\eta$-conversion allows expansion and contraction of the arguments of functions, and corresponds to function extensionality. A term is in \textit{normal form} when no more $\beta$-reductions are viable.\r
-\r
-\subsubsection*{Separation Theorem}\r
- Among the most important results for \lc{} (like fixpoint, Church-Rosser, and normalization theorems) is the \textit{separation theorem} (also known as \bohm's theorem \cite{bohm}).\r
-\r
- Even though this theorem may seem a basically syntactical property, its importance lays on showing that the syntactical constructions and the reduction rules of \lc{} work well together \cite{DBLP:conf/lics/Saurin05}. In particular, two essential consequences are:\r
-\r
- \begin{enumerate}\r
-  \item any non-trivial model of the \lc{} cannot identify $\beta\eta$-different normal forms;\r
-  \item normal forms can be explored by the only means of computational rules.\r
- \end{enumerate}\r
-\r
- Intuitively, \bohm's theorem states that when two $\lambda$-terms are syntactically different, then one can put them in the context of a bigger $\lambda$ program such that they reduce to two clearly different terms. By \textit{context} (denoted by $E[\,]$) we mean a $\lambda$-term with a hole ($[\,]$ is the hole), such that $E[M]$ is the $\lambda$-term obtained by replacing in $E[\,]$ the hole $[\,]$ with $M$.\r
-\r
-\begin{theoren}[\bohm{} theorem]\r
- Let $M$, $N$ be $\beta\eta$-distinct $\lambda$-terms in normal form; then there exists a context $E[\,]$ such that:\r
- \[\begin{array}{ll}\r
-  E[M] & \convb \operatorname{true} \text{, and}\\\r
-  E[N] & \convb \operatorname{false}, \\\r
- \end{array}\]\r
- where $\operatorname{true}:=\lambda x\,y.\,x$ and $\operatorname{false}:=\lambda x\,y.\,y$.\r
-\end{theoren}\r
-The proof of this theorem is carried out by induction on so-called \textit{\bohm{} trees} (syntax trees computed from the normal forms), and by means of \textit{\bohm{} transformations}. The technique used in the proof is called ``\bohm-out'', and is a powerful tool that was applied to separation problems in other $\lambda$-theories.\r
-\r
-Let us now make some remarks which will be useful in the last section.\r
-\r
-Firstly, note that an easy consequence of the theorem is the following:\r
-\r
-\begin{corollary}\r
- Let $M$, $N$ be $\beta\eta$-distinct $\lambda$-terms in normal form; then there exists a context $E[\,]$ such that $E[M]$ has a normal form, and $E[N]$ has no normal form.\r
-\end{corollary}\r
-\r
-This last formulation of \bohm's theorem is clearly related to the \textit{observational} or \textit{contextual equivalence} \cite{morris}, which was born at the times of the \bohm's theorem. Two terms are said to be \textit{observationally equivalent} if, when put in the same context, either they both converge to a normal form, or they both diverge. Intuitively, terms are observationally equivalent if they behave in the same way, when ``observed'' from the outside.\r
-\r
-It is now clear that \bohm's theorem actually states that, in the case of terms with a normal form, observational equivalence coincides with $\beta\eta$-convertibility.\r
-\r
-Note that the original proof of \bohm's theorem is \textit{constructive}: it consists of an actual algorithm which, given two $\beta\eta$-distinct $\lambda$-terms, constructs a corresponding discriminating context. Such algorithm was implemented in CAML in \cite{DBLP:journals/tcs/Huet93}, but to my knowledge it was never formalized in a \textit{proof assistant}.\r
-A formalization would not only yield a verified implementation of the algorithm (which is actually a well-known result and beyond doubt), but mainly:\r
-\begin{enumerate}\r
- \item probe the proof assistant in which it will be formalized and push it to its limits (see section Outcome);\r
- \item be a starting point to help us prove correct other separation algorithms which we are currently working on (see section Future Work).\r
-\end{enumerate}\r
-% A formalization would yield a verified implementation (proven to be correct, and to comply with its specification) of the algorithm; in addition, it would add up to the pile of formalized mathematical knowledge, allowing other researchers to build on top of it.\r
-\r
-\subsubsection*{Abella}\r
-The plan is to formalize \bohm's theorem in Abella. \textit{Abella} is an interactive theorem prover based on $\lambda$-tree syntax \cite{DBLP:conf/cade/Gacek08}, and it is intended for reasoning about object languages whose syntactic structure is presented through recursive rules.\r
-\r
-The strength of Abella is how it treats \textit{binding} in object languages: in fact, object-level bindings are represented in Abella using \textit{meta-level abstractions}. This makes the encoding of object languages much more straightforward, since usual notions related to binding (such as $\alpha$-equivalence and capture-avoiding substitutions) are already built into the logic and need not be implemented again at the specification level.\r
-\r
-To reason over $\lambda$-tree syntax, Abella uses the $\nabla$ (\textit{nabla}) quantifier, which allows one to move binders from the object-logic to the meta-logic. $\nabla$-bound variables are instantiated with \textit{nominal constants}, and indeed the intuition is that the formula $\nabla x.\,F$ holds iff $F$ holds for whatever $x$, but in a ``generic'' way.\r
-\r
-As a matter of fact, Abella has been used effectively to formalize proofs in which objects with bindings must be manipulated in a fundamental way: for example, some results in \lc{} (subject reduction, uniqueness of typing, normalizability \`a la Tait) and proof theory (cut-admissibility).\r
-\r
-\section*{Outcome}\r
-\r
-As a consequence of Abella's successful handling of binding, and of the syntactic nature of \bohm's theorem, Abella may be particularly well-suited to host its formalization. But this is not completely straightforward: let's see one possible obstacle. One $\nabla$ quantifier handles one binder at the object level, but $\lambda$-terms in strong normal form in \fire{} have the form $\lambda x_1\ldots x_n.\,x_j\,f_1\ldots f_m$ ($f$'s are fireballs), where the normal form begins with $n$ $\lambda$-abstractions. In order to handle iterated binders, it would seem natural for $\nabla$ to quantify over ``vectors'' of variables, but this is not possible at the moment. In the light of this and other technical complications, the formalization of \bohm's theorem won't be trivial, and will hopefully shed some light on possible drawbacks/improvements in Abella's logic; this is also the reason why the hosting research group at LIX, Paris is interested in this project.\r
-\r
-\section*{Future work}\r
- As we noted, the computer formalization of \bohm{}'s theorem would be a convenient result on its own\r
- sake; nevertheless, it poses a solid starting point to provide formal proofs of similar separation results in other $\lambda$-theories and other $\lambda$-calculi. %, for example in extensions of \lc, or according to different evaluation strategies.\r
-\r
- For example, the problem of separating $\lambda$-terms popped up inevitably while working with Claudio Sacerdoti Coen and Beniamino Accattoli on the observational equality of the \textit{fireball calculus} \fire{} \cite{DBLP:conf/lics/AccattoliC15}. Our goal there is to provide a suitable notion of \textit{bisimulation} in order to characterize syntactically the equivalence of programs (i.e. contextual equivalence).\r
-\r
- \subsubsection*{The Fireball Calculus}\r
-\r
- \fire{} is an \textit{open} call-by-value \lc{}. Recall that \textit{call-by-value} is an evaluation strategy for the \lc{} in which - intuitively - functions' arguments are evaluated before the function call. \fire{} is similar to Plotkin's call-by-value \lc{}, which is at the foundation of programming languages (OCaml) and proof assistants (Coq), but \fire{} (as a \textit{weak calculus}, when reductions occur only outside abstractions) is particularly elegant because:\r
- \begin{itemize}\r
-  \item it is \textit{strongly confluent};\r
-  \item normal forms have a clean syntactic description as \textit{fireballs}: a fireball is either an abstractions (like values in Plotkin), or a variable possibly applied to other fireballs.\r
- \end{itemize}\r
-\r
- Strong evaluation may be obtained as usual by iterating the weak one under abstractions. But, mainly because fireballs are not closed under substitutions, the strong calculus has some issues:\r
- \begin{itemize}\r
-  \item it is \textit{not} confluent;\r
-  \item contextual equivalence is not closed under reduction.\r
-  % a term and its strong normal form may not be contextual equivalent (in the usual sense).\r
-  For example: \[(\lambda y.\,z) \, (x\, x) \to_{\beta} z ,\] but in a context replacing the free variable $x$ with $\lambda x.\, x\, x$, the term on the left diverges, and the one on the right converges.\r
-\r
- \end{itemize}\r
-\r
- Therefore, it is not easy to give a syntactic characterization of contextually equivalent terms. We are working on a separation algorithm which departs non-trivially from \bohm's theorem and other separation algorithms \cite{BOHM1979271}, and it would be the first (working) separation algorithm in call-by-value. After a couple of months of trial and errors, we now understand quite well the problem, and we are done with designing the separation algorithm. It still remains to prove termination, which seems a difficult task.\r
- In fact, while the \bohm-out technique is ``completely described in less than a page of ML code'' \cite{DBLP:journals/tcs/Huet93}, our algorithm (as of now) consists of more than one-thousand lines of OCaml code; additionally, our procedure relies on the careful repetition of basic trasformations in a certain order, that when altered brings easily to looping and non-termination. Proving termination for such a long algorithm \textit{on paper} is a long and error-prone job, which would profit the support of a proof assistant.\r
-\r
- The formalization of \bohm's theorem would hence be the first step in formalizing our own separation algorithm, and facilitate us proving that the algorithm terminates and is indeed correct.\r
-\r
-\r
-\bibliographystyle{plain}\r
-\bibliography{statement}\r
-\r
-\end{document}\r