src/HOL/Quotient_Examples/Lift_Fun.thy
author wenzelm
Thu, 08 Dec 2022 11:24:43 +0100
changeset 76598 9f97eda3fcf1
parent 73932 fd21b4a93043
child 80914 d97fdabd9e2b
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
47455
26315a545e26 updated headers;
wenzelm
parents: 47308
diff changeset
     1
(*  Title:      HOL/Quotient_Examples/Lift_Fun.thy
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
     2
    Author:     Ondrej Kuncar
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
     3
*)
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
     4
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
     5
section \<open>Example of lifting definitions with contravariant or co/contravariant type variables\<close>
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
     6
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
     7
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
     8
theory Lift_Fun
66453
cc19f7ca2ed6 session-qualified theory imports: isabelle imports -U -i -d '~~/src/Benchmarks' -a;
wenzelm
parents: 63167
diff changeset
     9
imports Main "HOL-Library.Quotient_Syntax"
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    10
begin
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    11
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
    12
text \<open>This file is meant as a test case. 
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    13
  It contains examples of lifting definitions with quotients that have contravariant 
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
    14
  type variables or type variables which are covariant and contravariant in the same time.\<close>
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    15
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
    16
subsection \<open>Contravariant type variables\<close>
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    17
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
    18
text \<open>'a is a contravariant type variable and we are able to map over this variable
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
    19
  in the following four definitions. This example is based on HOL/Fun.thy.\<close>
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    20
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    21
quotient_type
67399
eab6ce8368fa ran isabelle update_op on all sources
nipkow
parents: 66453
diff changeset
    22
('a, 'b) fun' (infixr "\<rightarrow>" 55) = "'a \<Rightarrow> 'b" / "(=)" 
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    23
  by (simp add: identity_equivp)
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    24
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    25
quotient_definition "comp' :: ('b \<rightarrow> 'c) \<rightarrow> ('a \<rightarrow> 'b) \<rightarrow> 'a \<rightarrow> 'c"  is
47092
fa3538d6004b fix Quotient_Examples
kuncar
parents: 45799
diff changeset
    26
  "comp :: ('b \<Rightarrow> 'c) \<Rightarrow> ('a \<Rightarrow> 'b) \<Rightarrow> 'a \<Rightarrow> 'c" done
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    27
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    28
quotient_definition "fcomp' :: ('a \<Rightarrow> 'b) \<Rightarrow> ('b \<Rightarrow> 'c) \<Rightarrow> 'a \<Rightarrow> 'c" is 
47092
fa3538d6004b fix Quotient_Examples
kuncar
parents: 45799
diff changeset
    29
  fcomp done
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    30
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    31
quotient_definition "map_fun' :: ('c \<rightarrow> 'a) \<rightarrow> ('b \<rightarrow> 'd) \<rightarrow> ('a \<rightarrow> 'b) \<rightarrow> 'c \<rightarrow> 'd" 
47092
fa3538d6004b fix Quotient_Examples
kuncar
parents: 45799
diff changeset
    32
  is "map_fun::('c \<Rightarrow> 'a) \<Rightarrow> ('b \<Rightarrow> 'd) \<Rightarrow> ('a \<Rightarrow> 'b) \<Rightarrow> 'c \<Rightarrow> 'd" done
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    33
47092
fa3538d6004b fix Quotient_Examples
kuncar
parents: 45799
diff changeset
    34
quotient_definition "inj_on' :: ('a \<rightarrow> 'b) \<rightarrow> 'a set \<rightarrow> bool" is inj_on done
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    35
47092
fa3538d6004b fix Quotient_Examples
kuncar
parents: 45799
diff changeset
    36
quotient_definition "bij_betw' :: ('a \<rightarrow> 'b) \<rightarrow> 'a set \<rightarrow> 'b set \<rightarrow> bool" is bij_betw done
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    37
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    38
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
    39
subsection \<open>Co/Contravariant type variables\<close> 
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    40
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
    41
text \<open>'a is a covariant and contravariant type variable in the same time.
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
    42
  The following example is a bit artificial. We haven't had a natural one yet.\<close>
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    43
67399
eab6ce8368fa ran isabelle update_op on all sources
nipkow
parents: 66453
diff changeset
    44
quotient_type 'a endofun = "'a \<Rightarrow> 'a" / "(=)" by (simp add: identity_equivp)
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    45
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    46
definition map_endofun' :: "('a \<Rightarrow> 'b) \<Rightarrow> ('b \<Rightarrow> 'a) \<Rightarrow> ('a => 'a) \<Rightarrow> ('b => 'b)"
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    47
  where "map_endofun' f g e = map_fun g f e"
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    48
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    49
quotient_definition "map_endofun :: ('a \<Rightarrow> 'b) \<Rightarrow> ('b \<Rightarrow> 'a) \<Rightarrow> 'a endofun \<Rightarrow> 'b endofun" is
47092
fa3538d6004b fix Quotient_Examples
kuncar
parents: 45799
diff changeset
    50
  map_endofun' done
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    51
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
    52
