# HG changeset patch # User paulson # Date 1427810466 -3600 # Node ID 30519ff3dffb45ebe02864f8f12409c8510e904a # Parent 44b3f4fa33ca2449e2df90966022089ddd0a4ddb# Parent 99d9304daeb44cdc0076075ec89be61e16cd9da8 Merge diff -r 44b3f4fa33ca -r 30519ff3dffb src/Doc/Datatypes/Datatypes.thy --- a/src/Doc/Datatypes/Datatypes.thy Tue Mar 31 15:00:03 2015 +0100 +++ b/src/Doc/Datatypes/Datatypes.thy Tue Mar 31 15:01:06 2015 +0100 @@ -99,16 +99,18 @@ \item Section \ref{sec:defining-datatypes}, ``Defining Datatypes,'' describes how to specify datatypes using the @{command datatype} command. -\item Section \ref{sec:defining-recursive-functions}, ``Defining Recursive -Functions,'' describes how to specify recursive functions using -@{command primrec}. +\item Section \ref{sec:defining-primitively-recursive-functions}, ``Defining +Primitively Recursive Functions,'' describes how to specify recursive functions +using @{command primrec}. (A separate tutorial @{cite "isabelle-function"} +describes the more general \keyw{fun} and \keyw{function} commands.) \item Section \ref{sec:defining-codatatypes}, ``Defining Codatatypes,'' describes how to specify codatatypes using the @{command codatatype} command. -\item Section \ref{sec:defining-corecursive-functions}, ``Defining Corecursive -Functions,'' describes how to specify corecursive functions using the -@{command primcorec} and @{command primcorecursive} commands. +\item Section \ref{sec:defining-primitively-corecursive-functions}, +``Defining Primitively Corecursive Functions,'' describes how to specify +corecursive functions using the @{command primcorec} and +@{command primcorecursive} commands. \item Section \ref{sec:registering-bounded-natural-functors}, ``Registering Bounded Natural Functors,'' explains how to use the @{command bnf} command @@ -1151,17 +1153,15 @@ *} -section {* Defining Recursive Functions - \label{sec:defining-recursive-functions} *} +section {* Defining Primitively Recursive Functions + \label{sec:defining-primitively-recursive-functions} *} text {* Recursive functions over datatypes can be specified using the @{command primrec} command, which supports primitive recursion, or using the more general -\keyw{fun} and \keyw{function} commands. In this tutorial, the focus is on -@{command primrec}; the other two commands are described in a separate -tutorial @{cite "isabelle-function"}. - -%%% TODO: partial_function +\keyw{fun}, \keyw{function}, and \keyw{partial_function} commands. In this +tutorial, the focus is on @{command primrec}; \keyw{fun} and \keyw{function} are +described in a separate tutorial @{cite "isabelle-function"}. *} @@ -1947,8 +1947,8 @@ *} -section {* Defining Corecursive Functions - \label{sec:defining-corecursive-functions} *} +section {* Defining Primitively Corecursive Functions + \label{sec:defining-primitively-corecursive-functions} *} text {* Corecursive functions can be specified using the @{command primcorec} and @@ -2085,7 +2085,11 @@ pseudorandom seed (@{text n}): *} - primcorec(*<*) (in early)(*>*) +(*<*) + context early + begin +(*>*) + primcorec random_process :: "'a stream \ (int \ int) \ int \ 'a process" where "random_process s f n = @@ -2098,6 +2102,9 @@ else Choice (random_process (every_snd s) (f \ f) (f n)) (random_process (every_snd (stl s)) (f \ f) (f (f n))))" +(*<*) + end +(*>*) text {* \noindent @@ -2300,7 +2307,7 @@ the @{const LCons} case. The condition for @{const LCons} is left implicit, as the negation of that for @{const LNil}. -For this example, the constructor view is slighlty more involved than the +For this example, the constructor view is slightly more involved than the code equation. Recall the code view version presented in Section~\ref{sssec:primcorec-simple-corecursion}. % TODO: \[{thm code_view.lappend.code}\]