Skip to content

Commit

Permalink
coq_rules: subtyping rules
Browse files Browse the repository at this point in the history
  • Loading branch information
lucaspena committed May 20, 2020
1 parent 74f3359 commit 7331f17
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 3 deletions.
Binary file modified prover/coq_rules/coq_rules.pdf
Binary file not shown.
21 changes: 18 additions & 3 deletions prover/coq_rules/coq_rules.tex
Original file line number Diff line number Diff line change
Expand Up @@ -343,8 +343,8 @@ \subsection{Conversion Rules}
\end{center}
In addition to the above convertibility rules, we also allow identifying a term
$t$ of type $\cfa{x}{t}{U}$ with its \emph{$\eta$-expansion} $\clm{x}{T}{(t x)}$
for $x$ fresh in $t$. Note \emph{$\eta$-reduction} is deliberately not defined
(TODO: show example?).
for $x$ fresh in $t$. Note \emph{$\eta$-reduction} is deliberately not defined.
% TODO: show example?

\begin{notation}
We write $E[\Gamma] \vdash t \red u$ for the contextual closure of the rules
Expand All @@ -365,7 +365,22 @@ \subsection{Conversion Rules}
\[ E[\Gamma] \vdash t_1 \red \ldots \red u_1 \text{ and } E[\Gamma] \vdash t_2 \red \ldots \red u_2 \]
and either $u_1$ and $u_2$ are identical up irrelevant subterms, or they are
convertible up to $\eta$-exxpansion. We denote this as
$E[\Gamma] \vdash t_1 =_{\beta\delta\iota\zeta\eta} t_2$
$E[\Gamma] \vdash t_1 \conveq t_2$
\end{definition}

\subsection{Subtyping Rules}
The \emph{subtyping} relation is inductively defined as follows:
% TODO: display as proof rules?
\begin{itemize}
\item if $E[\Gamma] \vdash t \conveq u$, then $E[\Gamma] \vdash t \subty u$
\item if $i \leq j$, then $E[\Gamma] \vdash \Type(i) \subty \Type(j)$
\item $E[\Gamma] \vdash \Set \subty \Type(i)$ for all $i$
\item $E[\Gamma] \vdash \Prop \subty \Set$
\item if $E[\Gamma] \vdash T \conveq U$ and
$E[\Gamma \dcln (\lasm{x}{T})] \vdash T' \subty U'$, then
$E[\Gamma] \vdash \cfa{x}{T}{T'} \subty \cfa{x}{U}{U'}$
\end{itemize}

\subsection{Conversion/Subtyping: Polymorphic Universes}

\end{document}
2 changes: 2 additions & 0 deletions prover/coq_rules/newcommands.tex
Original file line number Diff line number Diff line change
Expand Up @@ -35,3 +35,5 @@
\newcommand{\sd}[1]{{{\color{JungleGreen} #1}}}

\newcommand{\red}{\triangleright}
\newcommand{\conveq}{=_{\beta\delta\iota\zeta\eta}}
\newcommand{\subty}{\leq_{\beta\delta\iota\zeta\eta}}

0 comments on commit 7331f17

Please sign in to comment.