author | Christian Urban <urbanc@in.tum.de> |
Fri, 12 Aug 2011 22:37:41 +0200 | |
changeset 2985 | 05ccb61aa628 |
child 2989 | 5df574281b69 |
permissions | -rw-r--r-- |
2985
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
1 |
\documentclass{llncs} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
2 |
\usepackage{times} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
3 |
\usepackage{isabelle} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
4 |
\usepackage{isabellesym} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
5 |
\usepackage{amsmath} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
6 |
\usepackage{amssymb} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
7 |
%%\usepackage{amsthm} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
8 |
\usepackage{tikz} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
9 |
\usepackage{pgf} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
10 |
\usepackage{pdfsetup} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
11 |
\usepackage{ot1patch} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
12 |
\usepackage{times} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
13 |
\usepackage{boxedminipage} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
14 |
\usepackage{proof} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
15 |
\usepackage{setspace} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
16 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
17 |
\allowdisplaybreaks |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
18 |
\urlstyle{rm} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
19 |
\isabellestyle{it} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
20 |
\renewcommand{\isastyleminor}{\it}% |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
21 |
\renewcommand{\isastyle}{\normalsize\it}% |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
22 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
23 |
\DeclareRobustCommand{\flqq}{\mbox{\guillemotleft}} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
24 |
\DeclareRobustCommand{\frqq}{\mbox{\guillemotright}} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
25 |
\renewcommand{\isacharunderscore}{\mbox{$\_\!\_$}} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
26 |
\renewcommand{\isasymbullet}{{\raisebox{-0.4mm}{\Large$\boldsymbol{\hspace{-0.5mm}\cdot\hspace{-0.5mm}}$}}} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
27 |
\def\dn{\,\stackrel{\mbox{\scriptsize def}}{=}\,} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
28 |
\renewcommand{\isasymequiv}{$\dn$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
29 |
%%\renewcommand{\isasymiota}{} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
30 |
\renewcommand{\isasymxi}{$..$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
31 |
\renewcommand{\isasymemptyset}{$\varnothing$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
32 |
\newcommand{\isasymnotapprox}{$\not\approx$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
33 |
\newcommand{\isasymLET}{$\mathtt{let}$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
34 |
\newcommand{\isasymAND}{$\mathtt{and}$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
35 |
\newcommand{\isasymIN}{$\mathtt{in}$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
36 |
\newcommand{\isasymEND}{$\mathtt{end}$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
37 |
\newcommand{\isasymBIND}{$\mathtt{bind}$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
38 |
\newcommand{\isasymANIL}{$\mathtt{anil}$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
39 |
\newcommand{\isasymACONS}{$\mathtt{acons}$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
40 |
\newcommand{\isasymCASE}{$\mathtt{case}$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
41 |
\newcommand{\isasymOF}{$\mathtt{of}$} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
42 |
\newcommand{\isasymAL}{\makebox[0mm][l]{$^\alpha$}} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
43 |
\newcommand{\isasymPRIME}{\makebox[0mm][l]{$'$}} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
44 |
\newcommand{\isasymFRESH}{\#} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
45 |
\newcommand{\LET}{\;\mathtt{let}\;} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
46 |
\newcommand{\IN}{\;\mathtt{in}\;} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
47 |
\newcommand{\END}{\;\mathtt{end}\;} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
48 |
\newcommand{\AND}{\;\mathtt{and}\;} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
49 |
\newcommand{\fv}{\mathit{fv}} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
50 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
51 |
\newcommand{\numbered}[1]{\refstepcounter{equation}{\rm(\arabic{equation})}\label{#1}} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
52 |
%----------------- theorem definitions ---------- |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
53 |
%%\theoremstyle{plain} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
54 |
%%\spnewtheorem{thm}[section]{Theorem} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
55 |
%%\newtheorem{property}[thm]{Property} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
56 |
%%\newtheorem{lemma}[thm]{Lemma} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
57 |
%%\spnewtheorem{defn}[theorem]{Definition} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
58 |
%%\spnewtheorem{exmple}[theorem]{Example} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
59 |
\spnewtheorem{myproperty}{Property}{\bfseries}{\rmfamily} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
60 |
%-------------------- environment definitions ----------------- |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
61 |
\newenvironment{proof-of}[1]{{\em Proof of #1:}}{} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
62 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
63 |
%\addtolength{\textwidth}{2mm} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
64 |
\addtolength{\parskip}{-0.33mm} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
65 |
\begin{document} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
66 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
67 |
\title{General Bindings and Alpha-Equivalence\\ in Nominal Isabelle} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
68 |
\author{Christian Urban and Cezary Kaliszyk} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
69 |
\institute{TU Munich, Germany} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
70 |
%%%{\{urbanc, kaliszyk\}@in.tum.de} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
71 |
\maketitle |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
72 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
73 |
\begin{abstract} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
74 |
Nominal Isabelle is a definitional extension of the Isabelle/HOL theorem |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
75 |
prover. It provides a proving infrastructure for reasoning about |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
76 |
programming language calculi involving named bound variables (as |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
77 |
opposed to de-Bruijn indices). In this paper we present an extension of |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
78 |
Nominal Isabelle for dealing with general bindings, that means |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
79 |
term-constructors where multiple variables are bound at once. Such general |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
80 |
bindings are ubiquitous in programming language research and only very |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
81 |
poorly supported with single binders, such as lambda-abstractions. Our |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
82 |
extension includes new definitions of $\alpha$-equivalence and establishes |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
83 |
automatically the reasoning infrastructure for $\alpha$-equated terms. We |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
84 |
also prove strong induction principles that have the usual variable |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
85 |
convention already built in. |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
86 |
\end{abstract} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
87 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
88 |
%\category{F.4.1}{subcategory}{third-level} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
89 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
90 |
%\terms |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
91 |
%formal reasoning, programming language calculi |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
92 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
93 |
%\keywords |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
94 |
%nominal logic work, variable convention |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
95 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
96 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
97 |
\input{session} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
98 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
99 |
\begin{spacing}{0.9} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
100 |
\bibliographystyle{plain} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
101 |
\bibliography{root} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
102 |
\end{spacing} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
103 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
104 |
%\pagebreak |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
105 |
%\input{Appendix} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
106 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
107 |
\end{document} |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
108 |
|
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
109 |
%%% Local Variables: |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
110 |
%%% mode: latex |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
111 |
%%% TeX-master: t |
05ccb61aa628
started lmcs paper (isabelle make lmcs)
Christian Urban <urbanc@in.tum.de>
parents:
diff
changeset
|
112 |
%%% End: |