doc-src/TutorialI/Types/document/Numbers.tex
author wenzelm
Wed, 03 Jan 2001 21:24:29 +0100
changeset 10774 4de3a0d3ae28
parent 10696 76d7f6c9a14c
child 10776 985066e9495d
permissions -rw-r--r--
recdef_tc;
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
49109fe3e919 auto generated
paulson
parents:
diff changeset
     5
\isacommand{theory}\ Numbers\ {\isacharequal}\ Main{\isacharcolon}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
     6
\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
     7
\isacommand{ML}\ {\isachardoublequote}Pretty{\isachardot}setmargin\ {\isadigit{6}}{\isadigit{4}}{\isachardoublequote}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
     8
\begin{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
     9
numeric literals; default simprules; can re-orient%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    10
\end{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    11
\isacommand{lemma}\ {\isachardoublequote}{\isacharhash}{\isadigit{2}}\ {\isacharasterisk}\ m\ {\isacharequal}\ m\ {\isacharplus}\ m{\isachardoublequote}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    12
\isacommand{oops}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    13
\begin{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    14
proof\ {\isacharparenleft}prove{\isacharparenright}{\isacharcolon}\ step\ {\isadigit{0}}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    15
\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    16
goal\ {\isacharparenleft}lemma{\isacharparenright}{\isacharcolon}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    17
{\isacharparenleft}{\isacharhash}{\isadigit{2}}{\isasymColon}{\isacharprime}a{\isacharparenright}\ {\isacharasterisk}\ m\ {\isacharequal}\ m\ {\isacharplus}\ m\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    18
\ {\isadigit{1}}{\isachardot}\ {\isacharparenleft}{\isacharhash}{\isadigit{2}}{\isasymColon}{\isacharprime}a{\isacharparenright}\ {\isacharasterisk}\ m\ {\isacharequal}\ m\ {\isacharplus}\ m
49109fe3e919 auto generated
paulson
parents:
diff changeset
    19
49109fe3e919 auto generated
paulson
parents:
diff changeset
    20
49109fe3e919 auto generated
paulson
parents:
diff changeset
    21
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    22
\ \ \ \ \ {\isacharhash}{\isadigit{0}}\ {\isacharequal}\ {\isadigit{0}}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    23
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    24
\rulename{numeral_0_eq_0}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    25
49109fe3e919 auto generated
paulson
parents:
diff changeset
    26
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    27
\ \ \ \ \ {\isacharhash}{\isadigit{1}}\ {\isacharequal}\ {\isadigit{1}}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    28
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    29
\rulename{numeral_1_eq_1}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    30
49109fe3e919 auto generated
paulson
parents:
diff changeset
    31
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    32
\ \ \ \ \ {\isacharhash}{\isadigit{2}}\ {\isacharplus}\ n\ {\isacharequal}\ Suc\ {\isacharparenleft}Suc\ n{\isacharparenright}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    33
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    34
\rulename{add_2_eq_Suc}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    35
49109fe3e919 auto generated
paulson
parents:
diff changeset
    36
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    37
\ \ \ \ \ n\ {\isacharplus}\ {\isacharhash}{\isadigit{2}}\ {\isacharequal}\ Suc\ {\isacharparenleft}Suc\ n{\isacharparenright}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    38
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    39
\rulename{add_2_eq_Suc'}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    40
49109fe3e919 auto generated
paulson
parents:
diff changeset
    41
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    42
\ \ \ \ \ m\ {\isacharplus}\ n\ {\isacharplus}\ k\ {\isacharequal}\ m\ {\isacharplus}\ {\isacharparenleft}n\ {\isacharplus}\ k{\isacharparenright}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    43
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    44
\rulename{add_assoc}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    45
49109fe3e919 auto generated
paulson
parents:
diff changeset
    46
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    47
\ \ \ \ \ m\ {\isacharplus}\ n\ {\isacharequal}\ n\ {\isacharplus}\ m%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    48
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    49
\rulename{add_commute}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    50
49109fe3e919 auto generated
paulson
parents:
diff changeset
    51
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    52
\ \ \ \ \ x\ {\isacharplus}\ {\isacharparenleft}y\ {\isacharplus}\ z{\isacharparenright}\ {\isacharequal}\ y\ {\isacharplus}\ {\isacharparenleft}x\ {\isacharplus}\ z{\isacharparenright}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    53
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    54
\rulename{add_left_commute}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    55
49109fe3e919 auto generated
paulson
parents:
diff changeset
    56
these form add_ac; similarly there is mult_ac%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    57
\end{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    58
\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}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    59
\isacommand{apply}\ {\isacharparenleft}simp\ add{\isacharcolon}\ add{\isacharunderscore}ac\ mult{\isacharunderscore}ac{\isacharparenright}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    60
\isacommand{oops}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    61
\begin{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    62
proof\ {\isacharparenleft}prove{\isacharparenright}{\isacharcolon}\ step\ {\isadigit{0}}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    63
\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    64
goal\ {\isacharparenleft}lemma{\isacharparenright}{\isacharcolon}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    65
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}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    66
\ {\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}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    67
49109fe3e919 auto generated
paulson
parents:
diff changeset
    68
proof\ {\isacharparenleft}prove{\isacharparenright}{\isacharcolon}\ step\ {\isadigit{1}}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    69
\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    70
goal\ {\isacharparenleft}lemma{\isacharparenright}{\isacharcolon}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    71
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}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    72
\ {\isadigit{1}}{\isachardot}\ Suc\ {\isacharparenleft}i\ {\isacharplus}\ {\isacharparenleft}m\ {\isacharasterisk}\ n\ {\isacharplus}\ j\ {\isacharasterisk}\ {\isacharparenleft}k\ {\isacharasterisk}\ l{\isacharparenright}{\isacharparenright}{\isacharparenright}\ {\isacharequal}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
    73
\ \ \ \ f\ {\isacharparenleft}i\ {\isacharplus}\ {\isacharparenleft}m\ {\isacharasterisk}\ n\ {\isacharplus}\ j\ {\isacharasterisk}\ {\isacharparenleft}k\ {\isacharasterisk}\ l{\isacharparenright}{\isacharparenright}{\isacharparenright}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    74
\end{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    75
%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    76
\begin{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    77
\begin{isabelle}%
10696
76d7f6c9a14c *** empty log message ***
nipkow
parents: 10668
diff changeset
    78
\ \ \ \ \ {\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
    79
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    80
\rulename{mult_le_mono}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    81
49109fe3e919 auto generated
paulson
parents:
diff changeset
    82
\begin{isabelle}%
10696
76d7f6c9a14c *** empty log message ***
nipkow
parents: 10668
diff changeset
    83
\ \ \ \ \ {\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
    84
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    85
\rulename{mult_less_mono1}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    86
49109fe3e919 auto generated
paulson
parents:
diff changeset
    87
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    88
\ \ \ \ \ m\ {\isasymle}\ n\ {\isasymLongrightarrow}\ m\ div\ k\ {\isasymle}\ n\ div\ k%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    89
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    90
\rulename{div_le_mono}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    91
49109fe3e919 auto generated
paulson
parents:
diff changeset
    92
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    93
\ \ \ \ \ {\isacharparenleft}m\ {\isacharplus}\ n{\isacharparenright}\ {\isacharasterisk}\ k\ {\isacharequal}\ m\ {\isacharasterisk}\ k\ {\isacharplus}\ n\ {\isacharasterisk}\ k%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    94
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    95
\rulename{add_mult_distrib}
49109fe3e919 auto generated
paulson
parents:
diff changeset
    96
49109fe3e919 auto generated
paulson
parents:
diff changeset
    97
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    98
\ \ \ \ \ {\isacharparenleft}m\ {\isacharminus}\ n{\isacharparenright}\ {\isacharasterisk}\ k\ {\isacharequal}\ m\ {\isacharasterisk}\ k\ {\isacharminus}\ n\ {\isacharasterisk}\ k%
49109fe3e919 auto generated
paulson
parents:
diff changeset
    99
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   100
\rulename{diff_mult_distrib}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   101
49109fe3e919 auto generated
paulson
parents:
diff changeset
   102
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   103
\ \ \ \ \ m\ mod\ n\ {\isacharasterisk}\ k\ {\isacharequal}\ m\ {\isacharasterisk}\ k\ mod\ {\isacharparenleft}n\ {\isacharasterisk}\ k{\isacharparenright}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   104
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   105
\rulename{mod_mult_distrib}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   106
49109fe3e919 auto generated
paulson
parents:
diff changeset
   107
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   108
\ \ \ \ \ 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}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   109
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   110
\rulename{nat_diff_split}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   111
\end{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   112
\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
   113
\isacommand{apply}\ {\isacharparenleft}simp\ split{\isacharcolon}\ nat{\isacharunderscore}diff{\isacharunderscore}split{\isacharparenright}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
   114
\isacommand{done}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   115
\begin{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   116
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   117
\ \ \ \ \ m\ mod\ n\ {\isacharequal}\ {\isacharparenleft}if\ m\ {\isacharless}\ n\ then\ m\ else\ {\isacharparenleft}m\ {\isacharminus}\ n{\isacharparenright}\ mod\ n{\isacharparenright}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   118
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   119
\rulename{mod_if}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   120
49109fe3e919 auto generated
paulson
parents:
diff changeset
   121
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   122
\ \ \ \ \ m\ div\ n\ {\isacharasterisk}\ n\ {\isacharplus}\ m\ mod\ n\ {\isacharequal}\ m%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   123
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   124
\rulename{mod_div_equality}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   125
49109fe3e919 auto generated
paulson
parents:
diff changeset
   126
49109fe3e919 auto generated
paulson
parents:
diff changeset
   127
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   128
\ \ \ \ \ a\ {\isacharasterisk}\ b\ div\ c\ {\isacharequal}\ a\ {\isacharasterisk}\ {\isacharparenleft}b\ div\ c{\isacharparenright}\ {\isacharplus}\ a\ {\isacharasterisk}\ {\isacharparenleft}b\ mod\ c{\isacharparenright}\ div\ c%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   129
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   130
\rulename{div_mult1_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   131
49109fe3e919 auto generated
paulson
parents:
diff changeset
   132
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   133
\ \ \ \ \ a\ {\isacharasterisk}\ b\ mod\ c\ {\isacharequal}\ a\ {\isacharasterisk}\ {\isacharparenleft}b\ mod\ c{\isacharparenright}\ mod\ c%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   134
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   135
\rulename{mod_mult1_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   136
49109fe3e919 auto generated
paulson
parents:
diff changeset
   137
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   138
\ \ \ \ \ a\ div\ {\isacharparenleft}b\ {\isacharasterisk}\ c{\isacharparenright}\ {\isacharequal}\ a\ div\ b\ div\ c%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   139
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   140
\rulename{div_mult2_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   141
49109fe3e919 auto generated
paulson
parents:
diff changeset
   142
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   143
\ \ \ \ \ a\ mod\ {\isacharparenleft}b\ {\isacharasterisk}\ c{\isacharparenright}\ {\isacharequal}\ b\ {\isacharasterisk}\ {\isacharparenleft}a\ div\ b\ mod\ c{\isacharparenright}\ {\isacharplus}\ a\ mod\ b%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   144
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   145
\rulename{mod_mult2_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   146
49109fe3e919 auto generated
paulson
parents:
diff changeset
   147
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   148
\ \ \ \ \ {\isadigit{0}}\ {\isacharless}\ c\ {\isasymLongrightarrow}\ c\ {\isacharasterisk}\ a\ div\ {\isacharparenleft}c\ {\isacharasterisk}\ b{\isacharparenright}\ {\isacharequal}\ a\ div\ b%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   149
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   150
\rulename{div_mult_mult1}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   151
49109fe3e919 auto generated
paulson
parents:
diff changeset
   152
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   153
\ \ \ \ \ a\ div\ {\isadigit{0}}\ {\isacharequal}\ {\isadigit{0}}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   154
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   155
\rulename{DIVISION_BY_ZERO_DIV}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   156
49109fe3e919 auto generated
paulson
parents:
diff changeset
   157
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   158
\ \ \ \ \ a\ mod\ {\isadigit{0}}\ {\isacharequal}\ a%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   159
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   160
\rulename{DIVISION_BY_ZERO_MOD}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   161
49109fe3e919 auto generated
paulson
parents:
diff changeset
   162
\begin{isabelle}%
10696
76d7f6c9a14c *** empty log message ***
nipkow
parents: 10668
diff changeset
   163
\ \ \ \ \ {\isasymlbrakk}m\ dvd\ n{\isacharsemicolon}\ n\ dvd\ m{\isasymrbrakk}\ {\isasymLongrightarrow}\ m\ {\isacharequal}\ n%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   164
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   165
\rulename{dvd_anti_sym}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   166
49109fe3e919 auto generated
paulson
parents:
diff changeset
   167
\begin{isabelle}%
10696
76d7f6c9a14c *** empty log message ***
nipkow
parents: 10668
diff changeset
   168
\ \ \ \ \ {\isasymlbrakk}k\ dvd\ m{\isacharsemicolon}\ k\ dvd\ n{\isasymrbrakk}\ {\isasymLongrightarrow}\ k\ dvd\ {\isacharparenleft}m\ {\isacharplus}\ n{\isacharparenright}%
10602
49109fe3e919 auto generated
paulson
parents:
diff changeset
   169
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   170
\rulename{dvd_add}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   171
49109fe3e919 auto generated
paulson
parents:
diff changeset
   172
For the integers, I'd list a few theorems that somehow involve negative 
49109fe3e919 auto generated
paulson
parents:
diff changeset
   173
numbers.  
49109fe3e919 auto generated
paulson
parents:
diff changeset
   174
49109fe3e919 auto generated
paulson
parents:
diff changeset
   175
Division, remainder of negatives
49109fe3e919 auto generated
paulson
parents:
diff changeset
   176
49109fe3e919 auto generated
paulson
parents:
diff changeset
   177
49109fe3e919 auto generated
paulson
parents:
diff changeset
   178
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   179
\ \ \ \ \ {\isacharhash}{\isadigit{0}}\ {\isacharless}\ b\ {\isasymLongrightarrow}\ {\isacharhash}{\isadigit{0}}\ {\isasymle}\ a\ mod\ b%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   180
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   181
\rulename{pos_mod_sign}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   182
49109fe3e919 auto generated
paulson
parents:
diff changeset
   183
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   184
\ \ \ \ \ {\isacharhash}{\isadigit{0}}\ {\isacharless}\ b\ {\isasymLongrightarrow}\ a\ mod\ b\ {\isacharless}\ b%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   185
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   186
\rulename{pos_mod_bound}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   187
49109fe3e919 auto generated
paulson
parents:
diff changeset
   188
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   189
\ \ \ \ \ b\ {\isacharless}\ {\isacharhash}{\isadigit{0}}\ {\isasymLongrightarrow}\ a\ mod\ b\ {\isasymle}\ {\isacharhash}{\isadigit{0}}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   190
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   191
\rulename{neg_mod_sign}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   192
49109fe3e919 auto generated
paulson
parents:
diff changeset
   193
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   194
\ \ \ \ \ b\ {\isacharless}\ {\isacharhash}{\isadigit{0}}\ {\isasymLongrightarrow}\ b\ {\isacharless}\ a\ mod\ b%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   195
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   196
\rulename{neg_mod_bound}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   197
49109fe3e919 auto generated
paulson
parents:
diff changeset
   198
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   199
\ \ \ \ \ {\isacharparenleft}a\ {\isacharplus}\ b{\isacharparenright}\ div\ c\ {\isacharequal}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
   200
\ \ \ \ \ a\ div\ c\ {\isacharplus}\ b\ div\ c\ {\isacharplus}\ {\isacharparenleft}a\ mod\ c\ {\isacharplus}\ b\ mod\ c{\isacharparenright}\ div\ c%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   201
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   202
\rulename{zdiv_zadd1_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   203
49109fe3e919 auto generated
paulson
parents:
diff changeset
   204
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   205
\ \ \ \ \ {\isacharparenleft}a\ {\isacharplus}\ b{\isacharparenright}\ mod\ c\ {\isacharequal}\ {\isacharparenleft}a\ mod\ c\ {\isacharplus}\ b\ mod\ c{\isacharparenright}\ mod\ c%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   206
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   207
\rulename{zmod_zadd1_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   208
49109fe3e919 auto generated
paulson
parents:
diff changeset
   209
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   210
\ \ \ \ \ a\ {\isacharasterisk}\ b\ div\ c\ {\isacharequal}\ a\ {\isacharasterisk}\ {\isacharparenleft}b\ div\ c{\isacharparenright}\ {\isacharplus}\ a\ {\isacharasterisk}\ {\isacharparenleft}b\ mod\ c{\isacharparenright}\ div\ c%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   211
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   212
\rulename{zdiv_zmult1_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   213
49109fe3e919 auto generated
paulson
parents:
diff changeset
   214
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   215
\ \ \ \ \ a\ {\isacharasterisk}\ b\ mod\ c\ {\isacharequal}\ a\ {\isacharasterisk}\ {\isacharparenleft}b\ mod\ c{\isacharparenright}\ mod\ c%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   216
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   217
\rulename{zmod_zmult1_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   218
49109fe3e919 auto generated
paulson
parents:
diff changeset
   219
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   220
\ \ \ \ \ {\isacharhash}{\isadigit{0}}\ {\isacharless}\ c\ {\isasymLongrightarrow}\ a\ div\ {\isacharparenleft}b\ {\isacharasterisk}\ c{\isacharparenright}\ {\isacharequal}\ a\ div\ b\ div\ c%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   221
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   222
\rulename{zdiv_zmult2_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   223
49109fe3e919 auto generated
paulson
parents:
diff changeset
   224
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   225
\ \ \ \ \ {\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%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   226
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   227
\rulename{zmod_zmult2_eq}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   228
49109fe3e919 auto generated
paulson
parents:
diff changeset
   229
\begin{isabelle}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   230
\ \ \ \ \ {\isasymbar}x\ {\isacharasterisk}\ y{\isasymbar}\ {\isacharequal}\ {\isasymbar}x{\isasymbar}\ {\isacharasterisk}\ {\isasymbar}y{\isasymbar}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   231
\end{isabelle}
49109fe3e919 auto generated
paulson
parents:
diff changeset
   232
\rulename{abs_mult}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   233
\end{isamarkuptext}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   234
\isacommand{end}\isanewline
49109fe3e919 auto generated
paulson
parents:
diff changeset
   235
\end{isabellebody}%
49109fe3e919 auto generated
paulson
parents:
diff changeset
   236
%%% Local Variables:
49109fe3e919 auto generated
paulson
parents:
diff changeset
   237
%%% mode: latex
49109fe3e919 auto generated
paulson
parents:
diff changeset
   238
%%% TeX-master: "root"
49109fe3e919 auto generated
paulson
parents:
diff changeset
   239
%%% End: