src/CTT/Arith.thy
author wenzelm
Fri, 16 Sep 2005 23:01:29 +0200
changeset 17441 5b5feca0344a
parent 12110 f8b4b11cd79d
child 19761 5cd82054c2c6
permissions -rw-r--r--
converted to Isar theory format;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
17441
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
     1
(*  Title:      CTT/Arith.thy
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     2
    ID:         $Id$
1474
3f7d67927fe2 expanded tabs
clasohm
parents: 0
diff changeset
     3
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     4
    Copyright   1991  University of Cambridge
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     5
*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     6
17441
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
     7
header {* Arithmetic operators and their definitions *}
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
     8
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
     9
theory Arith
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    10
imports Bool
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    11
begin
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    12
17441
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    13
text {*
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    14
  Proves about elementary arithmetic: addition, multiplication, etc.
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    15
  Tests definitions and simplifier.
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    16
*}
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    17
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    18
consts
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    19
  "#+"  :: "[i,i]=>i"   (infixr 65)
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    20
  "-"   :: "[i,i]=>i"   (infixr 65)
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    21
  "|-|" :: "[i,i]=>i"   (infixr 65)
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    22
  "#*"  :: "[i,i]=>i"   (infixr 70)
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    23
  div   :: "[i,i]=>i"   (infixr 70)
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    24
  mod   :: "[i,i]=>i"   (infixr 70)
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    25
12110
f8b4b11cd79d eliminated old "symbols" syntax, use "xsymbols" instead;
wenzelm
parents: 10467
diff changeset
    26
syntax (xsymbols)
17441
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    27
  "op #*"      :: "[i, i] => i"   (infixr "#\<times>" 70)
10467
e6e7205e9e91 x-symbol support for Pi, Sigma, -->, : (membership)
paulson
parents: 3837
diff changeset
    28
e6e7205e9e91 x-symbol support for Pi, Sigma, -->, : (membership)
paulson
parents: 3837
diff changeset
    29
syntax (HTML output)
17441
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    30
  "op #*"      :: "[i, i] => i"   (infixr "#\<times>" 70)
10467
e6e7205e9e91 x-symbol support for Pi, Sigma, -->, : (membership)
paulson
parents: 3837
diff changeset
    31
17441
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    32
defs
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    33
  add_def:     "a#+b == rec(a, b, %u v. succ(v))"
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    34
  diff_def:    "a-b == rec(b, a, %u v. rec(v, 0, %x y. x))"
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    35
  absdiff_def: "a|-|b == (a-b) #+ (b-a)"
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    36
  mult_def:    "a#*b == rec(a, 0, %u v. b #+ v)"
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    37
  mod_def:     "a mod b == rec(a, 0, %u v. rec(succ(v) |-| b, 0, %x y. succ(v)))"
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    38
  div_def:     "a div b == rec(a, 0, %u v. rec(succ(u) mod b, succ(v), %x y. v))"
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    39
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    40
ML {* use_legacy_bindings (the_context ()) *}
5b5feca0344a converted to Isar theory format;
wenzelm
parents: 12110
diff changeset
    41
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    42
end