src/HOL/Extraction/QuotRem.thy
author webertj
Fri, 01 Jun 2007 23:21:40 +0200
changeset 23193 1f2d94b6a8ef
parent 22845 5f9138bcb3d7
child 23373 ead82c82da9e
permissions -rw-r--r--
some tests for arith added
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
13405
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
     1
(*  Title:      HOL/Extraction/QuotRem.thy
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
     2
    ID:         $Id$
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
     3
    Author:     Stefan Berghofer, TU Muenchen
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
     4
*)
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
     5
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
     6
header {* Quotient and remainder *}
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
     7
16417
9bc16273c2d4 migrated theory headers to new format
haftmann
parents: 15244
diff changeset
     8
theory QuotRem imports Main begin
13405
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
     9
text {* Derivation of quotient and remainder using program extraction. *}
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    10
13931
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    11
lemma nat_eq_dec: "\<And>n::nat. m = n \<or> m \<noteq> n"
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    12
  apply (induct m)
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    13
  apply (case_tac n)
15244
9473137b3550 mod becuase of chnage in induct
nipkow
parents: 13931
diff changeset
    14
  apply (case_tac [3] n)
17604
5f30179fbf44 rules -> iprover
nipkow
parents: 17145
diff changeset
    15
  apply (simp only: nat.simps, iprover?)+
13405
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    16
  done
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    17
13931
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    18
theorem division: "\<exists>r q. a = Suc b * q + r \<and> r \<le> b"
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    19
proof (induct a)
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    20
  case 0
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    21
  have "0 = Suc b * 0 + 0 \<and> 0 \<le> b" by simp
17604
5f30179fbf44 rules -> iprover
nipkow
parents: 17145
diff changeset
    22
  thus ?case by iprover
13931
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    23
next
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    24
  case (Suc a)
17604
5f30179fbf44 rules -> iprover
nipkow
parents: 17145
diff changeset
    25
  then obtain r q where I: "a = Suc b * q + r" and "r \<le> b" by iprover
13931
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    26
  from nat_eq_dec show ?case
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    27
  proof
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    28
    assume "r = b"
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    29
    with I have "Suc a = Suc b * (Suc q) + 0 \<and> 0 \<le> b" by simp
17604
5f30179fbf44 rules -> iprover
nipkow
parents: 17145
diff changeset
    30
    thus ?case by iprover
13931
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    31
  next
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    32
    assume "r \<noteq> b"
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    33
    hence "r < b" by (simp add: order_less_le)
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    34
    with I have "Suc a = Suc b * q + (Suc r) \<and> (Suc r) \<le> b" by simp
17604
5f30179fbf44 rules -> iprover
nipkow
parents: 17145
diff changeset
    35
    thus ?case by iprover
13931
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    36
  qed
38d43d168e87 Converted main proof to Isar.
berghofe
parents: 13405
diff changeset
    37
qed
13405
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    38
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    39
extract division
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    40
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    41
text {*
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    42
  The program extracted from the above proof looks as follows
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    43
  @{thm [display] division_def [no_vars]}
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    44
  The corresponding correctness theorem is
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    45
  @{thm [display] division_correctness [no_vars]}
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    46
*}
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    47
17145
e623e57b0f44 Adapted to new code generator syntax.
berghofe
parents: 16417
diff changeset
    48
code_module Div
e623e57b0f44 Adapted to new code generator syntax.
berghofe
parents: 16417
diff changeset
    49
contains
13405
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    50
  test = "division 9 2"
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    51
22845
5f9138bcb3d7 changed code generator invocation syntax
haftmann
parents: 21545
diff changeset
    52
code_gen division in SML
20593
5af400cc64d5 added some stuff for code generation 2
haftmann
parents: 17604
diff changeset
    53
13405
d20a4e67afc8 Examples for program extraction in HOL.
berghofe
parents:
diff changeset
    54
end