--- a/Quotient-Paper/Paper.thy Thu Jun 17 00:27:57 2010 +0100
+++ b/Quotient-Paper/Paper.thy Thu Jun 17 07:34:29 2010 +0200
@@ -247,6 +247,7 @@
at the beginning of this section about having to collect theorems that are
lifted from the raw level to the quotient level into one giant list. Our
quotient package is the first one that is modular so that it allows to lift
+%%% FIXME: First-order ones exist, HOL-Light one lifts theorems separately.
single theorems separately. This has the advantage for the user of being able to develop a
formal theory interactively as a natural progression. A pleasing side-result of
the modularity is that we are able to clearly specify what is involved
@@ -397,6 +398,7 @@
would not be true in general. However, we can prove specific and useful
instances of the quotient theorem. We will
show an example in Section \ref{sec:resp}.
+%%% FIXME the example is gone from the paper?
*}
@@ -843,7 +845,7 @@
the equivalence classes are not equal is necessary.
In the following we will first define the statement of the
- regularized theorem based on @{text "raw_thm"} and the
+ regularized theorem based on @{text "raw_thm"} and
@{text "quot_thm"}. Then we define the statement of the injected theorem, based
on @{text "reg_thm"} theorem and @{text "quot_thm"}. We then show the 3 proofs,
which can all be performed independently from each other.
@@ -870,11 +872,8 @@
@{text "\<forall>x\<^sup>\<sigma> \<in> Respects (REL (\<sigma>, \<tau>)). REG (t, s)"}
\end{cases}$\smallskip\\
\multicolumn{3}{@ {}l}{equality:}\smallskip\\
- @{text "REG (=\<^bsup>\<sigma>\<Rightarrow>\<sigma>\<Rightarrow>bool\<^esup>, =\<^bsup>\<tau>\<Rightarrow>\<tau>\<Rightarrow>bool\<^esup>)"} & $\dn$ &
- $\begin{cases}
- @{text "="} \quad\mbox{provided @{text "\<sigma> = \<tau>"}}\\
- @{text "REL (\<sigma>, \<tau>)"}\\
- \end{cases}$\\
+ %% REL of two equal types is the equality so we do not need a separate case
+ @{text "REG (=\<^bsup>\<sigma>\<Rightarrow>\<sigma>\<Rightarrow>bool\<^esup>, =\<^bsup>\<tau>\<Rightarrow>\<tau>\<Rightarrow>bool\<^esup>)"} & $\dn$ & @{text "REL (\<sigma>, \<tau>)"}\\\smallskip\\
\multicolumn{3}{@ {}l}{applications, variables and constants:}\\
@{text "REG (t\<^isub>1 t\<^isub>2, s\<^isub>1 s\<^isub>2)"} & $\dn$ & @{text "REG (t\<^isub>1, s\<^isub>1) REG (t\<^isub>2, s\<^isub>2)"}\\
@{text "REG (x\<^isub>1, x\<^isub>2)"} & $\dn$ & @{text "x\<^isub>1"}\\
@@ -926,21 +925,22 @@
In the first proof step, establishing @{text "raw_thm \<longrightarrow> reg_thm"}, we always
start with an implication. Isabelle provides \emph{mono} rules that can split up
the implications into simpler implication subgoals. This succeeds for every
- monotone connectives, except in places wher the function @{text REG} inserted,
+ monotone connective, except in places wher the function @{text REG} inserted,
for example, a quantifier by a bounded quantifier. In this case we have
rules of the form
@{text [display, indent=10] "(\<forall>x. R x \<longrightarrow> (P x \<longrightarrow> Q x)) \<longrightarrow> (\<forall>x. P x \<longrightarrow> \<forall>x \<in> R. Q x)"}
\noindent
- They decompose a bounded quantifier on the right-hand side, but are only applicable
- if we can prove that
+ They decompose a bounded quantifier on the right-hand side. We can decompose a
+ bounded quantifier anywhere if R is an equivalence relation or
+ if it is a relation over function types with the range being an equivalence
+ relation. If @{text R} is an equivalence relation we can prove that
@{text [display, indent=10] "\<forall>x \<in> Respects R. P x = \<forall>x. P x"}
\noindent
- And finally it can be removed anywhere if @{term R\<^isub>2} is an equivalence relation
- and we can prove
+ And when @{term R\<^isub>2} is an equivalence relation and we can prove
@{thm [display, indent=10] (concl) ball_reg_eqv_range[of R\<^isub>1 R\<^isub>2, no_vars]}
@@ -951,7 +951,7 @@
because this allows us to completely separate the first and the second
proof step into independent ``units''.
- The secon proof step, establishing @{text "reg_thm \<longleftrightarrow> inj_thm"}, starts with an equality.
+ The second proof step, establishing @{text "reg_thm \<longleftrightarrow> inj_thm"}, starts with an equality.
The proof again follows the structure of the
two underlying terms, and is defined for a goal being a relation between these two terms.