src/HOL/ex/Eval_Examples.thy
author haftmann
Thu, 20 Sep 2007 16:37:31 +0200
changeset 24659 6b7ac2a43df8
parent 24587 4f2cbf6e563f
child 24835 8c26128f8997
permissions -rw-r--r--
more permissive
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
23268
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
     1
(*  ID:         $Id$
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
     2
    Author:     Florian Haftmann, TU Muenchen
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
     3
*)
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
     4
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
     5
header {* Small examples for evaluation mechanisms *}
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
     6
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
     7
theory Eval_Examples
24659
6b7ac2a43df8 more permissive
haftmann
parents: 24587
diff changeset
     8
imports Eval "~~/src/HOL/Real/Rational"
23268
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
     9
begin
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    10
24292
26ac9fe0e80e added evaluation examples
haftmann
parents: 24280
diff changeset
    11
text {* SML evaluation oracle *}
26ac9fe0e80e added evaluation examples
haftmann
parents: 24280
diff changeset
    12
26ac9fe0e80e added evaluation examples
haftmann
parents: 24280
diff changeset
    13
lemma "True \<or> False" by evaluation
26ac9fe0e80e added evaluation examples
haftmann
parents: 24280
diff changeset
    14
lemma "\<not> (Suc 0 = Suc 1)" by evaluation
26ac9fe0e80e added evaluation examples
haftmann
parents: 24280
diff changeset
    15
lemma "[] = ([]\<Colon> int list)" by evaluation
26ac9fe0e80e added evaluation examples
haftmann
parents: 24280
diff changeset
    16
lemma "[()] = [()]" by evaluation
26ac9fe0e80e added evaluation examples
haftmann
parents: 24280
diff changeset
    17
lemma "fst ([]::nat list, Suc 0) = []" by evaluation
26ac9fe0e80e added evaluation examples
haftmann
parents: 24280
diff changeset
    18
23268
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    19
text {* evaluation oracle *}
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    20
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    21
lemma "True \<or> False" by eval
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    22
lemma "\<not> (Suc 0 = Suc 1)" by eval
24280
c9867bdf2424 updated code generator setup
haftmann
parents: 23268
diff changeset
    23
lemma "[] = ([]\<Colon> int list)" by eval
c9867bdf2424 updated code generator setup
haftmann
parents: 23268
diff changeset
    24
lemma "[()] = [()]" by eval
24292
26ac9fe0e80e added evaluation examples
haftmann
parents: 24280
diff changeset
    25
lemma "fst ([]::nat list, Suc 0) = []" by eval
23268
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    26
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    27
text {* term evaluation *}
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    28
24587
4f2cbf6e563f multi-functional value keyword
haftmann
parents: 24423
diff changeset
    29
value "(Suc 2 + 1) * 4"
4f2cbf6e563f multi-functional value keyword
haftmann
parents: 24423
diff changeset
    30
value "(Suc 2 + 1) * 4"
4f2cbf6e563f multi-functional value keyword
haftmann
parents: 24423
diff changeset
    31
value "(Suc 2 + Suc 0) * Suc 3"
4f2cbf6e563f multi-functional value keyword
haftmann
parents: 24423
diff changeset
    32
value "nat 100"
4f2cbf6e563f multi-functional value keyword
haftmann
parents: 24423
diff changeset
    33
value "(10\<Colon>int) \<le> 12"
4f2cbf6e563f multi-functional value keyword
haftmann
parents: 24423
diff changeset
    34
value "[]::nat list"
4f2cbf6e563f multi-functional value keyword
haftmann
parents: 24423
diff changeset
    35
value "[(nat 100, ())]"
4f2cbf6e563f multi-functional value keyword
haftmann
parents: 24423
diff changeset
    36
value "max (2::int) 4"
24659
6b7ac2a43df8 more permissive
haftmann
parents: 24587
diff changeset
    37
value "of_int 2 / of_int 4 * (1::rat)"
6b7ac2a43df8 more permissive
haftmann
parents: 24587
diff changeset
    38
23268
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    39
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    40
text {* a fancy datatype *}
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    41
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    42
datatype ('a, 'b) bair =
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    43
    Bair "'a\<Colon>order" 'b
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    44
  | Shift "('a, 'b) cair"
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    45
  | Dummy unit
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    46
and ('a, 'b) cair =
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    47
    Cair 'a 'b
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    48
24587
4f2cbf6e563f multi-functional value keyword
haftmann
parents: 24423
diff changeset
    49
value "Shift (Cair (4::nat) [Suc 0])"
23268
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    50
572a483de1b0 renamed ex/Eval_Examples.thy;
wenzelm
parents:
diff changeset
    51
end