text \<open>Registration of the map function for 'a endofun.\<close>
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    53
55467
a5c9002bc54d renamed 'enriched_type' to more informative 'functor' (following the renaming of enriched type constructors to bounded natural functors)
blanchet
parents: 47455
diff changeset
    54
functor map_endofun : map_endofun
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    55
proof -
47308
9caab698dbe4 new package Lifting - initial commit
kuncar
parents: 47119
diff changeset
    56
  have "\<forall> x. abs_endofun (rep_endofun x) = x" using Quotient3_endofun by (auto simp: Quotient3_def)
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    57
  then show "map_endofun id id = id" 
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    58
    by (auto simp: map_endofun_def map_endofun'_def map_fun_def fun_eq_iff)
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    59
  
47308
9caab698dbe4 new package Lifting - initial commit
kuncar
parents: 47119
diff changeset
    60
  have a:"\<forall> x. rep_endofun (abs_endofun x) = x" using Quotient3_endofun 
67399
eab6ce8368fa ran isabelle update_op on all sources
nipkow
parents: 66453
diff changeset
    61
    Quotient3_rep_abs[of "(=)" abs_endofun rep_endofun] by blast
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    62
  show "\<And>f g h i. map_endofun f g \<circ> map_endofun h i = map_endofun (f \<circ> h) (i \<circ> g)"
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    63
    by (auto simp: map_endofun_def map_endofun'_def map_fun_def fun_eq_iff) (simp add: a o_assoc) 
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    64
qed
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
    65
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
    66
text \<open>Relator for 'a endofun.\<close>
47097
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
    67
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
    68
definition
55941
a6a380edbec5 renamed 'endofun_rel' to 'rel_endofun'
blanchet
parents: 55467
diff changeset
    69
  rel_endofun' :: "('a \<Rightarrow> 'b \<Rightarrow> bool) \<Rightarrow> ('a \<Rightarrow> 'a) \<Rightarrow> ('b \<Rightarrow> 'b) \<Rightarrow> bool" 
47097
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
    70
where
55941
a6a380edbec5 renamed 'endofun_rel' to 'rel_endofun'
blanchet
parents: 55467
diff changeset
    71
  "rel_endofun' R = (\<lambda>f g. (R ===> R) f g)"
47097
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
    72
55941
a6a380edbec5 renamed 'endofun_rel' to 'rel_endofun'
blanchet
parents: 55467
diff changeset
    73
quotient_definition "rel_endofun :: ('a \<Rightarrow> 'b \<Rightarrow> bool) \<Rightarrow> 'a endofun \<Rightarrow> 'b endofun \<Rightarrow> bool" is
a6a380edbec5 renamed 'endofun_rel' to 'rel_endofun'
blanchet
parents: 55467
diff changeset
    74
  rel_endofun' done
47097
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
    75
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
    76
lemma endofun_quotient:
47308
9caab698dbe4 new package Lifting - initial commit
kuncar
parents: 47119
diff changeset
    77
assumes a: "Quotient3 R Abs Rep"
55941
a6a380edbec5 renamed 'endofun_rel' to 'rel_endofun'
blanchet
parents: 55467
diff changeset
    78
shows "Quotient3 (rel_endofun R) (map_endofun Abs Rep) (map_endofun Rep Abs)"
47308
9caab698dbe4 new package Lifting - initial commit
kuncar
parents: 47119
diff changeset
    79
proof (intro Quotient3I)
47097
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
    80
  show "\<And>a. map_endofun Abs Rep (map_endofun Rep Abs a) = a"
73932
fd21b4a93043 added opaque_combs and renamed hide_lams to opaque_lifting
desharna
parents: 67399
diff changeset
    81
    by (metis (opaque_lifting, no_types) a abs_o_rep id_apply map_endofun.comp map_endofun.id o_eq_dest_lhs)
47097
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
    82
next
55941
a6a380edbec5 renamed 'endofun_rel' to 'rel_endofun'
blanchet
parents: 55467
diff changeset
    83
  show "\<And>a. rel_endofun R (map_endofun Rep Abs a) (map_endofun Rep Abs a)"
47308
9caab698dbe4 new package Lifting - initial commit
kuncar
parents: 47119
diff changeset
    84
  using fun_quotient3[OF a a, THEN Quotient3_rep_reflp]
55941
a6a380edbec5 renamed 'endofun_rel' to 'rel_endofun'
blanchet
parents: 55467
diff changeset
    85
  unfolding rel_endofun_def map_endofun_def map_fun_def o_def map_endofun'_def rel_endofun'_def id_def 
47308
9caab698dbe4 new package Lifting - initial commit
kuncar
parents: 47119
diff changeset
    86
    by (metis (mono_tags) Quotient3_endofun rep_abs_rsp)
47097
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
    87
next
47116
529d2a949bd4 tuned proof - no smt call
kuncar
parents: 47097
diff changeset
    88
  have abs_to_eq: "\<And> x y. abs_endofun x = abs_endofun y \<Longrightarrow> x = y" 
47308
9caab698dbe4 new package Lifting - initial commit
kuncar
parents: 47119
diff changeset
    89
  by (drule arg_cong[where f=rep_endofun]) (simp add: Quotient3_rep_abs[OF Quotient3_endofun])
47116
529d2a949bd4 tuned proof - no smt call
kuncar
parents: 47097
diff changeset
    90
  fix r s
55941
a6a380edbec5 renamed 'endofun_rel' to 'rel_endofun'
blanchet
parents: 55467
diff changeset
    91
  show "rel_endofun R r s =
a6a380edbec5 renamed 'endofun_rel' to 'rel_endofun'
blanchet
parents: 55467
diff changeset
    92
          (rel_endofun R r r \<and>
a6a380edbec5 renamed 'endofun_rel' to 'rel_endofun'
blanchet
parents: 55467
diff changeset
    93
           rel_endofun R s s \<and> map_endofun Abs Rep r = map_endofun Abs Rep s)"
a6a380edbec5 renamed 'endofun_rel' to 'rel_endofun'
blanchet
parents: 55467
diff changeset
    94
    apply(auto simp add: rel_endofun_def rel_endofun'_def map_endofun_def map_endofun'_def)
47308
9caab698dbe4 new package Lifting - initial commit
kuncar
parents: 47119
diff changeset
    95
    using fun_quotient3[OF a a,THEN Quotient3_refl1]
47097
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
    96
    apply metis
47308
9caab698dbe4 new package Lifting - initial commit
kuncar
parents: 47119
diff changeset
    97
    using fun_quotient3[OF a a,THEN Quotient3_refl2]
47097
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
    98
    apply metis
47308
9caab698dbe4 new package Lifting - initial commit
kuncar
parents: 47119
diff changeset
    99
    using fun_quotient3[OF a a, THEN Quotient3_rel]
47097
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
   100
    apply metis
47308
9caab698dbe4 new package Lifting - initial commit
kuncar
parents: 47119
diff changeset
   101
    by (auto intro: fun_quotient3[OF a a, THEN Quotient3_rel, THEN iffD1] simp add: abs_to_eq)
47097
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
   102
qed
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
   103
55941
a6a380edbec5 renamed 'endofun_rel' to 'rel_endofun'
blanchet
parents: 55467
diff changeset
   104
declare [[mapQ3 endofun = (rel_endofun, endofun_quotient)]]
47097
987cb55cac44 fix example files
kuncar
parents: 47092
diff changeset
   105
47092
fa3538d6004b fix Quotient_Examples
kuncar
parents: 45799
diff changeset
   106
quotient_definition "endofun_id_id :: ('a endofun) endofun" is "id :: ('a \<Rightarrow> 'a) \<Rightarrow> ('a \<Rightarrow> 'a)" done
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
   107
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
   108
term  endofun_id_id
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
   109
thm  endofun_id_id_def
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
   110
67399
eab6ce8368fa ran isabelle update_op on all sources
nipkow
parents: 66453
diff changeset
   111
quotient_type 'a endofun' = "'a endofun" / "(=)" by (simp add: identity_equivp)
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
   112
63167
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
   113
text \<open>We have to map "'a endofun" to "('a endofun') endofun", i.e., mapping (lifting)
0909deb8059b isabelle update_cartouches -c -t;
wenzelm
parents: 58889
diff changeset
   114
  over a type variable which is a covariant and contravariant type variable.\<close>
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
   115
47092
fa3538d6004b fix Quotient_Examples
kuncar
parents: 45799
diff changeset
   116
quotient_definition "endofun'_id_id :: ('a endofun') endofun'" is endofun_id_id done
45799
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
   117
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
   118
term  endofun'_id_id
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
   119
thm  endofun'_id_id_def
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
   120
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
   121
7fa9410c746a added an example file with lifting of constants with contravariant and co/contravariant types
kuncar
parents:
diff changeset
   122
end