Quot/Examples/LarryInt.thy
author Christian Urban <urbanc@in.tum.de>
Tue, 26 Jan 2010 00:18:48 +0100
changeset 932 7781c7cbd27e
parent 913 b1f55dd64481
child 1128 17ca92ab4660
permissions -rw-r--r--
used the internal Option.map instead of custom option_map
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     1
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     2
header{*The Integers as Equivalence Classes over Pairs of Natural Numbers*}
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     3
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     4
theory LarryInt 
790
3a48ffcf0f9a generalised absrep function; needs consolidation
Christian Urban <urbanc@in.tum.de>
parents: 767
diff changeset
     5
imports Nat "../QuotMain" "../QuotProd"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     6
begin
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     7
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     8
fun
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     9
  intrel :: "(nat \<times> nat) \<Rightarrow> (nat \<times> nat) \<Rightarrow> bool" 
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    10
where
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    11
  "intrel (x, y) (u, v) = (x + v = u + y)"
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    12
766
df053507edba renamed "quotient" command to "quotient_type"; needs new keyword file to be installed
Christian Urban <urbanc@in.tum.de>
parents: 753
diff changeset
    13
quotient_type int = "nat \<times> nat" / intrel
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    14
  by (auto simp add: equivp_def expand_fun_eq)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    15
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    16
instantiation int :: "{zero, one, plus, uminus, minus, times, ord}"
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    17
begin
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    18
767
37285ec4387d on suggestion of Tobias renamed "quotient_def" to "quotient_definition"; needs new keyword file
Christian Urban <urbanc@in.tum.de>
parents: 766
diff changeset
    19
quotient_definition 
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    20
  Zero_int_def: "0::int" as "(0::nat, 0::nat)"
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    21
767
37285ec4387d on suggestion of Tobias renamed "quotient_def" to "quotient_definition"; needs new keyword file
Christian Urban <urbanc@in.tum.de>
parents: 766
diff changeset
    22
quotient_definition
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    23
  One_int_def: "1::int" as "(1::nat, 0::nat)"
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    24
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    25
definition
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    26
  "add_raw \<equiv> \<lambda>(x, y) (u, v). (x + (u::nat), y + (v::nat))"
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    27
767
37285ec4387d on suggestion of Tobias renamed "quotient_def" to "quotient_definition"; needs new keyword file
Christian Urban <urbanc@in.tum.de>
parents: 766
diff changeset
    28
quotient_definition
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    29
  "(op +) :: int \<Rightarrow> int \<Rightarrow> int" 
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    30
as 
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    31
  "add_raw"
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    32
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    33
definition
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    34
  "uminus_raw \<equiv> \<lambda>(x::nat, y::nat). (y, x)"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    35
767
37285ec4387d on suggestion of Tobias renamed "quotient_def" to "quotient_definition"; needs new keyword file
Christian Urban <urbanc@in.tum.de>
parents: 766
diff changeset
    36
quotient_definition
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    37
  "uminus :: int \<Rightarrow> int" 
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    38
as 
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    39
  "uminus_raw"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    40
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    41
fun
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    42
  mult_raw::"nat \<times> nat \<Rightarrow> nat \<times> nat \<Rightarrow> nat \<times> nat"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    43
where
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    44
  "mult_raw (x, y) (u, v) = (x*u + y*v, x*v + y*u)"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    45
767
37285ec4387d on suggestion of Tobias renamed "quotient_def" to "quotient_definition"; needs new keyword file
Christian Urban <urbanc@in.tum.de>
parents: 766
diff changeset
    46
quotient_definition
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    47
  "(op *) :: int \<Rightarrow> int \<Rightarrow> int" 
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    48
as 
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    49
  "mult_raw"
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    50
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    51
definition
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    52
  "le_raw \<equiv> \<lambda>(x, y) (u, v). (x+v \<le> u+(y::nat))"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    53
767
37285ec4387d on suggestion of Tobias renamed "quotient_def" to "quotient_definition"; needs new keyword file
Christian Urban <urbanc@in.tum.de>
parents: 766
diff changeset
    54
