doc-src/TutorialI/Types/document/Numbers.tex
author wenzelm
Mon, 05 Feb 2001 20:44:51 +0100
changeset 11073 e45b136716f5
parent 10950 aa788fcb75a5
child 11174 96a533d300a6
permissions -rw-r--r--
polyml multiplatform setup;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
     1
%
49109fe3e919 auto generated
paulson
parents:
diff changeset
     2
\begin{isabellebody}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
     3
\def\isabellecontext{Numbers}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
     4
\isanewline
10776
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
     5
\isacommand{theory}\ Numbers\ {\isacharequal}\ Real{\isacharcolon}\isanewline
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
     6
\isanewline
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
     7
\isacommand{ML}\ {\isachardoublequote}Pretty{\isachardot}setmargin\ {\isadigit{6}}{\isadigit{4}}{\isachardoublequote}\isanewline
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
     8
\isacommand{ML}\ {\isachardoublequote}IsarOutput{\isachardot}indent\ {\isacharcolon}{\isacharequal}\ {\isadigit{0}}{\isachardoublequote}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
     9
\begin{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    10
numeric literals; default simprules; can re-orient%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    11
\end{isamarkuptext}%
10878
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    12
\isacommand{lemma}\ {\isachardoublequote}{\isacharhash}{\isadigit{2}}\ {\isacharasterisk}\ m\ {\isacharequal}\ m\ {\isacharplus}\ m{\isachardoublequote}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    13
\begin{isamarkuptxt}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    14
\begin{isabelle}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    15
\ {\isadigit{1}}{\isachardot}\ {\isacharparenleft}{\isacharhash}{\isadigit{2}}{\isasymColon}{\isacharprime}a{\isacharparenright}\ {\isacharasterisk}\ m\ {\isacharequal}\ m\ {\isacharplus}\ m%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    16
\end{isabelle}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    17
\end{isamarkuptxt}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    18
\isacommand{oops}\isanewline
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    19
\isanewline
10878
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    20
\isacommand{consts}\ h\ {\isacharcolon}{\isacharcolon}\ {\isachardoublequote}nat\ {\isasymRightarrow}\ nat{\isachardoublequote}\isanewline
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    21
\isacommand{recdef}\ h\ {\isachardoublequote}{\isacharbraceleft}{\isacharbraceright}{\isachardoublequote}\isanewline
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    22
{\isachardoublequote}h\ i\ {\isacharequal}\ {\isacharparenleft}if\ i\ {\isacharequal}\ {\isacharhash}{\isadigit{3}}\ then\ {\isacharhash}{\isadigit{2}}\ else\ i{\isacharparenright}{\isachardoublequote}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    23
\begin{isamarkuptext}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    24
\isa{h\ {\isacharhash}{\isadigit{3}}\ {\isacharequal}\ {\isacharhash}{\isadigit{2}}}
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    25
\isa{h\ i\ {\isacharequal}\ i}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    26
\end{isamarkuptext}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    27
%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    28
\begin{isamarkuptext}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    29
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
    30
{\isacharhash}{\isadigit{0}}\ {\isacharequal}\ {\isadigit{0}}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    31
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    32
\rulename{numeral_0_eq_0}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    33
49109fe3e919 auto generated
paulson
parents:
diff changeset
    34
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
    35
{\isacharhash}{\isadigit{1}}\ {\isacharequal}\ {\isadigit{1}}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    36
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    37
\rulename{numeral_1_eq_1}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    38
49109fe3e919 auto generated
paulson
parents:
diff changeset
    39
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
    40
{\isacharhash}{\isadigit{2}}\ {\isacharplus}\ n\ {\isacharequal}\ Suc\ {\isacharparenleft}Suc\ n{\isacharparenright}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    41
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    42
\rulename{add_2_eq_Suc}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    43
49109fe3e919 auto generated
paulson
parents:
diff changeset
    44
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
    45
n\ {\isacharplus}\ {\isacharhash}{\isadigit{2}}\ {\isacharequal}\ Suc\ {\isacharparenleft}Suc\ n{\isacharparenright}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    46
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    47
\rulename{add_2_eq_Suc'}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    48
49109fe3e919 auto generated
paulson
parents:
diff changeset
    49
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
    50
m\ {\isacharplus}\ n\ {\isacharplus}\ k\ {\isacharequal}\ m\ {\isacharplus}\ {\isacharparenleft}n\ {\isacharplus}\ k{\isacharparenright}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    51
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    52
\rulename{add_assoc}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    53
49109fe3e919 auto generated
paulson
parents:
diff changeset
    54
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
    55
m\ {\isacharplus}\ n\ {\isacharequal}\ n\ {\isacharplus}\ m%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    56
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    57
\rulename{add_commute}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    58
49109fe3e919 auto generated
paulson
parents:
diff changeset
    59
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
    60
x\ {\isacharplus}\ {\isacharparenleft}y\ {\isacharplus}\ z{\isacharparenright}\ {\isacharequal}\ y\ {\isacharplus}\ {\isacharparenleft}x\ {\isacharplus}\ z{\isacharparenright}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    61
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    62
\rulename{add_left_commute}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    63
49109fe3e919 auto generated
paulson
parents:
diff changeset
    64
these form add_ac; similarly there is mult_ac%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    65
\end{isamarkuptext}%
10878
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    66
\isacommand{lemma}\ {\isachardoublequote}Suc{\isacharparenleft}i\ {\isacharplus}\ j{\isacharasterisk}l{\isacharasterisk}k\ {\isacharplus}\ m{\isacharasterisk}n{\isacharparenright}\ {\isacharequal}\ f\ {\isacharparenleft}n{\isacharasterisk}m\ {\isacharplus}\ i\ {\isacharplus}\ k{\isacharasterisk}j{\isacharasterisk}l{\isacharparenright}{\isachardoublequote}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    67
\begin{isamarkuptxt}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    68
\begin{isabelle}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    69
\ {\isadigit{1}}{\isachardot}\ Suc\ {\isacharparenleft}i\ {\isacharplus}\ j\ {\isacharasterisk}\ l\ {\isacharasterisk}\ k\ {\isacharplus}\ m\ {\isacharasterisk}\ n{\isacharparenright}\ {\isacharequal}\ f\ {\isacharparenleft}n\ {\isacharasterisk}\ m\ {\isacharplus}\ i\ {\isacharplus}\ k\ {\isacharasterisk}\ j\ {\isacharasterisk}\ l{\isacharparenright}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    70
\end{isabelle}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    71
\end{isamarkuptxt}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    72
\isacommand{apply}\ {\isacharparenleft}simp\ add{\isacharcolon}\ add{\isacharunderscore}ac\ mult{\isacharunderscore}ac{\isacharparenright}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    73
\begin{isamarkuptxt}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    74
\begin{isabelle}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    75
\ {\isadigit{1}}{\isachardot}\ Suc\ {\isacharparenleft}i\ {\isacharplus}\ {\isacharparenleft}m\ {\isacharasterisk}\ n\ {\isacharplus}\ j\ {\isacharasterisk}\ {\isacharparenleft}k\ {\isacharasterisk}\ l{\isacharparenright}{\isacharparenright}{\isacharparenright}\ {\isacharequal}\isanewline
10950
aa788fcb75a5 updated;
wenzelm
parents: 10878
diff changeset
    76
\isaindent{\ {\isadigit{1}}{\isachardot}\ }f\ {\isacharparenleft}i\ {\isacharplus}\ {\isacharparenleft}m\ {\isacharasterisk}\ n\ {\isacharplus}\ j\ {\isacharasterisk}\ {\isacharparenleft}k\ {\isacharasterisk}\ l{\isacharparenright}{\isacharparenright}{\isacharparenright}%
10878
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    77
\end{isabelle}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    78
\end{isamarkuptxt}%
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
    79
\isacommand{oops}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    80
\begin{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    81
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
    82
{\isasymlbrakk}i\ {\isasymle}\ j{\isacharsemicolon}\ k\ {\isasymle}\ l{\isasymrbrakk}\ {\isasymLongrightarrow}\ i\ {\isacharasterisk}\ k\ {\isasymle}\ j\ {\isacharasterisk}\ l%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    83
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    84
\rulename{mult_le_mono}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    85
49109fe3e919 auto generated
paulson
parents:
diff changeset
    86
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
    87
{\isasymlbrakk}i\ {\isacharless}\ j{\isacharsemicolon}\ {\isadigit{0}}\ {\isacharless}\ k{\isasymrbrakk}\ {\isasymLongrightarrow}\ i\ {\isacharasterisk}\ k\ {\isacharless}\ j\ {\isacharasterisk}\ k%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    88
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    89
\rulename{mult_less_mono1}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    90
49109fe3e919 auto generated
paulson
parents:
diff changeset
    91
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
    92
m\ {\isasymle}\ n\ {\isasymLongrightarrow}\ m\ div\ k\ {\isasymle}\ n\ div\ k%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    93
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    94
\rulename{div_le_mono}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    95
49109fe3e919 auto generated
paulson
parents:
diff changeset
    96
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
    97
{\isacharparenleft}m\ {\isacharplus}\ n{\isacharparenright}\ {\isacharasterisk}\ k\ {\isacharequal}\ m\ {\isacharasterisk}\ k\ {\isacharplus}\ n\ {\isacharasterisk}\ k%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
    98
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    99
\rulename{add_mult_distrib}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   100
49109fe3e919 auto generated
paulson
parents:
diff changeset
   101
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   102
{\isacharparenleft}m\ {\isacharminus}\ n{\isacharparenright}\ {\isacharasterisk}\ k\ {\isacharequal}\ m\ {\isacharasterisk}\ k\ {\isacharminus}\ n\ {\isacharasterisk}\ k%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   103
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   104
\rulename{diff_mult_distrib}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   105
49109fe3e919 auto generated
paulson
parents:
diff changeset
   106
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   107
m\ mod\ n\ {\isacharasterisk}\ k\ {\isacharequal}\ m\ {\isacharasterisk}\ k\ mod\ {\isacharparenleft}n\ {\isacharasterisk}\ k{\isacharparenright}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   108
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   109
\rulename{mod_mult_distrib}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   110
49109fe3e919 auto generated
paulson
parents:
diff changeset
   111
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   112
P\ {\isacharparenleft}a\ {\isacharminus}\ b{\isacharparenright}\ {\isacharequal}\ {\isacharparenleft}{\isacharparenleft}a\ {\isacharless}\ b\ {\isasymlongrightarrow}\ P\ {\isadigit{0}}{\isacharparenright}\ {\isasymand}\ {\isacharparenleft}{\isasymforall}d{\isachardot}\ a\ {\isacharequal}\ b\ {\isacharplus}\ d\ {\isasymlongrightarrow}\ P\ d{\isacharparenright}{\isacharparenright}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   113
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   114
\rulename{nat_diff_split}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   115
\end{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   116
\isacommand{lemma}\ {\isachardoublequote}{\isacharparenleft}n{\isacharminus}{\isadigit{1}}{\isacharparenright}{\isacharasterisk}{\isacharparenleft}n{\isacharplus}{\isadigit{1}}{\isacharparenright}\ {\isacharequal}\ n{\isacharasterisk}n\ {\isacharminus}\ {\isadigit{1}}{\isachardoublequote}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
   117
\isacommand{apply}\ {\isacharparenleft}simp\ split{\isacharcolon}\ nat{\isacharunderscore}diff{\isacharunderscore}split{\isacharparenright}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
   118
\isacommand{done}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   119
\begin{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   120
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   121
m\ mod\ n\ {\isacharequal}\ {\isacharparenleft}if\ m\ {\isacharless}\ n\ then\ m\ else\ {\isacharparenleft}m\ {\isacharminus}\ n{\isacharparenright}\ mod\ n{\isacharparenright}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   122
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   123
\rulename{mod_if}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   124
49109fe3e919 auto generated
paulson
parents:
diff changeset
   125
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   126
m\ div\ n\ {\isacharasterisk}\ n\ {\isacharplus}\ m\ mod\ n\ {\isacharequal}\ m%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   127
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   128
\rulename{mod_div_equality}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   129
49109fe3e919 auto generated
paulson
parents:
diff changeset
   130
49109fe3e919 auto generated
paulson
parents:
diff changeset
   131
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   132
a\ {\isacharasterisk}\ b\ div\ c\ {\isacharequal}\ a\ {\isacharasterisk}\ {\isacharparenleft}b\ div\ c{\isacharparenright}\ {\isacharplus}\ a\ {\isacharasterisk}\ {\isacharparenleft}b\ mod\ c{\isacharparenright}\ div\ c%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   133
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   134
\rulename{div_mult1_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   135
49109fe3e919 auto generated
paulson
parents:
diff changeset
   136
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   137
a\ {\isacharasterisk}\ b\ mod\ c\ {\isacharequal}\ a\ {\isacharasterisk}\ {\isacharparenleft}b\ mod\ c{\isacharparenright}\ mod\ c%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   138
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   139
\rulename{mod_mult1_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   140
49109fe3e919 auto generated
paulson
parents:
diff changeset
   141
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   142
a\ div\ {\isacharparenleft}b\ {\isacharasterisk}\ c{\isacharparenright}\ {\isacharequal}\ a\ div\ b\ div\ c%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   143
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   144
\rulename{div_mult2_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   145
49109fe3e919 auto generated
paulson
parents:
diff changeset
   146
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   147
a\ mod\ {\isacharparenleft}b\ {\isacharasterisk}\ c{\isacharparenright}\ {\isacharequal}\ b\ {\isacharasterisk}\ {\isacharparenleft}a\ div\ b\ mod\ c{\isacharparenright}\ {\isacharplus}\ a\ mod\ b%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   148
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   149
\rulename{mod_mult2_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   150
49109fe3e919 auto generated
paulson
parents:
diff changeset
   151
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   152
{\isadigit{0}}\ {\isacharless}\ c\ {\isasymLongrightarrow}\ c\ {\isacharasterisk}\ a\ div\ {\isacharparenleft}c\ {\isacharasterisk}\ b{\isacharparenright}\ {\isacharequal}\ a\ div\ b%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   153
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   154
\rulename{div_mult_mult1}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   155
49109fe3e919 auto generated
paulson
parents:
diff changeset
   156
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   157
a\ div\ {\isadigit{0}}\ {\isacharequal}\ {\isadigit{0}}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   158
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   159
\rulename{DIVISION_BY_ZERO_DIV}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   160
49109fe3e919 auto generated
paulson
parents:
diff changeset
   161
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   162
a\ mod\ {\isadigit{0}}\ {\isacharequal}\ a%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   163
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   164
\rulename{DIVISION_BY_ZERO_MOD}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   165
49109fe3e919 auto generated
paulson
parents:
diff changeset
   166
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   167
{\isasymlbrakk}m\ dvd\ n{\isacharsemicolon}\ n\ dvd\ m{\isasymrbrakk}\ {\isasymLongrightarrow}\ m\ {\isacharequal}\ n%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   168
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   169
\rulename{dvd_anti_sym}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   170
49109fe3e919 auto generated
paulson
parents:
diff changeset
   171
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   172
{\isasymlbrakk}k\ dvd\ m{\isacharsemicolon}\ k\ dvd\ n{\isasymrbrakk}\ {\isasymLongrightarrow}\ k\ dvd\ m\ {\isacharplus}\ n%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   173
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   174
\rulename{dvd_add}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   175
49109fe3e919 auto generated
paulson
parents:
diff changeset
   176
For the integers, I'd list a few theorems that somehow involve negative 
49109fe3e919 auto generated
paulson
parents:
diff changeset
   177
numbers.  
49109fe3e919 auto generated
paulson
parents:
diff changeset
   178
49109fe3e919 auto generated
paulson
parents:
diff changeset
   179
Division, remainder of negatives
49109fe3e919 auto generated
paulson
parents:
diff changeset
   180
49109fe3e919 auto generated
paulson
parents:
diff changeset
   181
49109fe3e919 auto generated
paulson
parents:
diff changeset
   182
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   183
{\isacharhash}{\isadigit{0}}\ {\isacharless}\ b\ {\isasymLongrightarrow}\ {\isacharhash}{\isadigit{0}}\ {\isasymle}\ a\ mod\ b%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   184
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   185
\rulename{pos_mod_sign}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   186
49109fe3e919 auto generated
paulson
parents:
diff changeset
   187
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   188
{\isacharhash}{\isadigit{0}}\ {\isacharless}\ b\ {\isasymLongrightarrow}\ a\ mod\ b\ {\isacharless}\ b%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   189
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   190
\rulename{pos_mod_bound}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   191
49109fe3e919 auto generated
paulson
parents:
diff changeset
   192
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   193
b\ {\isacharless}\ {\isacharhash}{\isadigit{0}}\ {\isasymLongrightarrow}\ a\ mod\ b\ {\isasymle}\ {\isacharhash}{\isadigit{0}}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   194
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   195
\rulename{neg_mod_sign}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   196
49109fe3e919 auto generated
paulson
parents:
diff changeset
   197
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   198
b\ {\isacharless}\ {\isacharhash}{\isadigit{0}}\ {\isasymLongrightarrow}\ b\ {\isacharless}\ a\ mod\ b%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   199
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   200
\rulename{neg_mod_bound}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   201
49109fe3e919 auto generated
paulson
parents:
diff changeset
   202
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   203
{\isacharparenleft}a\ {\isacharplus}\ b{\isacharparenright}\ div\ c\ {\isacharequal}\ a\ div\ c\ {\isacharplus}\ b\ div\ c\ {\isacharplus}\ {\isacharparenleft}a\ mod\ c\ {\isacharplus}\ b\ mod\ c{\isacharparenright}\ div\ c%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   204
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   205
\rulename{zdiv_zadd1_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   206
49109fe3e919 auto generated
paulson
parents:
diff changeset
   207
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   208
{\isacharparenleft}a\ {\isacharplus}\ b{\isacharparenright}\ mod\ c\ {\isacharequal}\ {\isacharparenleft}a\ mod\ c\ {\isacharplus}\ b\ mod\ c{\isacharparenright}\ mod\ c%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   209
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   210
\rulename{zmod_zadd1_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   211
49109fe3e919 auto generated
paulson
parents:
diff changeset
   212
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   213
a\ {\isacharasterisk}\ b\ div\ c\ {\isacharequal}\ a\ {\isacharasterisk}\ {\isacharparenleft}b\ div\ c{\isacharparenright}\ {\isacharplus}\ a\ {\isacharasterisk}\ {\isacharparenleft}b\ mod\ c{\isacharparenright}\ div\ c%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   214
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   215
\rulename{zdiv_zmult1_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   216
49109fe3e919 auto generated
paulson
parents:
diff changeset
   217
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   218
a\ {\isacharasterisk}\ b\ mod\ c\ {\isacharequal}\ a\ {\isacharasterisk}\ {\isacharparenleft}b\ mod\ c{\isacharparenright}\ mod\ c%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   219
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   220
\rulename{zmod_zmult1_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   221
49109fe3e919 auto generated
paulson
parents:
diff changeset
   222
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   223
{\isacharhash}{\isadigit{0}}\ {\isacharless}\ c\ {\isasymLongrightarrow}\ a\ div\ {\isacharparenleft}b\ {\isacharasterisk}\ c{\isacharparenright}\ {\isacharequal}\ a\ div\ b\ div\ c%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   224
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   225
\rulename{zdiv_zmult2_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   226
49109fe3e919 auto generated
paulson
parents:
diff changeset
   227
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   228
{\isacharhash}{\isadigit{0}}\ {\isacharless}\ c\ {\isasymLongrightarrow}\ a\ mod\ {\isacharparenleft}b\ {\isacharasterisk}\ c{\isacharparenright}\ {\isacharequal}\ b\ {\isacharasterisk}\ {\isacharparenleft}a\ div\ b\ mod\ c{\isacharparenright}\ {\isacharplus}\ a\ mod\ b%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   229
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   230
\rulename{zmod_zmult2_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   231
49109fe3e919 auto generated
paulson
parents:
diff changeset
   232
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   233
{\isasymbar}x\ {\isacharasterisk}\ y{\isasymbar}\ {\isacharequal}\ {\isasymbar}x{\isasymbar}\ {\isacharasterisk}\ {\isasymbar}y{\isasymbar}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   234
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   235
\rulename{abs_mult}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   236
\end{isamarkuptext}%
10878
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
   237
\isacommand{lemma}\ {\isachardoublequote}{\isasymlbrakk}abs\ x\ {\isacharless}\ a{\isacharsemicolon}\ abs\ y\ {\isacharless}\ b{\isasymrbrakk}\ {\isasymLongrightarrow}\ abs\ x\ {\isacharplus}\ abs\ y\ {\isacharless}\ {\isacharparenleft}a\ {\isacharplus}\ b\ {\isacharcolon}{\isacharcolon}\ int{\isacharparenright}{\isachardoublequote}\isanewline
b254d5ad6dd4 auto update
paulson
parents: 10790
diff changeset
   238
\isacommand{by}\ arith%
10776
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   239
\begin{isamarkuptext}%
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   240
REALS
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   241
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   242
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   243
{\isasymbar}r{\isasymbar}\ {\isacharcircum}\ n\ {\isacharequal}\ {\isasymbar}r\ {\isacharcircum}\ n{\isasymbar}%
10776
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   244
\end{isabelle}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   245
\rulename{realpow_abs}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   246
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   247
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   248
x\ {\isacharless}\ y\ {\isasymLongrightarrow}\ {\isasymexists}r{\isachardot}\ x\ {\isacharless}\ r\ {\isasymand}\ r\ {\isacharless}\ y%
10776
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   249
\end{isabelle}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   250
\rulename{real_dense}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   251
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   252
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   253
{\isasymbar}r{\isasymbar}\ {\isacharcircum}\ n\ {\isacharequal}\ {\isasymbar}r\ {\isacharcircum}\ n{\isasymbar}%
10776
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   254
\end{isabelle}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   255
\rulename{realpow_abs}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   256
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   257
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   258
x\ {\isacharasterisk}\ {\isacharparenleft}y\ {\isacharslash}\ z{\isacharparenright}\ {\isacharequal}\ x\ {\isacharasterisk}\ y\ {\isacharslash}\ z%
10776
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   259
\end{isabelle}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   260
\rulename{real_times_divide1_eq}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   261
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   262
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   263
y\ {\isacharslash}\ z\ {\isacharasterisk}\ x\ {\isacharequal}\ y\ {\isacharasterisk}\ x\ {\isacharslash}\ z%
10776
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   264
\end{isabelle}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   265
\rulename{real_times_divide2_eq}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   266
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   267
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   268
x\ {\isacharslash}\ {\isacharparenleft}y\ {\isacharslash}\ z{\isacharparenright}\ {\isacharequal}\ x\ {\isacharasterisk}\ z\ {\isacharslash}\ y%
10776
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   269
\end{isabelle}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   270
\rulename{real_divide_divide1_eq}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   271
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   272
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   273
x\ {\isacharslash}\ y\ {\isacharslash}\ z\ {\isacharequal}\ x\ {\isacharslash}\ {\isacharparenleft}y\ {\isacharasterisk}\ z{\isacharparenright}%
10776
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   274
\end{isabelle}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   275
\rulename{real_divide_divide2_eq}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   276
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   277
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   278
{\isacharminus}\ x\ {\isacharslash}\ y\ {\isacharequal}\ {\isacharminus}\ {\isacharparenleft}x\ {\isacharslash}\ y{\isacharparenright}%
10776
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   279
\end{isabelle}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   280
\rulename{real_minus_divide_eq}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   281
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   282
\begin{isabelle}%
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   283
x\ {\isacharslash}\ {\isacharminus}\ y\ {\isacharequal}\ {\isacharminus}\ {\isacharparenleft}x\ {\isacharslash}\ y{\isacharparenright}%
10776
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   284
\end{isabelle}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   285
\rulename{real_divide_minus_eq}
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   286
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   287
This last NOT a simprule
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   288
10790
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   289
\begin{isabelle}%
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   290
{\isacharparenleft}x\ {\isacharplus}\ y{\isacharparenright}\ {\isacharslash}\ z\ {\isacharequal}\ x\ {\isacharslash}\ z\ {\isacharplus}\ y\ {\isacharslash}\ z%
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   291
\end{isabelle}
520dd8696927 *** empty log message ***
nipkow
parents: 10776
diff changeset
   292
\rulename{real_add_divide_distrib}%
10776
985066e9495d updated;
wenzelm
parents: 10696
diff changeset
   293
\end{isamarkuptext}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   294
\isacommand{end}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
   295
\end{isabellebody}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   296
%%% Local Variables:
49109fe3e919 auto generated
paulson
parents:
diff changeset
   297
%%% mode: latex
49109fe3e919 auto generated
paulson
parents:
diff changeset
   298
%%% TeX-master: "root"
49109fe3e919 auto generated
paulson
parents:
diff changeset
   299
%%% End: