doc-src/IsarRef/isar-ref.tex
author wenzelm
Sun, 15 Oct 2000 19:50:35 +0200
changeset 10220 2a726de6e124
parent 10208 2b284ef75049
child 10240 9ac0fe356ea7
permissions -rw-r--r--
proper symbol markup with \isamath, \isatext; support sub/super scripts:
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
7046
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
     1
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
     2
%% $Id$
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
     3
7836
7a9270282fd3 a4paper;
wenzelm
parents: 7532
diff changeset
     4
\documentclass[12pt,a4paper,fleqn]{report}
9695
ec7d7f877712 proper setup of iman.sty/extra.sty/ttbox.sty;
wenzelm
parents: 9658
diff changeset
     5
\usepackage{latexsym,graphicx,../iman,../extra,../ttbox,../proof,../rail,../railsetup,../isar,../pdfsetup}
7046
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
     6
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
     7
\title{\includegraphics[scale=0.5]{isabelle_isar} \\[4ex] The Isabelle/Isar Reference Manual}
7050
c70d3402fef5 checkpoint;
wenzelm
parents: 7046
diff changeset
     8
\author{\emph{Markus Wenzel} \\ TU M\"unchen}
7046
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
     9
7050
c70d3402fef5 checkpoint;
wenzelm
parents: 7046
diff changeset
    10
\makeindex
c70d3402fef5 checkpoint;
wenzelm
parents: 7046
diff changeset
    11
9658
97d6d0a72d35 tuned \isastyle;
wenzelm
parents: 9600
diff changeset
    12
\newcommand{\isastyle}{\small\tt\slshape}
97d6d0a72d35 tuned \isastyle;
wenzelm
parents: 9600
diff changeset
    13
\newcommand{\isa}[1]{\emph{\isastyle #1}}
10208
2b284ef75049 tuned syms;
wenzelm
parents: 10160
diff changeset
    14
\newcommand{\isamath}[1]{\emph{$#1$}}
2b284ef75049 tuned syms;
wenzelm
parents: 10160
diff changeset
    15
\newcommand{\isasymColon}{\isamath{\mathrel{::}}}
2b284ef75049 tuned syms;
wenzelm
parents: 10160
diff changeset
    16
\newcommand{\isasymRightarrow}{\isamath{\Rightarrow}}
9204
e865dda0313e tuned rail setup;
wenzelm
parents: 8896
diff changeset
    17
e865dda0313e tuned rail setup;
wenzelm
parents: 8896
diff changeset
    18
\railterm{percent,ppercent,underscore,lbrace,rbrace,atsign}
7167
wenzelm
parents: 7135
diff changeset
    19
\railterm{ident,longident,symident,var,textvar,typefree,typevar,nat,string,verbatim,keyword}
8596
wenzelm
parents: 8594
diff changeset
    20
\railterm{name,nameref,text,type,term,prop,atom}
7134
320b412e5800 more stuff;
wenzelm
parents: 7050
diff changeset
    21
8594
d2e2a3df6871 rail token vs. terminal;
wenzelm
parents: 8547
diff changeset
    22
\railalias{ident}{\railtoken{ident}}
d2e2a3df6871 rail token vs. terminal;
wenzelm
parents: 8547
diff changeset
    23
\railalias{longident}{\railtoken{longident}}
d2e2a3df6871 rail token vs. terminal;
wenzelm
parents: 8547
diff changeset
    24
\railalias{symident}{\railtoken{symident}}
d2e2a3df6871 rail token vs. terminal;
wenzelm
parents: 8547
diff changeset
    25
\railalias{var}{\railtoken{var}}
d2e2a3df6871 rail token vs. terminal;
wenzelm
parents: 8547
diff changeset
    26
\railalias{textvar}{\railtoken{textvar}}
d2e2a3df6871 rail token vs. terminal;
wenzelm
parents: 8547
diff changeset
    27
\railalias{typefree}{\railtoken{typefree}}
d2e2a3df6871 rail token vs. terminal;
wenzelm
parents: 8547
diff changeset
    28
\railalias{typevar}{\railtoken{typevar}}
d2e2a3df6871 rail token vs. terminal;
wenzelm
parents: 8547
diff changeset
    29
\railalias{nat}{\railtoken{nat}}
d2e2a3df6871 rail token vs. terminal;
wenzelm
parents: 8547
diff changeset
    30
\railalias{string}{\railtoken{string}}
d2e2a3df6871 rail token vs. terminal;
wenzelm
parents: 8547
diff changeset
    31
\railalias{verbatim}{\railtoken{verbatim}}
d2e2a3df6871 rail token vs. terminal;
wenzelm
parents: 8547
diff changeset
    32
\railalias{keyword}{\railtoken{keyword}}
d2e2a3df6871 rail token vs. terminal;
wenzelm
parents: 8547
diff changeset
    33
7134
320b412e5800 more stuff;
wenzelm
parents: 7050
diff changeset
    34
\railalias{name}{\railqtoken{name}}
320b412e5800 more stuff;
wenzelm
parents: 7050
diff changeset
    35
\railalias{nameref}{\railqtoken{nameref}}
320b412e5800 more stuff;
wenzelm
parents: 7050
diff changeset
    36
\railalias{text}{\railqtoken{text}}
320b412e5800 more stuff;
wenzelm
parents: 7050
diff changeset
    37
\railalias{type}{\railqtoken{type}}
320b412e5800 more stuff;
wenzelm
parents: 7050
diff changeset
    38
\railalias{term}{\railqtoken{term}}
320b412e5800 more stuff;
wenzelm
parents: 7050
diff changeset
    39
\railalias{prop}{\railqtoken{prop}}
320b412e5800 more stuff;
wenzelm
parents: 7050
diff changeset
    40
\railalias{atom}{\railqtoken{atom}}
320b412e5800 more stuff;
wenzelm
parents: 7050
diff changeset
    41
7895
7c492d8bc8e3 updated;
wenzelm
parents: 7836
diff changeset
    42
\newcommand{\drv}{\mathrel{\vdash}}
7c492d8bc8e3 updated;
wenzelm
parents: 7836
diff changeset
    43
\newcommand{\edrv}{\mathop{\drv}\nolimits}
7974
34245feb6e82 improved;
wenzelm
parents: 7895
diff changeset
    44
\newcommand{\Or}{\mathrel{\;|\;}}
7895
7c492d8bc8e3 updated;
wenzelm
parents: 7836
diff changeset
    45
7046
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    46
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    47
\setcounter{secnumdepth}{2} \setcounter{tocdepth}{2}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    48
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    49
\pagestyle{headings}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    50
\sloppy
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    51
\binperiod     %%%treat . like a binary operator
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    52
7134
320b412e5800 more stuff;
wenzelm
parents: 7050
diff changeset
    53
\renewcommand{\phi}{\varphi}
7046
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    54
8514
wenzelm
parents: 8509
diff changeset
    55
%\includeonly{generic,refcard}
7895
7c492d8bc8e3 updated;
wenzelm
parents: 7836
diff changeset
    56
7046
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    57
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    58
\begin{document}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    59
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    60
\underscoreoff
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    61
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    62
\maketitle 
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    63
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    64
\begin{abstract}
7167
wenzelm
parents: 7135
diff changeset
    65
  \emph{Intelligible semi-automated reasoning} (\emph{Isar}) is a generic
wenzelm
parents: 7135
diff changeset
    66
  approach to readable formal proof documents.  It sets out to bridge the
wenzelm
parents: 7135
diff changeset
    67
  semantic gap between any internal notions of proof based on primitive
wenzelm
parents: 7135
diff changeset
    68
  inferences and tactics, and an appropriate level of abstraction for
wenzelm
parents: 7135
diff changeset
    69
  user-level work.  The Isar formal proof language has been designed to
wenzelm
parents: 7135
diff changeset
    70
  satisfy quite contradictory requirements, being both ``declarative'' and
wenzelm
parents: 7135
diff changeset
    71
  immediately ``executable'', by virtue of the \emph{Isar/VM} interpreter.
wenzelm
parents: 7135
diff changeset
    72
  
10160
wenzelm
parents: 9695
diff changeset
    73
  The Isabelle/Isar system provides an interpreter for the Isar formal proof
wenzelm
parents: 9695
diff changeset
    74
  language.  The input may consist either of proper document constructors, or
wenzelm
parents: 9695
diff changeset
    75
  improper auxiliary commands (for diagnostics, exploration etc.).  Proof
wenzelm
parents: 9695
diff changeset
    76
  texts consisting of proper elements only admit a purely static reading, thus
wenzelm
parents: 9695
diff changeset
    77
  being intelligible later without requiring dynamic replay that is so typical
wenzelm
parents: 9695
diff changeset
    78
  for traditional proof scripts.  Any of the Isabelle/Isar commands may be
wenzelm
parents: 9695
diff changeset
    79
  executed in single-steps, so basically the interpreter has a proof text
wenzelm
parents: 9695
diff changeset
    80
  debugger already built-in.
7167
wenzelm
parents: 7135
diff changeset
    81
  
8509
wenzelm
parents: 7988
diff changeset
    82
  Employing the Isar instantiation of \emph{Proof~General}, a generic Emacs
wenzelm
parents: 7988
diff changeset
    83
  interface for interactive proof assistants, we arrive at a reasonable
wenzelm
parents: 7988
diff changeset
    84
  environment for \emph{live document editing}.  Thus proof texts may be
8547
wenzelm
parents: 8514
diff changeset
    85
  developed incrementally by issuing proof commands, including forward and
wenzelm
parents: 8514
diff changeset
    86
  backward tracing of partial documents; intermediate states may be inspected
wenzelm
parents: 8514
diff changeset
    87
  by diagnostic commands.
7167
wenzelm
parents: 7135
diff changeset
    88
  
7335
abba35b98892 draft release;
wenzelm
parents: 7297
diff changeset
    89
  The Isar subsystem is tightly integrated into the Isabelle/Pure meta-logic
abba35b98892 draft release;
wenzelm
parents: 7297
diff changeset
    90
  implementation.  Theories, theorems, proof procedures etc.\ may be used
7895
7c492d8bc8e3 updated;
wenzelm
parents: 7836
diff changeset
    91
  interchangeably between classic Isabelle proof scripts and Isabelle/Isar
10160
wenzelm
parents: 9695
diff changeset
    92
  documents.  Even more, Isar provides a set of emulation commands and methods
wenzelm
parents: 9695
diff changeset
    93
  for simulating traditional tactic scripts within new-style theory documents.
wenzelm
parents: 9695
diff changeset
    94
  
wenzelm
parents: 9695
diff changeset
    95
  The Isar framework is as generic as Isabelle, able to support a wide range
wenzelm
parents: 9695
diff changeset
    96
  of object-logics.  Currently, the end-user working environment is most
wenzelm
parents: 9695
diff changeset
    97
  complete for Isabelle/HOL.
7046
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    98
\end{abstract}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
    99
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   100
\pagenumbering{roman} \tableofcontents \clearfirst
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   101
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   102
%FIXME
9600
a585662e6490 some more refs;
wenzelm
parents: 9204
diff changeset
   103
\nocite{Aspinall:2000:eProof}
a585662e6490 some more refs;
wenzelm
parents: 9204
diff changeset
   104
\nocite{Bauer-Wenzel:2000:HB}
a585662e6490 some more refs;
wenzelm
parents: 9204
diff changeset
   105
\nocite{Harrison:1996:MizarHOL}
a585662e6490 some more refs;
wenzelm
parents: 9204
diff changeset
   106
\nocite{Muzalewski:Mizar}
7046
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   107
\nocite{Rudnicki:1992:MizarOverview}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   108
\nocite{Rudnicki:1992:MizarOverview}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   109
\nocite{Syme:1997:DECLARE}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   110
\nocite{Syme:1998:thesis}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   111
\nocite{Syme:1999:TPHOL}
9600
a585662e6490 some more refs;
wenzelm
parents: 9204
diff changeset
   112
\nocite{Trybulec:1993:MizarFeatures}
a585662e6490 some more refs;
wenzelm
parents: 9204
diff changeset
   113
\nocite{Wiedijk:1999:Mizar}
a585662e6490 some more refs;
wenzelm
parents: 9204
diff changeset
   114
\nocite{Wiedijk:2000:MV}
7988
wenzelm
parents: 7981
diff changeset
   115
\nocite{Zammit:1999:TPHOL}
7046
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   116
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   117
\include{intro}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   118
\include{basics}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   119
\include{syntax}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   120
\include{pure}
7135
wenzelm
parents: 7134
diff changeset
   121
\include{generic}
7046
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   122
\include{hol}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   123
7895
7c492d8bc8e3 updated;
wenzelm
parents: 7836
diff changeset
   124
\appendix
7c492d8bc8e3 updated;
wenzelm
parents: 7836
diff changeset
   125
\include{refcard}
9600
a585662e6490 some more refs;
wenzelm
parents: 9204
diff changeset
   126
\include{conversion}
7895
7c492d8bc8e3 updated;
wenzelm
parents: 7836
diff changeset
   127
7046
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   128
\begingroup
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   129
  \bibliographystyle{plain} \small\raggedright\frenchspacing
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   130
  \bibliography{../manual}
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   131
\endgroup
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   132
8828
5be2d1745c61 improved indexing;
wenzelm
parents: 8596
diff changeset
   133
\printindex
7046
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   134
9f755ff43cff skeleton only;
wenzelm
parents:
diff changeset
   135
\end{document}