quotient_definition 
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    55
  le_int_def: "(op \<le>) :: int \<Rightarrow> int \<Rightarrow> bool" 
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    56
as 
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    57
  "le_raw"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    58
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    59
definition
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    60
  less_int_def: "z < (w::int) \<equiv> (z \<le> w & z \<noteq> w)"
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    61
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    62
definition
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    63
  diff_int_def:  "z - (w::int) \<equiv> z + (-w)"
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    64
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    65
instance ..
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    66
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    67
end
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    68
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    69
subsection{*Construction of the Integers*}
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    70
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    71
lemma zminus_zminus_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    72
  "uminus_raw (uminus_raw z) = z"
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    73
  by (cases z) (simp add: uminus_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    74
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    75
lemma [quot_respect]:
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    76
  shows "(intrel ===> intrel) uminus_raw uminus_raw"
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    77
  by (simp add: uminus_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    78
  
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
    79
lemma zminus_zminus:
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
    80
  fixes z::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
    81
  shows "- (- z) = z"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
    82
  by(lifting zminus_zminus_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    83
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    84
lemma zminus_0_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    85
  shows "uminus_raw (0, 0) = (0, 0::nat)"
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
    86
  by (simp add: uminus_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    87
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
    88
lemma zminus_0: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
    89
  shows "- 0 = (0::int)"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
    90
  by (lifting zminus_0_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    91
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    92
subsection{*Integer Addition*}
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    93
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    94
lemma zminus_zadd_distrib_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    95
  shows "uminus_raw (add_raw z w) = add_raw (uminus_raw z) (uminus_raw w)"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    96
by (cases z, cases w)
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
    97
   (auto simp add: add_raw_def uminus_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    98
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    99
lemma [quot_respect]:
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   100
  shows "(intrel ===> intrel ===> intrel) add_raw add_raw"
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   101
by (simp add: add_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   102
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   103
lemma zminus_zadd_distrib: 
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   104
  fixes z w::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   105
  shows "- (z + w) = (- z) + (- w)"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   106
  by(lifting zminus_zadd_distrib_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   107
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   108
lemma zadd_commute_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   109
  shows "add_raw z w = add_raw w z"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   110
by (cases z, cases w)
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   111
   (simp add: add_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   112
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   113
lemma zadd_commute:
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   114
  fixes z w::"int"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   115
  shows "(z::int) + w = w + z"
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   116
  by (lifting zadd_commute_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   117
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   118
lemma zadd_assoc_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   119
  shows "add_raw (add_raw z1 z2) z3 = add_raw z1 (add_raw z2 z3)"
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   120
  by (cases z1, cases z2, cases z3) (simp add: add_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   121
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   122
lemma zadd_assoc: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   123
  fixes z1 z2 z3::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   124
  shows "(z1 + z2) + z3 = z1 + (z2 + z3)"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   125
  by (lifting zadd_assoc_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   126
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   127
lemma zadd_0_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   128
  shows "add_raw (0, 0) z = z"
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   129
  by (simp add: add_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   130
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   131
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   132
text {*also for the instance declaration int :: plus_ac0*}
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   133
lemma zadd_0: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   134
  fixes z::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   135
  shows "0 + z = z"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   136
  by (lifting zadd_0_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   137
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   138
lemma zadd_zminus_inverse_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   139
  shows "intrel (add_raw (uminus_raw z) z) (0, 0)"
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   140
  by (cases z) (simp add: add_raw_def uminus_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   141
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   142
lemma zadd_zminus_inverse2: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   143
  fixes z::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   144
  shows "(- z) + z = 0"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   145
  by (lifting zadd_zminus_inverse_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   146
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   147
subsection{*Integer Multiplication*}
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   148
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   149
lemma zmult_zminus_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   150
  shows "mult_raw (uminus_raw z) w = uminus_raw (mult_raw z w)"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   151
apply(cases z, cases w)
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   152
apply(simp add: uminus_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   153
done
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   154
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   155
lemma mult_raw_fst:
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   156
  assumes a: "intrel x z"
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   157
  shows "intrel (mult_raw x y) (mult_raw z y)"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   158
using a
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   159
apply(cases x, cases y, cases z)
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   160
apply(auto simp add: mult_raw.simps intrel.simps)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   161
apply(rename_tac u v w x y z)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   162
apply(subgoal_tac "u*w + z*w = y*w + v*w  &  u*x + z*x = y*x + v*x")
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   163
apply(simp add: mult_ac)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   164
apply(simp add: add_mult_distrib [symmetric])
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   165
done
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   166
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   167
lemma mult_raw_snd:
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   168
  assumes a: "intrel x z"
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   169
  shows "intrel (mult_raw y x) (mult_raw y z)"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   170
using a
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   171
apply(cases x, cases y, cases z)
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   172
apply(auto simp add: mult_raw.simps intrel.simps)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   173
apply(rename_tac u v w x y z)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   174
apply(subgoal_tac "u*w + z*w = y*w + v*w  &  u*x + z*x = y*x + v*x")
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   175
apply(simp add: mult_ac)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   176
apply(simp add: add_mult_distrib [symmetric])
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   177
done
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   178
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   179
lemma [quot_respect]:
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   180
  shows "(intrel ===> intrel ===> intrel) mult_raw mult_raw"
913
b1f55dd64481 Changed fun_map and rel_map to definitions.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 804
diff changeset
   181
apply(simp only: fun_rel_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   182
apply(rule allI | rule impI)+
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   183
apply(rule equivp_transp[OF int_equivp])
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   184
apply(rule mult_raw_fst)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   185
apply(assumption)
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   186
apply(rule mult_raw_snd)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   187
apply(assumption)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   188
done
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   189
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   190
lemma zmult_zminus: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   191
  fixes z w::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   192
  shows "(- z) * w = - (z * w)"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   193
  by (lifting zmult_zminus_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   194
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   195
lemma zmult_commute_raw: 
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   196
  shows "mult_raw z w = mult_raw w z"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   197
apply(cases z, cases w)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   198
apply(simp add: add_ac mult_ac)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   199
done
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   200
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   201
lemma zmult_commute: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   202
  fixes z w::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   203
  shows "z * w = w * z"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   204
  by (lifting zmult_commute_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   205
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   206
lemma zmult_assoc_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   207
  shows "mult_raw (mult_raw z1 z2) z3 = mult_raw z1 (mult_raw z2 z3)"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   208
apply(cases z1, cases z2, cases z3)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   209
apply(simp add: add_mult_distrib2 mult_ac)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   210
done
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   211
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   212
lemma zmult_assoc: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   213
  fixes z1 z2 z3::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   214
  shows "(z1 * z2) * z3 = z1 * (z2 * z3)"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   215
  by (lifting zmult_assoc_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   216
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   217
lemma zadd_mult_distrib_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   218
  shows "mult_raw (add_raw z1 z2) w = add_raw (mult_raw z1 w) (mult_raw z2 w)"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   219
apply(cases z1, cases z2, cases w)
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   220
apply(simp add: add_mult_distrib2 mult_ac add_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   221
done
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   222
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   223
lemma zadd_zmult_distrib: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   224
  fixes z1 z2 w::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   225
  shows "(z1 + z2) * w = (z1 * w) + (z2 * w)"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   226
  by(lifting zadd_mult_distrib_raw)
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   227
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   228
lemma zadd_zmult_distrib2: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   229
  fixes w z1 z2::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   230
  shows "w * (z1 + z2) = (w * z1) + (w * z2)"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   231
  by (simp add: zmult_commute [of w] zadd_zmult_distrib)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   232
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   233
lemma zdiff_zmult_distrib: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   234
  fixes w z1 z2::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   235
  shows "(z1 - z2) * w = (z1 * w) - (z2 * w)"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   236
  by (simp add: diff_int_def zadd_zmult_distrib zmult_zminus)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   237
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   238
lemma zdiff_zmult_distrib2: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   239
  fixes w z1 z2::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   240
  shows "w * (z1 - z2) = (w * z1) - (w * z2)"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   241
  by (simp add: zmult_commute [of w] zdiff_zmult_distrib)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   242
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   243
lemmas int_distrib =
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   244
  zadd_zmult_distrib zadd_zmult_distrib2
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   245
  zdiff_zmult_distrib zdiff_zmult_distrib2
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   246
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   247
lemma zmult_1_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   248
  shows "mult_raw (1, 0) z = z"
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   249
  by (cases z) (auto)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   250
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   251
lemma zmult_1:
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   252
  fixes z::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   253
  shows "1 * z = z"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   254
  by (lifting zmult_1_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   255
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   256
lemma zmult_1_right: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   257
  fixes z::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   258
  shows "z * 1 = z"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   259
  by (rule trans [OF zmult_commute zmult_1])
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   260
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   261
lemma zero_not_one:
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   262
  shows "\<not>(intrel (0, 0) (1::nat, 0::nat))"
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   263
  by auto
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   264
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   265
text{*The Integers Form A Ring*}
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   266
instance int :: comm_ring_1
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   267
proof
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   268
  fix i j k :: int
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   269
  show "(i + j) + k = i + (j + k)" by (simp add: zadd_assoc)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   270
  show "i + j = j + i" by (simp add: zadd_commute)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   271
  show "0 + i = i" by (rule zadd_0)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   272
  show "- i + i = 0" by (rule zadd_zminus_inverse2)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   273
  show "i - j = i + (-j)" by (simp add: diff_int_def)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   274
  show "(i * j) * k = i * (j * k)" by (rule zmult_assoc)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   275
  show "i * j = j * i" by (rule zmult_commute)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   276
  show "1 * i = i" by (rule zmult_1) 
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   277
  show "(i + j) * k = i * k + j * k" by (simp add: int_distrib)
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   278
  show "0 \<noteq> (1::int)" by (lifting zero_not_one)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   279
qed
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   280
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   281
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   282
subsection{*The @{text "\<le>"} Ordering*}
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   283
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   284
lemma zle_refl_raw:
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   285
  shows "le_raw w w"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   286
  by (cases w) (simp add: le_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   287
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   288
lemma [quot_respect]:
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   289
  shows "(intrel ===> intrel ===> op =) le_raw le_raw"
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   290
  by (auto) (simp_all add: le_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   291
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   292
lemma zle_refl: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   293
  fixes w::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   294
  shows "w \<le> w"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   295
  by (lifting zle_refl_raw)
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   296
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   297
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   298
lemma zle_trans_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   299
  shows "\<lbrakk>le_raw i j; le_raw j k\<rbrakk> \<Longrightarrow> le_raw i k"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   300
apply(cases i, cases j, cases k)
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   301
apply(auto simp add: le_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   302
done
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   303
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   304
lemma zle_trans: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   305
  fixes i j k::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   306
  shows "\<lbrakk>i \<le> j; j \<le> k\<rbrakk> \<Longrightarrow> i \<le> k"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   307
  by (lifting zle_trans_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   308
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   309
lemma zle_anti_sym_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   310
  shows "\<lbrakk>le_raw z w; le_raw w z\<rbrakk> \<Longrightarrow> intrel z w"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   311
apply(cases z, cases w)
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   312
apply(auto iff: le_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   313
done
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   314
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   315
lemma zle_anti_sym: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   316
  fixes z w::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   317
  shows "\<lbrakk>z \<le> w; w \<le> z\<rbrakk> \<Longrightarrow> z = w"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   318
  by (lifting zle_anti_sym_raw)
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   319
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   320
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   321
(* Axiom 'order_less_le' of class 'order': *)
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   322
lemma zless_le: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   323
  fixes w z::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   324
  shows "(w < z) = (w \<le> z & w \<noteq> z)"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   325
  by (simp add: less_int_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   326
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   327
instance int :: order
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   328
apply (default)
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   329
apply(auto simp add: zless_le zle_anti_sym)[1]
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   330
apply(rule zle_refl)
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   331
apply(erule zle_trans, assumption)
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   332
apply(erule zle_anti_sym, assumption)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   333
done
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   334
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   335
(* Axiom 'linorder_linear' of class 'linorder': *)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   336
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   337
lemma zle_linear_raw:
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   338
  shows "le_raw z w \<or> le_raw w z"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   339
apply(cases w, cases z)
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   340
apply(auto iff: le_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   341
done
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   342
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   343
lemma zle_linear: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   344
  fixes z w::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   345
  shows "z \<le> w \<or> w \<le> z"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   346
  by (lifting zle_linear_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   347
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   348
instance int :: linorder
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   349
apply(default)
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   350
apply(rule zle_linear)
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   351
done
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   352
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   353
lemma zadd_left_mono_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   354
  shows "le_raw i j \<Longrightarrow> le_raw (add_raw k i) (add_raw k j)"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   355
apply(cases k)
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   356
apply(auto simp add: add_raw_def le_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   357
done
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   358
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   359
lemma zadd_left_mono: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   360
  fixes i j::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   361
  shows "i \<le> j \<Longrightarrow> k + i \<le> k + j"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   362
  by (lifting zadd_left_mono_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   363
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   364
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   365
subsection{*Magnitide of an Integer, as a Natural Number: @{term nat}*}
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   366
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   367
definition
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   368
  "nat_raw \<equiv> \<lambda>(x, y).x - (y::nat)"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   369
767
37285ec4387d on suggestion of Tobias renamed "quotient_def" to "quotient_definition"; needs new keyword file
Christian Urban <urbanc@in.tum.de>
parents: 766
diff changeset
   370
quotient_definition
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   371
  "nat2::int \<Rightarrow> nat"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   372
as
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   373
  "nat_raw"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   374
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   375
abbreviation
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   376
  "less_raw x y \<equiv> (le_raw x y \<and> \<not>(x = y))"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   377
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   378
lemma nat_le_eq_zle_raw:
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   379
  shows "less_raw (0, 0) w \<or> le_raw (0, 0) z \<Longrightarrow> (nat_raw w \<le> nat_raw z) = (le_raw w z)"
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   380
apply(auto)
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   381
sorry
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   382
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   383
lemma [quot_respect]:
753
544b05e03ec0 Removed lambdas on the right hand side. This fixes all 'PROBLEM' comments.
Cezary Kaliszyk <kaliszyk@in.tum.de>
parents: 717
diff changeset
   384
  shows "(intrel ===> op =) nat_raw nat_raw"
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   385
  by (auto iff: nat_raw_def)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   386
804
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   387
lemma nat_le_eq_zle: 
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   388
  fixes w z::"int"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   389
  shows "0 < w \<or> 0 \<le> z \<Longrightarrow> (nat2 w \<le> nat2 z) = (w\<le>z)"
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   390
  unfolding less_int_def
Christian Urban <urbanc@in.tum.de>
parents: 790
diff changeset
   391
  by (lifting nat_le_eq_zle_raw)
715
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   392
3d7a9d4d2bb6 added Int example from Larry
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   393
end