src/CTT/Arith.thy
 author kleing Wed Apr 14 14:13:05 2004 +0200 (2004-04-14) changeset 14565 c6dc17aab88a parent 12110 f8b4b11cd79d child 17441 5b5feca0344a permissions -rw-r--r--
use more symbols in HTML output
```     1 (*  Title:      CTT/arith
```
```     2     ID:         \$Id\$
```
```     3     Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
```
```     4     Copyright   1991  University of Cambridge
```
```     5
```
```     6 Arithmetic operators and their definitions
```
```     7
```
```     8 Proves about elementary arithmetic: addition, multiplication, etc.
```
```     9 Tests definitions and simplifier.
```
```    10 *)
```
```    11
```
```    12 Arith = CTT +
```
```    13
```
```    14 consts "#+","-","|-|"   :: "[i,i]=>i"   (infixr 65)
```
```    15        "#*",div,mod     :: "[i,i]=>i"   (infixr 70)
```
```    16
```
```    17 syntax (xsymbols)
```
```    18   "op #*"      :: [i, i] => i   (infixr "#\\<times>" 70)
```
```    19
```
```    20 syntax (HTML output)
```
```    21   "op #*"      :: [i, i] => i   (infixr "#\\<times>" 70)
```
```    22
```
```    23 rules
```
```    24   add_def     "a#+b == rec(a, b, %u v. succ(v))"
```
```    25   diff_def    "a-b == rec(b, a, %u v. rec(v, 0, %x y. x))"
```
```    26   absdiff_def "a|-|b == (a-b) #+ (b-a)"
```
```    27   mult_def    "a#*b == rec(a, 0, %u v. b #+ v)"
```
```    28   mod_def     "a mod b == rec(a, 0, %u v. rec(succ(v) |-| b, 0, %x y. succ(v)))"
```
```    29   div_def     "a div b == rec(a, 0, %u v. rec(succ(u) mod b, succ(v), %x y. v))"
```
```    30 end
```