doc-src/IsarAdvanced/Functions/functions.tex
author krauss
Fri, 19 Oct 2007 10:05:21 +0200
changeset 25092 1d7616d74095
parent 23805 953eb3c5f793
child 26784 eee21d6d0a6b
permissions -rw-r--r--
removed funny formatting
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{\isasymIN}{\cmd{in}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    37
\newcommand{\isasymCODEGEN}{\cmd{code\_gen}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    38
\newcommand{\isasymPRINTCODETHMS}{\cmd{print\_codethms}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    39
\newcommand{\isasymFUN}{\cmd{fun}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    40
\newcommand{\isasymFUNCTION}{\cmd{function}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    41
\newcommand{\isasymPRIMREC}{\cmd{primrec}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    42
\newcommand{\isasymRECDEF}{\cmd{recdef}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    43
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    44
\newcommand{\qt}[1]{``#1''}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    45
\newcommand{\qtt}[1]{"{}{#1}"{}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    46
\newcommand{\qn}[1]{\emph{#1}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    47
\newcommand{\strong}[1]{{\bfseries #1}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    48
\newcommand{\fixme}[1][!]{\strong{FIXME: #1}}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    49
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    50
\newtheorem{exercise}{Exercise}{\bf}{\itshape}
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    51
%\newtheorem*{thmstar}{Theorem}{\bf}{\itshape}
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    52
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    53
\hyphenation{Isabelle}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    54
\hyphenation{Isar}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    55
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    56
\isadroptag{theory}
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    57
\title{Defining Recursive Functions in Isabelle/HOL}
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    58
\author{Alexander Krauss}
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    59
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    60
\isabellestyle{tt}
23188
595a0e24bd8e updated
krauss
parents: 23003
diff changeset
    61
\renewcommand{\isastyletxt}{\isastyletext}% use same formatting for txt and text
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    62
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    63
\begin{document}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    64
23805
953eb3c5f793 updated
krauss
parents: 23188
diff changeset
    65
\date{\ \\}
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    66
\maketitle
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    67
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    68
\begin{abstract}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    69
  This tutorial describes the use of the new \emph{function} package,
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    70
	which provides general recursive function definitions for Isabelle/HOL.
23188
595a0e24bd8e updated
krauss
parents: 23003
diff changeset
    71
	We start with very simple examples and then gradually move on to more
595a0e24bd8e updated
krauss
parents: 23003
diff changeset
    72
	advanced topics such as manual termination proofs, nested recursion,
23805
953eb3c5f793 updated
krauss
parents: 23188
diff changeset
    73
	partiality, tail recursion and congruence rules.
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    74
\end{abstract}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    75
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    76
%\thispagestyle{empty}\clearpage
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    77
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    78
%\pagenumbering{roman}
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    79
%\clearfirst
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    80
23003
4b0bf04a4d68 updated
krauss
parents: 21212
diff changeset
    81
\input{intro.tex}
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    82
\input{Thy/document/Functions.tex}
23805
953eb3c5f793 updated
krauss
parents: 23188
diff changeset
    83
%\input{conclusion.tex}
21212
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    84
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    85
\begingroup
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    86
%\tocentry{\bibname}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    87
\bibliographystyle{plain} \small\raggedright\frenchspacing
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    88
\bibliography{../../manual}
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    89
\endgroup
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    90
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    91
\end{document}
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
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    94
%%% Local Variables: 
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    95
%%% mode: latex
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    96
%%% TeX-master: t
547224bf9348 Added a (stub of a) function tutorial
krauss
parents:
diff changeset
    97
%%% End: