src/CCL/Term.ML
author nipkow
Fri, 10 May 2002 18:00:48 +0200
changeset 13133 03d20664cb79
parent 5062 fbdb0b541314
child 17456 bcf7544875b2
permissions -rw-r--r--
A new theory of pointer program examples
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1459
d12da312eff4 expanded tabs
clasohm
parents: 1087
diff changeset
     1
(*  Title:      CCL/terms
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     2
    ID:         $Id$
1459
d12da312eff4 expanded tabs
clasohm
parents: 1087
diff changeset
     3
    Author:     Martin Coen, Cambridge University Computer Laboratory
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     4
    Copyright   1993  University of Cambridge
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     5
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     6
For terms.thy.
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     7
*)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     8
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
     9
open Term;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    10
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    11
val simp_can_defs = [one_def,inl_def,inr_def];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    12
val simp_ncan_defs = [if_def,when_def,split_def,fst_def,snd_def,thd_def];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    13
val simp_defs = simp_can_defs @ simp_ncan_defs;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    14
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    15
val ind_can_defs = [zero_def,succ_def,nil_def,cons_def];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    16
val ind_ncan_defs = [ncase_def,nrec_def,lcase_def,lrec_def];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    17
val ind_defs = ind_can_defs @ ind_ncan_defs;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    18
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    19
val data_defs = simp_defs @ ind_defs @ [napply_def];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    20
val genrec_defs = [letrec_def,letrec2_def,letrec3_def];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    21
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    22
(*** Beta Rules, including strictness ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    23
5062
fbdb0b541314 isatool fixgoal;
wenzelm
parents: 3837
diff changeset
    24
Goalw [let_def] "~ t=bot--> let x be t in f(x) = f(t)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    25
by (res_inst_tac [("t","t")] term_case 1);
8
c3d2c6dcf3f0 Installation of new simplfier. Previously appeared to set up the old
lcp
parents: 0
diff changeset
    26
by (ALLGOALS(simp_tac(CCL_ss addsimps [caseBtrue,caseBfalse,caseBpair,caseBlam])));
1087
c1ccf6679a96 replaced store_thm by bind_thm
clasohm
parents: 757
diff changeset
    27
bind_thm("letB", result() RS mp);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    28
5062
fbdb0b541314 isatool fixgoal;
wenzelm
parents: 3837
diff changeset
    29
Goalw [let_def] "let x be bot in f(x) = bot";
642
0db578095e6a CCL/Gfp/coinduct2, coinduct3: modified proofs to suppress deep unification
lcp
parents: 289
diff changeset
    30
by (rtac caseBbot 1);
757
2ca12511676d added qed and qed_goal[w]
clasohm
parents: 642
diff changeset
    31
qed "letBabot";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    32
5062
fbdb0b541314 isatool fixgoal;
wenzelm
parents: 3837
diff changeset
    33
Goalw [let_def] "let x be t in bot = bot";
642
0db578095e6a CCL/Gfp/coinduct2, coinduct3: modified proofs to suppress deep unification
lcp
parents: 289
diff changeset
    34
by (resolve_tac ([caseBbot] RL [term_case]) 1);
8
c3d2c6dcf3f0 Installation of new simplfier. Previously appeared to set up the old
lcp
parents: 0
diff changeset
    35
by (ALLGOALS(simp_tac(CCL_ss addsimps [caseBtrue,caseBfalse,caseBpair,caseBlam])));
757
2ca12511676d added qed and qed_goal[w]
clasohm
parents: 642
diff changeset
    36
qed "letBbbot";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    37
5062
fbdb0b541314 isatool fixgoal;
wenzelm
parents: 3837
diff changeset
    38
Goalw [apply_def] "(lam x. b(x)) ` a = b(a)";
8
c3d2c6dcf3f0 Installation of new simplfier. Previously appeared to set up the old
lcp
parents: 0
diff changeset
    39
by (ALLGOALS(simp_tac(CCL_ss addsimps [caseBtrue,caseBfalse,caseBpair,caseBlam])));
757
2ca12511676d added qed and qed_goal[w]
clasohm
parents: 642
diff changeset
    40
qed "applyB";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    41
5062
fbdb0b541314 isatool fixgoal;
wenzelm
parents: 3837
diff changeset
    42
Goalw [apply_def] "bot ` a = bot";
642
0db578095e6a CCL/Gfp/coinduct2, coinduct3: modified proofs to suppress deep unification
lcp
parents: 289
diff changeset
    43
by (rtac caseBbot 1);
757
2ca12511676d added qed and qed_goal[w]
clasohm
parents: 642
diff changeset
    44
qed "applyBbot";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    45
5062
fbdb0b541314 isatool fixgoal;
wenzelm
parents: 3837
diff changeset
    46
Goalw [fix_def] "fix(f) = f(fix(f))";
642
0db578095e6a CCL/Gfp/coinduct2, coinduct3: modified proofs to suppress deep unification
lcp
parents: 289
diff changeset
    47
by (resolve_tac [applyB RS ssubst] 1 THEN rtac refl 1);
757
2ca12511676d added qed and qed_goal[w]
clasohm
parents: 642
diff changeset
    48
qed "fixB";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    49
5062
fbdb0b541314 isatool fixgoal;
wenzelm
parents: 3837
diff changeset
    50
Goalw [letrec_def]
3837
d7f033c74b38 fixed dots;
wenzelm
parents: 2035
diff changeset
    51
      "letrec g x be h(x,g) in g(a) = h(a,%y. letrec g x be h(x,g) in g(y))";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    52
by (resolve_tac [fixB RS ssubst] 1 THEN 
642
0db578095e6a CCL/Gfp/coinduct2, coinduct3: modified proofs to suppress deep unification
lcp
parents: 289
diff changeset
    53
    resolve_tac [applyB RS ssubst] 1 THEN rtac refl 1);
757
2ca12511676d added qed and qed_goal[w]
clasohm
parents: 642
diff changeset
    54
qed "letrecB";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    55
8
c3d2c6dcf3f0 Installation of new simplfier. Previously appeared to set up the old
lcp
parents: 0
diff changeset
    56
val rawBs = caseBs @ [applyB,applyBbot];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    57
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    58
fun raw_mk_beta_rl defs s = prove_goalw Term.thy defs s
2035
e329b36d9136 Ran expandshort; used stac instead of ssubst
paulson
parents: 1459
diff changeset
    59
           (fn _ => [stac letrecB 1,
1459
d12da312eff4 expanded tabs
clasohm
parents: 1087
diff changeset
    60
                     simp_tac (CCL_ss addsimps rawBs) 1]);
8
c3d2c6dcf3f0 Installation of new simplfier. Previously appeared to set up the old
lcp
parents: 0
diff changeset
    61
fun mk_beta_rl s = raw_mk_beta_rl data_defs s;
c3d2c6dcf3f0 Installation of new simplfier. Previously appeared to set up the old
lcp
parents: 0
diff changeset
    62
c3d2c6dcf3f0 Installation of new simplfier. Previously appeared to set up the old
lcp
parents: 0
diff changeset
    63
fun raw_mk_beta_rl defs s = prove_goalw Term.thy defs s
c3d2c6dcf3f0 Installation of new simplfier. Previously appeared to set up the old
lcp
parents: 0
diff changeset
    64
           (fn _ => [simp_tac (CCL_ss addsimps rawBs 
2035
e329b36d9136 Ran expandshort; used stac instead of ssubst
paulson
parents: 1459
diff changeset
    65
                               setloop (stac letrecB)) 1]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    66
fun mk_beta_rl s = raw_mk_beta_rl data_defs s;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    67
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    68
val ifBtrue    = mk_beta_rl "if true then t else u = t";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    69
val ifBfalse   = mk_beta_rl "if false then t else u = u";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    70
val ifBbot     = mk_beta_rl "if bot then t else u = bot";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    71
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    72
val whenBinl   = mk_beta_rl "when(inl(a),t,u) = t(a)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    73
val whenBinr   = mk_beta_rl "when(inr(a),t,u) = u(a)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    74
val whenBbot   = mk_beta_rl "when(bot,t,u) = bot";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    75
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    76
val splitB     = mk_beta_rl "split(<a,b>,h) = h(a,b)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    77
val splitBbot  = mk_beta_rl "split(bot,h) = bot";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    78
val fstB       = mk_beta_rl "fst(<a,b>) = a";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    79
val fstBbot    = mk_beta_rl "fst(bot) = bot";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    80
val sndB       = mk_beta_rl "snd(<a,b>) = b";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    81
val sndBbot    = mk_beta_rl "snd(bot) = bot";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    82
val thdB       = mk_beta_rl "thd(<a,<b,c>>) = c";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    83
val thdBbot    = mk_beta_rl "thd(bot) = bot";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    84
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    85
val ncaseBzero = mk_beta_rl "ncase(zero,t,u) = t";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    86
val ncaseBsucc = mk_beta_rl "ncase(succ(n),t,u) = u(n)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    87
val ncaseBbot  = mk_beta_rl "ncase(bot,t,u) = bot";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    88
val nrecBzero  = mk_beta_rl "nrec(zero,t,u) = t";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    89
val nrecBsucc  = mk_beta_rl "nrec(succ(n),t,u) = u(n,nrec(n,t,u))";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    90
val nrecBbot   = mk_beta_rl "nrec(bot,t,u) = bot";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    91
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    92
val lcaseBnil  = mk_beta_rl "lcase([],t,u) = t";
289
78541329ff35 changed "." to "$" to eliminate ambiguity
clasohm
parents: 8
diff changeset
    93
val lcaseBcons = mk_beta_rl "lcase(x$xs,t,u) = u(x,xs)";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    94
val lcaseBbot  = mk_beta_rl "lcase(bot,t,u) = bot";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    95
val lrecBnil   = mk_beta_rl "lrec([],t,u) = t";
289
78541329ff35 changed "." to "$" to eliminate ambiguity
clasohm
parents: 8
diff changeset
    96
val lrecBcons  = mk_beta_rl "lrec(x$xs,t,u) = u(x,xs,lrec(xs,t,u))";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    97
val lrecBbot   = mk_beta_rl "lrec(bot,t,u) = bot";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    98
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
    99
val letrec2B = raw_mk_beta_rl (data_defs @ [letrec2_def])
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   100
       "letrec g x y be h(x,y,g) in g(p,q) = \
3837
d7f033c74b38 fixed dots;
wenzelm
parents: 2035
diff changeset
   101
\                     h(p,q,%u v. letrec g x y be h(x,y,g) in g(u,v))";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   102
val letrec3B = raw_mk_beta_rl (data_defs @ [letrec3_def])
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   103
       "letrec g x y z be h(x,y,z,g) in g(p,q,r) = \
3837
d7f033c74b38 fixed dots;
wenzelm
parents: 2035
diff changeset
   104
\                     h(p,q,r,%u v w. letrec g x y z be h(x,y,z,g) in g(u,v,w))";
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   105
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   106
val napplyBzero   = mk_beta_rl "f^zero`a = a";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   107
val napplyBsucc   = mk_beta_rl "f^succ(n)`a = f(f^n`a)";
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   108
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   109
val termBs = [letB,applyB,applyBbot,splitB,splitBbot,
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   110
              fstB,fstBbot,sndB,sndBbot,thdB,thdBbot,
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   111
              ifBtrue,ifBfalse,ifBbot,whenBinl,whenBinr,whenBbot,
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   112
              ncaseBzero,ncaseBsucc,ncaseBbot,nrecBzero,nrecBsucc,nrecBbot,
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   113
              lcaseBnil,lcaseBcons,lcaseBbot,lrecBnil,lrecBcons,lrecBbot,
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   114
              napplyBzero,napplyBsucc];
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   115
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   116
(*** Constructors are injective ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   117
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   118
val term_injs = map (mk_inj_rl Term.thy 
1459
d12da312eff4 expanded tabs
clasohm
parents: 1087
diff changeset
   119
                     [applyB,splitB,whenBinl,whenBinr,ncaseBsucc,lcaseBcons])
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   120
               ["(inl(a) = inl(a')) <-> (a=a')",
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   121
                "(inr(a) = inr(a')) <-> (a=a')",
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   122
                "(succ(a) = succ(a')) <-> (a=a')",
289
78541329ff35 changed "." to "$" to eliminate ambiguity
clasohm
parents: 8
diff changeset
   123
                "(a$b = a'$b') <-> (a=a' & b=b')"];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   124
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   125
(*** Constructors are distinct ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   126
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   127
val term_dstncts = mkall_dstnct_thms Term.thy data_defs (ccl_injs @ term_injs)
289
78541329ff35 changed "." to "$" to eliminate ambiguity
clasohm
parents: 8
diff changeset
   128
                    [["bot","inl","inr"],["bot","zero","succ"],["bot","nil","op $"]];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   129
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   130
(*** Rules for pre-order [= ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   131
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   132
local
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   133
  fun mk_thm s = prove_goalw Term.thy data_defs s (fn _ => 
8
c3d2c6dcf3f0 Installation of new simplfier. Previously appeared to set up the old
lcp
parents: 0
diff changeset
   134
                  [simp_tac (ccl_ss addsimps (ccl_porews)) 1]);
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   135
in
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   136
  val term_porews = map mk_thm ["inl(a) [= inl(a') <-> a [= a'",
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   137
                                "inr(b) [= inr(b') <-> b [= b'",
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   138
                                "succ(n) [= succ(n') <-> n [= n'",
289
78541329ff35 changed "." to "$" to eliminate ambiguity
clasohm
parents: 8
diff changeset
   139
                                "x$xs [= x'$xs' <-> x [= x'  & xs [= xs'"];
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   140
end;
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   141
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   142
(*** Rewriting and Proving ***)
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   143
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   144
val term_rews = termBs @ term_injs @ term_dstncts @ ccl_porews @ term_porews;
8
c3d2c6dcf3f0 Installation of new simplfier. Previously appeared to set up the old
lcp
parents: 0
diff changeset
   145
val term_ss = ccl_ss addsimps term_rews;
0
a5a9c433f639 Initial revision
clasohm
parents:
diff changeset
   146
8
c3d2c6dcf3f0 Installation of new simplfier. Previously appeared to set up the old
lcp
parents: 0
diff changeset
   147
val term_cs = ccl_cs addSEs (term_dstncts RL [notE]) 
c3d2c6dcf3f0 Installation of new simplfier. Previously appeared to set up the old
lcp
parents: 0
diff changeset
   148
                     addSDs (XH_to_Ds term_injs);