doc-src/IsarAdvanced/Functions/functions.tex
author wenzelm
Mon, 05 May 2008 15:27:13 +0200
changeset 26784 eee21d6d0a6b
parent 25092 1d7616d74095
child 26911 871cc7f11034
permissions -rw-r--r--
removed isasymIN -- already defined in isar.sty;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
     1
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
     2
%% $Id$
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
     3
25092
1d7616d74095 removed funny formatting
krauss
parents: 23805
diff changeset
     4
\documentclass[a4paper,fleqn]{article}
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
     5
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
     6
\usepackage{latexsym,graphicx}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
     7
\usepackage[refpage]{nomencl}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
     8
\usepackage{../../iman,../../extra,../../isar,../../proof}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
     9
\usepackage{Thy/document/isabelle,Thy/document/isabellesym}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    10
\usepackage{style}
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    11
\usepackage{mathpartir}
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    12
\usepackage{amsthm}
25092
1d7616d74095 removed funny formatting
krauss
parents: 23805
diff changeset
    13
\usepackage{Thy/document/pdfsetup}
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    14
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    15
\newcommand{\cmd}[1]{\isacommand{#1}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    16
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    17
\newcommand{\isasymINFIX}{\cmd{infix}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    18
\newcommand{\isasymLOCALE}{\cmd{locale}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    19
\newcommand{\isasymINCLUDES}{\cmd{includes}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    20
\newcommand{\isasymDATATYPE}{\cmd{datatype}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    21
\newcommand{\isasymAXCLASS}{\cmd{axclass}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    22
\newcommand{\isasymFIXES}{\cmd{fixes}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    23
\newcommand{\isasymASSUMES}{\cmd{assumes}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    24
\newcommand{\isasymDEFINES}{\cmd{defines}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    25
\newcommand{\isasymNOTES}{\cmd{notes}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    26
\newcommand{\isasymSHOWS}{\cmd{shows}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    27
\newcommand{\isasymCLASS}{\cmd{class}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    28
\newcommand{\isasymINSTANCE}{\cmd{instance}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    29
\newcommand{\isasymLEMMA}{\cmd{lemma}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    30
\newcommand{\isasymPROOF}{\cmd{proof}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    31
\newcommand{\isasymQED}{\cmd{qed}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    32
\newcommand{\isasymFIX}{\cmd{fix}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    33
\newcommand{\isasymASSUME}{\cmd{assume}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    34
\newcommand{\isasymSHOW}{\cmd{show}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    35
\newcommand{\isasymNOTE}{\cmd{note}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    36
\newcommand{\isasymCODEGEN}{\cmd{code\_gen}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    37
\newcommand{\isasymPRINTCODETHMS}{\cmd{print\_codethms}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    38
\newcommand{\isasymFUN}{\cmd{fun}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    39
\newcommand{\isasymFUNCTION}{\cmd{function}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    40
\newcommand{\isasymPRIMREC}{\cmd{primrec}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    41
\newcommand{\isasymRECDEF}{\cmd{recdef}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    42
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    43
\newcommand{\qt}[1]{``#1''}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    44
\newcommand{\qtt}[1]{"{}{#1}"{}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    45
\newcommand{\qn}[1]{\emph{#1}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    46
\newcommand{\strong}[1]{{\bfseries #1}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    47
\newcommand{\fixme}[1][!]{\strong{FIXME: #1}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    48
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    49
\newtheorem{exercise}{Exercise}{\bf}{\itshape}
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    50
%\newtheorem*{thmstar}{Theorem}{\bf}{\itshape}
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    51
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    52
\hyphenation{Isabelle}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    53
\hyphenation{Isar}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    54
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    55
\isadroptag{theory}
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    56
\title{Defining Recursive Functions in Isabelle/HOL}
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    57
\author{Alexander Krauss}
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    58
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    59
\isabellestyle{tt}
23188
595a0e24bd8e updated
krauss
parents: 23003
diff changeset
    60
\renewcommand{\isastyletxt}{\isastyletext}% use same formatting for txt and text
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    61
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    62
\begin{document}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    63
23805
953eb3c5f793 updated
krauss
parents: 23188
diff changeset
    64
\date{\ \\}
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    65
\maketitle
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    66
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    67
\begin{abstract}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    68
  This tutorial describes the use of the new \emph{function} package,
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    69
	which provides general recursive function definitions for Isabelle/HOL.
23188
595a0e24bd8e updated
krauss
parents: 23003
diff changeset
    70
	We start with very simple examples and then gradually move on to more
595a0e24bd8e updated
krauss
parents: 23003
diff changeset
    71
	advanced topics such as manual termination proofs, nested recursion,
23805
953eb3c5f793 updated
krauss
parents: 23188
diff changeset
    72
	partiality, tail recursion and congruence rules.
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    73
\end{abstract}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    74
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    75
%\thispagestyle{empty}\clearpage
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    76
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    77
%\pagenumbering{roman}
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    78
%\clearfirst
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    79
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    80
\input{intro.tex}
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    81
\input{Thy/document/Functions.tex}
23805
953eb3c5f793 updated
krauss
parents: 23188
diff changeset
    82
%\input{conclusion.tex}
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    83
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    84
\begingroup
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    85
%\tocentry{\bibname}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    86
\bibliographystyle{plain} \small\raggedright\frenchspacing
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    87
\bibliography{../../manual}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    88
\endgroup
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    89
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    90
\end{document}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    91
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    92
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    93
%%% Local Variables: 
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    94
%%% mode: latex
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    95
%%% TeX-master: t
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    96
%%% End: