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