src/HOL/Hyperreal/Transcendental.thy
author wenzelm
Wed, 05 Dec 2001 03:13:57 +0100
changeset 12378 86c58273f8c0
parent 12196 a3be6b3a9c0b
child 13958 c1c67582c9b5
permissions -rw-r--r--
removed bang_args;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
12196
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
     1
(*  Title       : Transcendental.thy
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
     2
    Author      : Jacques D. Fleuriot
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
     3
    Copyright   : 1998,1999 University of Cambridge
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
     4
                  1999 University of Edinburgh
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
     5
    Description : Power Series, transcendental functions etc.
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
     6
*)
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
     7
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
     8
Transcendental = NthRoot + Fact + HSeries + EvenOdd + Lim + 
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
     9
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    10
constdefs
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    11
    root :: [nat,real] => real
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    12
    "root n x == (@u. ((0::real) < x --> 0 < u) & (u ^ n = x))"
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    13
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    14
    sqrt :: real => real
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    15
    "sqrt x == root 2 x"
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    16
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    17
    exp :: real => real
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    18
    "exp x == suminf(%n. inverse(real (fact n)) * (x ^ n))"
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    19
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    20
    sin :: real => real
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    21
    "sin x == suminf(%n. (if even(n) then 0 else
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    22
             ((- 1) ^ ((n - Suc 0) div 2))/(real (fact n))) * x ^ n)"
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    23
 
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    24
    diffs :: (nat => real) => nat => real
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    25
    "diffs c == (%n. real (Suc n) * c(Suc n))"
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    26
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    27
    cos :: real => real
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    28
    "cos x == suminf(%n. (if even(n) then ((- 1) ^ (n div 2))/(real (fact n)) 
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    29
                          else 0) * x ^ n)"
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    30
  
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    31
    ln :: real => real
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    32
    "ln x == (@u. exp u = x)"
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    33
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    34
    pi :: real
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    35
    "pi == 2 * (@x. 0 <= (x::real) & x <= 2 & cos x = 0)"
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    36
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    37
    tan :: real => real
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    38
    "tan x == (sin x)/(cos x)"
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    39
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    40
    arcsin :: real => real
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    41
    "arcsin y == (@x. -(pi/2) <= x & x <= pi/2 & sin x = y)"
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    42
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    43
    arcos :: real => real
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    44
    "arcos y == (@x. 0 <= x & x <= pi & cos x = y)"
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    45
     
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    46
    arctan :: real => real
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    47
    "arctan y == (@x. -(pi/2) < x & x < pi/2 & tan x = y)"
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    48
  
a3be6b3a9c0b new theories from Jacques Fleuriot
paulson
parents:
diff changeset
    49
end