aboutsummaryrefslogtreecommitdiffhomepage
path: root/doc
diff options
context:
space:
mode:
Diffstat (limited to 'doc')
-rw-r--r--doc/RefMan-tac.tex19
-rw-r--r--doc/RefMan-tacex.tex29
2 files changed, 34 insertions, 14 deletions
diff --git a/doc/RefMan-tac.tex b/doc/RefMan-tac.tex
index 43c6f965b..565c94e6a 100644
--- a/doc/RefMan-tac.tex
+++ b/doc/RefMan-tac.tex
@@ -1337,8 +1337,9 @@ Qed.
\tacindex{functional induction}
\label{FunInduction}}
-The tactic \texttt{functional induction} performs case analysis
-and induction following the definition of a function.
+The \emph{experimental} tactic \texttt{functional induction}
+performs case analysis and induction following the definition of
+a (not mutually recursive) function.
\begin{coq_eval}
Reset Initial.
@@ -1355,11 +1356,17 @@ Qed.
\texttt{functional induction} is a shorthand for the more general
command \texttt{Functional Scheme} which builds induction
principles following the recursive structure of (possibly
-mutually recursive) functions.
+mutually recursive)
+functions. \SeeAlso{\ref{FunScheme-examples}} for the difference
+between using one or the other.
-\Rem \texttt{functional induction} does not work on polymorphic
-and dependently typed functions yet. It may also fail on
-functions built by certain tactics.
+\Rem \texttt{functional induction} may fail on functions built by
+tactics. In particular case analysis of a function are considered
+only if they are not inside an application.
+
+\Rem Arguments of the function must be given, including
+implicits. If the function is recursive, arguments must be
+variables, otherwise they may be any term.
\SeeAlso{\ref{FunScheme},\ref{FunScheme-examples}}
diff --git a/doc/RefMan-tacex.tex b/doc/RefMan-tacex.tex
index a26a18267..98ae9a7db 100644
--- a/doc/RefMan-tacex.tex
+++ b/doc/RefMan-tacex.tex
@@ -352,14 +352,13 @@ Qed.
\end{coq_example*}
\paragraph{remark:} \texttt{functional induction} makes no use of
-a induction principle, so be warned that each time it is used, a
-term mimicking the structure of \texttt{div2} (roughly the size
-of {\tt div2\_ind}) is built. Using \texttt{Functional Scheme} is
-generally faster and less memory consuming. On the other hand
-\texttt{functional induction} performs some extra simplifications
-that \texttt{Functional Scheme} does not, and as it is a tactic
-it can be used in tactic definitions.
-
+an induction principle, so be warned that each time it is
+applied, a term mimicking the structure of \texttt{div2} (roughly
+the size of {\tt div2\_ind}) is built. Using \texttt{Functional
+ Scheme} is generally faster and less memory consuming. On the
+other hand \texttt{functional induction} performs some extra
+simplifications that \texttt{Functional Scheme} does not, and as
+it is a tactic it can be used in tactic definitions.
\example{Induction scheme for \texttt{tree\_size}}
@@ -808,6 +807,8 @@ is undecidable in general case, don't expect miracles from it!
\SeeAlso the \texttt{ring} tactic (Chapter~\ref{ring})
+
+
\section{Using the tactical language}
\subsection{About the cardinality of the set of natural numbers}
@@ -847,6 +848,11 @@ of non-linear matching).
\subsection{Permutation on closed lists}
+Another more complex example is the problem of permutation on closed lists. The
+aim is to show that a closed list is a permutation of another one.
+
+First, we define the permutation predicate as shown in table~\ref{permutpred}.
+
\begin{figure}
\begin{centerframe}
\begin{coq_example*}
@@ -932,6 +938,7 @@ With {\tt PermutProve}, we can now prove lemmas as
follows:
%\begin{figure}
%\begin{centerframe}
+
\begin{coq_example*}
Lemma permut_ex1 :
permut nat (1 :: 2 :: 3 :: nil) (3 :: 2 :: 1 :: nil).
@@ -1051,6 +1058,12 @@ Proof. TautoProp. Qed.
\subsection{Deciding type isomorphisms}
+A more tricky problem is to decide equalities between types and modulo
+isomorphisms. Here, we choose to use the isomorphisms of the simply typed
+$\lb{}$-calculus with Cartesian product and $unit$ type (see, for example,
+\cite{RC95}). The axioms of this $\lb{}$-calculus are given by
+table~\ref{isosax}.
+
\begin{figure}
\begin{centerframe}
\begin{coq_eval}