src/HOL/Types_To_Sets/Examples/Prerequisites.thy
author immler
Wed, 14 Nov 2018 01:31:55 +0000
changeset 69295 b8b33ef47f40
parent 64551 79e9587dbcca
child 69296 bc0b0d465991
permissions -rw-r--r--
use locales in Group_On_With
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
64551
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
     1
(*  Title:      HOL/Types_To_Sets/Examples/Prerequisites.thy
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
     2
    Author:     Ondřej Kunčar, TU München
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
     3
*)
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
     4
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
     5
theory Prerequisites
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
     6
  imports Main
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
     7
begin
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
     8
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
     9
context
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    10
  fixes Rep Abs A T
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    11
  assumes type: "type_definition Rep Abs A"
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    12
  assumes T_def: "T \<equiv> (\<lambda>(x::'a) (y::'b). x = Rep y)"
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    13
begin
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    14
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    15
lemma type_definition_Domainp: "Domainp T = (\<lambda>x. x \<in> A)"
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    16
proof -
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    17
  interpret type_definition Rep Abs A by(rule type)
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    18
  show ?thesis
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    19
    unfolding Domainp_iff[abs_def] T_def fun_eq_iff
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    20
    by (metis Abs_inverse Rep)
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    21
qed
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    22
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    23
end
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    24
69295
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    25
subsection \<open>setting up transfer for local typedef\<close>
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    26
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    27
lemmas [transfer_rule] = \<comment> \<open>prefer right-total rules\<close>
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    28
  right_total_All_transfer
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    29
  right_total_UNIV_transfer
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    30
  right_total_Ex_transfer
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    31
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    32
locale local_typedef = fixes S ::"'b set" and s::"'s itself"
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    33
  assumes Ex_type_definition_S: "\<exists>(Rep::'s \<Rightarrow> 'b) (Abs::'b \<Rightarrow> 's). type_definition Rep Abs S"
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    34
begin
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    35
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    36
definition "rep = fst (SOME (Rep::'s \<Rightarrow> 'b, Abs). type_definition Rep Abs S)"
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    37
definition "Abs = snd (SOME (Rep::'s \<Rightarrow> 'b, Abs). type_definition Rep Abs S)"
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    38
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    39
lemma type_definition_S: "type_definition rep Abs S"
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    40
  unfolding Abs_def rep_def split_beta'
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    41
  by (rule someI_ex) (use Ex_type_definition_S in auto)
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    42
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    43
lemma rep_in_S[simp]: "rep x \<in> S"
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    44
  and rep_inverse[simp]: "Abs (rep x) = x"
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    45
  and Abs_inverse[simp]: "y \<in> S \<Longrightarrow> rep (Abs y) = y"
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    46
  using type_definition_S
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    47
  unfolding type_definition_def by auto
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    48
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    49
definition cr_S where "cr_S \<equiv> \<lambda>s b. s = rep b"
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    50
lemmas Domainp_cr_S = type_definition_Domainp[OF type_definition_S cr_S_def, transfer_domain_rule]
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    51
lemmas right_total_cr_S = typedef_right_total[OF type_definition_S cr_S_def, transfer_rule]
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    52
  and bi_unique_cr_S = typedef_bi_unique[OF type_definition_S cr_S_def, transfer_rule]
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    53
  and left_unique_cr_S = typedef_left_unique[OF type_definition_S cr_S_def, transfer_rule]
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    54
  and right_unique_cr_S = typedef_right_unique[OF type_definition_S cr_S_def, transfer_rule]
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    55
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    56
lemma cr_S_rep[intro, simp]: "cr_S (rep a) a" by (simp add: cr_S_def)
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    57
lemma cr_S_Abs[intro, simp]: "a\<in>S \<Longrightarrow> cr_S a (Abs a)" by (simp add: cr_S_def)
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    58
64551
79e9587dbcca proper session HOL-Types_To_Sets;
wenzelm
parents:
diff changeset
    59
end
69295
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    60
b8b33ef47f40 use locales in Group_On_With
immler
parents: 64551
diff changeset
    61
end