src/ZF/Coind/Types.thy
author wenzelm
Fri, 24 Feb 2023 11:07:31 +0100
changeset 77363 cbd053fff24c
parent 76215 a642599ffdea
permissions -rw-r--r--
unused (see also 7b318273a4aa and a1fb4d28e609);
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1478
2b8c2a7547ab expanded tabs
clasohm
parents: 1401
diff changeset
     1
(*  Title:      ZF/Coind/Types.thy
2b8c2a7547ab expanded tabs
clasohm
parents: 1401
diff changeset
     2
    Author:     Jacob Frost, Cambridge University Computer Laboratory
916
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
     3
    Copyright   1995  University of Cambridge
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
     4
*)
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
     5
16417
9bc16273c2d4 migrated theory headers to new format
haftmann
parents: 13339
diff changeset
     6
theory Types imports Language begin
916
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
     7
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
     8
consts
12595
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
     9
  Ty :: i               (* Datatype of types *)
1478
2b8c2a7547ab expanded tabs
clasohm
parents: 1401
diff changeset
    10
  TyConst :: i          (* Abstract type of type constants *)
6112
5e4871c5136b datatype package improvements
paulson
parents: 6068
diff changeset
    11
5e4871c5136b datatype package improvements
paulson
parents: 6068
diff changeset
    12
datatype
12595
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    13
  "Ty" = t_const ("tc \<in> TyConst")
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    14
       | t_fun ("t1 \<in> Ty","t2 \<in> Ty")
916
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    15
  
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    16
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    17
(* Definition of type environments and associated operators *)
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    18
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    19
consts
1401
0c439768f45c removed quotes from consts and syntax sections
clasohm
parents: 1155
diff changeset
    20
  TyEnv :: i
6112
5e4871c5136b datatype package improvements
paulson
parents: 6068
diff changeset
    21
5e4871c5136b datatype package improvements
paulson
parents: 6068
diff changeset
    22
datatype
934
2e0203309287 Replaced rules by defs. Also got rid of tyconstU by
lcp
parents: 916
diff changeset
    23
  "TyEnv" = te_emp
12595
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    24
          | te_owr ("te \<in> TyEnv","x \<in> ExVar","t \<in> Ty") 
916
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    25
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    26
consts
76215
a642599ffdea More syntactic cleanup. LaTeX markup working
paulson <lp15@cam.ac.uk>
parents: 76213
diff changeset
    27
  te_dom :: "i \<Rightarrow> i"
a642599ffdea More syntactic cleanup. LaTeX markup working
paulson <lp15@cam.ac.uk>
parents: 76213
diff changeset
    28
  te_app :: "[i,i] \<Rightarrow> i"
6046
2c8a8be36c94 converted to use new primrec section
paulson
parents: 3840
diff changeset
    29
2c8a8be36c94 converted to use new primrec section
paulson
parents: 3840
diff changeset
    30
2c8a8be36c94 converted to use new primrec section
paulson
parents: 3840
diff changeset
    31
primrec (*domain of the type environment*)
2c8a8be36c94 converted to use new primrec section
paulson
parents: 3840
diff changeset
    32
  "te_dom (te_emp) = 0"
46822
95f1e700b712 mathematical symbols for Isabelle/ZF example theories
paulson
parents: 35762
diff changeset
    33
  "te_dom (te_owr(te,x,v)) = te_dom(te) \<union> {x}"
6046
2c8a8be36c94 converted to use new primrec section
paulson
parents: 3840
diff changeset
    34
2c8a8be36c94 converted to use new primrec section
paulson
parents: 3840
diff changeset
    35
primrec (*lookup up identifiers in the type environment*)
2c8a8be36c94 converted to use new primrec section
paulson
parents: 3840
diff changeset
    36
  "te_app (te_emp,x) = 0"
6068
2d8f3e1f1151 if-then-else syntax for ZF
paulson
parents: 6046
diff changeset
    37
  "te_app (te_owr(te,y,t),x) = (if x=y then t else te_app(te,x))"
916
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    38
12595
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    39
inductive_cases te_owrE [elim!]: "te_owr(te,f,t) \<in> TyEnv"
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    40
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    41
(*redundant??*)
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    42
lemma te_app_owr1: "te_app(te_owr(te,x,t),x) = t"
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    43
by simp
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    44
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    45
(*redundant??*)
76213
e44d86131648 Removal of obsolete ASCII syntax
paulson <lp15@cam.ac.uk>
parents: 46822
diff changeset
    46
lemma te_app_owr2: "x \<noteq> y \<Longrightarrow> te_app(te_owr(te,x,t),y) = te_app(te,y)"
12595
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    47
by auto
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    48
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    49
lemma te_app_owr [simp]:
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    50
     "te_app(te_owr(te,x,t),y) = (if x=y then t else te_app(te,y))"
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    51
by auto
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    52
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    53
lemma te_appI:
76213
e44d86131648 Removal of obsolete ASCII syntax
paulson <lp15@cam.ac.uk>
parents: 46822
diff changeset
    54
     "\<lbrakk>te \<in> TyEnv; x \<in> ExVar; x \<in> te_dom(te)\<rbrakk> \<Longrightarrow> te_app(te,x) \<in> Ty"
12595
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    55
apply (erule_tac P = "x \<in> te_dom (te) " in rev_mp)
13339
0f89104dd377 Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents: 12595
diff changeset
    56
apply (erule TyEnv.induct, auto)
12595
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    57
done
916
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    58
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    59
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    60
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    61
d03bb9f50b3b New example by Jacob Frost, tidied by lcp
lcp
parents:
diff changeset
    62
12595
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    63
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    64
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    65
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    66
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    67
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    68
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    69
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    70
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    71
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    72
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    73
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    74
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    75
0480d02221b8 conversion to Isar
paulson
parents: 11318
diff changeset
    76
end