src/HOL/Datatype_Examples/Lift_BNF.thy
author wenzelm
Wed, 19 Aug 2015 16:21:10 +0200
changeset 60975 5f3d6e16ea78
parent 60918 4ceef1592e8c
child 62137 b8dc1fd7d900
permissions -rw-r--r--
avoid ambiguities on native Windows, such as / vs. /cygdrive/c/cygwin;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
60918
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
     1
theory Lift_BNF
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
     2
imports Main
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
     3
begin
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
     4
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
     5
typedef 'a nonempty_list = "{xs :: 'a list. xs \<noteq> []}"
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
     6
  by blast
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
     7
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
     8
lift_bnf (no_warn_wits) (neset: 'a) nonempty_list
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
     9
  for map: nemap rel: nerel
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    10
  by simp_all
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    11
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    12
typedef ('a :: finite, 'b) fin_nonempty_list = "{(xs :: 'a set, ys :: 'b list). ys \<noteq> []}"
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    13
  by blast
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    14
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    15
lift_bnf (dead 'a :: finite, 'b) fin_nonempty_list
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    16
  by auto
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    17
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    18
datatype 'a tree = Leaf | Node 'a "'a tree nonempty_list"
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    19
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    20
record 'a point =
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    21
  xCoord :: 'a
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    22
  yCoord :: 'a
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    23
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    24
copy_bnf ('a, 's) point_ext
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    25
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    26
typedef 'a it = "UNIV :: 'a set"
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    27
  by blast
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    28
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    29
copy_bnf (plugins del: size) 'a it
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    30
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    31
typedef ('a, 'b) T_prod = "UNIV :: ('a \<times> 'b) set"
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    32
  by blast
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    33
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    34
copy_bnf ('a, 'b) T_prod
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    35
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    36
typedef ('a, 'b, 'c) T_func = "UNIV :: ('a \<Rightarrow> 'b * 'c) set"
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    37
  by blast
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    38
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    39
copy_bnf ('a, 'b, 'c) T_func
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    40
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    41
typedef ('a, 'b) sum_copy = "UNIV :: ('a + 'b) set"
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    42
  by blast
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    43
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    44
copy_bnf ('a, 'b) sum_copy
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    45
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    46
typedef ('a, 'b) T_sum = "{Inl x | x. True} :: ('a + 'b) set"
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    47
  by blast
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    48
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    49
lift_bnf (no_warn_wits) ('a, 'b) T_sum [wits: "Inl :: 'a \<Rightarrow> 'a + 'b"]
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    50
  by (auto simp: map_sum_def sum_set_defs split: sum.splits)
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    51
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    52
typedef ('key, 'value) alist = "{xs :: ('key \<times> 'value) list. (distinct \<circ> map fst) xs}"
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    53
  morphisms impl_of Alist
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    54
proof
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    55
  show "[] \<in> {xs. (distinct o map fst) xs}"
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    56
    by simp
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    57
qed
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    58
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    59
lift_bnf (dead 'k, 'v) alist [wits: "Nil :: ('k \<times> 'v) list"]
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    60
  by simp_all
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    61
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    62
typedef 'a myopt = "{X :: 'a set. finite X \<and> card X \<le> 1}" by (rule exI[of _ "{}"]) auto
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    63
lemma myopt_type_def: "type_definition
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    64
  (\<lambda>X. if card (Rep_myopt X) = 1 then Some (the_elem (Rep_myopt X)) else None)
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    65
  (\<lambda>x. Abs_myopt (case x of Some x \<Rightarrow> {x} | _ \<Rightarrow> {}))
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    66
  (UNIV :: 'a option set)"
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    67
  apply unfold_locales
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    68
    apply (auto simp: Abs_myopt_inverse dest!: card_eq_SucD split: option.splits)
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    69
   apply (metis Rep_myopt_inverse)
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    70
  apply (metis One_nat_def Rep_myopt Rep_myopt_inverse Suc_le_mono card_0_eq le0 le_antisym mem_Collect_eq nat.exhaust)
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    71
  done
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    72
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    73
copy_bnf 'a myopt via myopt_type_def
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    74
4ceef1592e8c new command for lifting BNF structure over typedefs
traytel
parents:
diff changeset
    75
end