aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--doc/Setoid.tex94
1 files changed, 46 insertions, 48 deletions
diff --git a/doc/Setoid.tex b/doc/Setoid.tex
index b9695f30e..2659cae1e 100644
--- a/doc/Setoid.tex
+++ b/doc/Setoid.tex
@@ -8,10 +8,9 @@ This chapter presents the \texttt{Setoid\_replace} tactic.
\asection{Description of \texttt{Setoid\_replace}}
Working on user-defined structures in \Coq\ is not very easy if
-Leibnitz equality does not denote the intended equality. For example
-using pairs of \verb|nat| to denote rationals always drive to prove
-some boring lemma like
-\verb| (P:nat -> Prop) (P ((3),(6)) ->(P ((1),(2))|.
+Leibniz equality does not denote the intended equality. For example
+using lists to denote finite sets drive to difficulties since two
+non convertible terms can denote the same set.
We present here a \Coq\ module, {\tt Setoid\_replace}, which allow to
structure and automate some parts of the work. In particular, if
@@ -24,12 +23,12 @@ Under the toplevel
load the \texttt{Setoid\_replace} files with the command:
\begin{coq_eval}
- Require Setoid_replace.
+ Require Setoid.
\end{coq_eval}
\begin{quotation}
\begin{verbatim}
-Require Setoid_replace.
+Require Setoid.
\end{verbatim}
\end{quotation}
@@ -39,7 +38,7 @@ The specification of a setoid can be found in the file
\begin{quotation}
\begin{verbatim}
-contrib/setoid/Setoid_replace.v
+theories/Setoids/Setoid.v
\end{verbatim}
\end{quotation}
@@ -62,20 +61,20 @@ Record Setoid_Theory : Prop :=
\end{small}
To define a setoid structure on \verb+A+, you must provide a relation
-on \verb+A+, prove that this relation is an equivalence
-relation, and pack them with the \verb|Build_Setoid_Theory|
-constructor.
+\verb|Aeq| on \verb+A+ and prove that \verb|Aeq| is an equivalence
+relation. That is, you have to define an object of type
+\verb|(Setoid_Theory A Aeq)|.
-Finally to register a ring the syntax is:
+Finally to register a setoid the syntax is:
\comindex{Add Setoid}
\begin{quotation}
- \texttt{Add Setoid} \textit{ A Aequiv ST}
+ \texttt{Add Setoid} \textit{ A Aeq ST}
\end{quotation}
-\noindent where \textit{Aequiv} is a term of type \texttt{A->A->Prop},
+\noindent where \textit{Aeq} is a term of type \texttt{A->A->Prop} and
\textit{ST} is a term of type
-\texttt{(Setoid\_Theory }\textit{A Aequiv}\texttt{)}.
+\texttt{(Setoid\_Theory }\textit{A Aeq}\texttt{)}.
\begin{ErrMsgs}
\item \errindex{Not a valid setoid theory}.\\
@@ -85,14 +84,13 @@ Finally to register a ring the syntax is:
same type.
\end{ErrMsgs}
-Currently, the hypothesis is made than no more than one ring structure
+Currently, only one setoid structure
may be declared for a given type.
This allows automatic detection of the theory used to achieve the
-replacement. On popular demand, we can change that and allow several
-ring structures on the same type.
+replacement.
-The table of theories of \texttt{Setoid} is compatible with the \Coq\
-sectioning mechanism. If you declare a Ring inside a section, the
+The table of setoid theories is compatible with the \Coq\
+sectioning mechanism. If you declare a setoid inside a section, the
declaration will be thrown away when closing the section.
And when you load a compiled file, all the \texttt{Add Setoid}
commands of this file that are not inside a section will be loaded.
@@ -105,35 +103,23 @@ commands of this file that are not inside a section will be loaded.
A morphism is nothing else than a function compatible with the
equivalence relation.
-In order to be able to replace a term by an equivalent under an
-application, the term being compatible must be a morphism. For example
-you want to be able to replace \verb+((3),(6))+ with \verb+((1),(2))+
-in \verb+(plus ((3),(6)) ((1),(2)))+ but not in
-\verb+(fst ((3),(6)))+. To achieve this goal each morphism has to be
-declared to the system, which will ask you to prove the compatibility
-lemma.
+You can only replace a term by an equivalent in position of argument
+of a morphism. That's why each morphism has to be
+declared to the system, which will ask you to prove the accurate
+compatibility lemma.
The syntax is the following :
\comindex{Add Morphism}
\begin{quotation}
- \texttt{Add Morphism} \textit{ f}
+ \texttt{Add Morphism} \textit{ f }:\textit{ ident}
\end{quotation}
\noindent where f is the name of a term which type is a non dependent
-product.
-
-\begin{Variants}
-\item \texttt{Add Morphism} \textit{ s t}
-\end{Variants}
-
-\noindent where \textit{s} is a new identifier which will denote the
-compatibility lemma and \textit{t} is a term which type is a non
-dependent product.
+product (the term you want to declare as a morphism) and
+\textit{ident} is a new identifier which will denote the
+compatibility lemma.
\begin{ErrMsgs}
-\item \errindex{The term \term \ is not a known name}\\
-That happens when the term you give was not a name. In this case, try
-the variant.
\item \errindex{The term \term \ is already declared as a morphism}
\item \errindex{The term \term \ is not a product}
\item \errindex{The term \term \ should not be a dependent product}
@@ -144,18 +130,30 @@ declared.
\asection{The tactic itself}
\tacindex{Setoid\_replace}
+\tacindex{Setoid\_rewrite}
-After having registered all the setoids and morphisms needed, you can
-use the tactic called \texttt{Setoid\_replace}. The synatx is
+After having registered all the setoids and morphisms you need, you can
+use the tactic called \texttt{Setoid\_replace}. The syntax is
\begin{quotation}
\texttt{Setoid\_replace} $ term_1$ with $term_2$
\end{quotation}
-The effect is similar to the one of Replace except that some subgoals
-may appear asking to prove equivalence of subterm of the given terms.
-\texttt{Trivial} or \texttt{Auto} should be sufficient to solve the
-easiest ones. Otherwise you may have to use \verb+Seq_refl+,
-\verb+Seq_sym+ or \verb+Seq_trans+ with the right arguments (for
-example \verb+(Seq_refl Prop iff Prop_S)+ is of type
-\verb+(x:Prop)x<->x+).
+The effect is similar to the one of \texttt{Replace}.
+
+You also have a tactic called \texttt{Setoid\_rewrite} which is the
+equivalent of \texttt{Rewrite} for setoids. The syntax is
+
+\begin{quotation}
+\texttt{Setoid\_rewrite} \term
+\end{quotation}
+
+\begin{Variants}
+ \item \texttt{Setoid\_rewrite ->} \term
+ \item \texttt{Setoid\_rewrite <-} \term
+\end{Variants}
+
+The arrow tells the systems in which direction the rewriting has to be
+done. Moreover, you can use \texttt{Rewrite} for setoid
+rewriting. In that case the system will check if the term you give is
+an equality or a setoid equivalence and do the appropriate work.